ブロードキャストが呼び出されますが、PhoneStateListenerが呼び出されません。エミュレーターで実行するとコードは正常に機能しますが、実際のデバイスで試してみると、PhoneStateListenerが呼び出されないため、この問題に悩まされます。コードは次のとおりです。
TelephonyManager telephony = (TelephonyManager)context.getSystemService(Context.TELEPHONY_SERVICE); //TelephonyManager object
CustomPhoneStateListener customPhoneListener = new CustomPhoneStateListener();
telephony.listen(customPhoneListener, PhoneStateListener.LISTEN_CALL_STATE); //Register our listener with TelephonyManager
上記のコードはonReceive()メソッドにあり、これがonReceive()の外部であるがブロードキャストクラスにあるPhoneStateListenerを拡張する私のクラスです。
public class CustomPhoneStateListener extends PhoneStateListener {
private static final String TAG = "CustomPhoneStateListener";
@Override
public void onCallStateChanged(int state, String phonenumber){
if(phonenumber!=null && phonenumber.length()>0)
incoming_nr=phonenumber;
act=new Call_RecorderActivity();
switch(state){
case TelephonyManager.CALL_STATE_RINGING:
Log.d(TAG, "CALL_STATE_RINGING");
prev_state=state;
break;
case TelephonyManager.CALL_STATE_OFFHOOK:
Log.d(TAG, "CALL_STATE_OFFHOOK");
prev_state=state;
break;
case TelephonyManager.CALL_STATE_IDLE:
prev_state=state;
Log.d(TAG, "CALL_STATE_IDLE==>"+incoming_nr);
break;
// Intent.FLAG_ACTIVITY_BROUGHT_TO_FRONT
// |Intent.FLAG_ACTIVITY_REORDER_TO_FRONT
} //switch close
}
}
logcatは着信時にこれを表示します
01-22 11:25:12.529: I/IncomingCallReceiver(1463): Bundle[mParcelledData.dataSize=168]
01-22 11:25:12.539: I/IncomingCallReceiver(1463): State: RINGING
01-22 11:25:12.539: I/IncomingCallReceiver(1463): Incomng Number: +9184848xxxx2
01-22 11:25:12.779: D/CustomPhoneStateListener(1463): CALL_STATE_IDLE==>+9184848xxxx2
01-22 11:25:16.299: I/IncomingCallReceiver(1463): Bundle[mParcelledData.dataSize=92]
01-22 11:25:16.299: I/IncomingCallReceiver(1463): State: OFFHOOK
01-22 11:25:18.849: I/IncomingCallReceiver(1463): Bundle[mParcelledData.dataSize=88]
01-22 11:25:18.849: I/IncomingCallReceiver(1463): State: IDLE
それに関連する提案は受け付けられますよろしくお願いします