my broadcast is getting called but PhoneStateListener is not called my code works fine when I run it in emulator but when I try it on actual device PhoneStateListener never gets a call, I am going nutts on this problem
Here is my code:
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
the above code is in onReceive() method and here is my class extensing PhoneStateListener
outside onReceive() but in broadcast class.
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 shows this on incoming call
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
Any suggestion related to it will be accepted
Thanks in advance
Your service is getting cleaned up before the callback gets invoked. You should not really be relying on anything allocated in your
BroadcastReceiverto exist afteronReceiveexits. You should putCustomPhoneStateListenerinServiceorActivity. Then you can use anIntentto launch the activity or service to do your state monitoring.From the
BroadcastReceiverdocs,The reason it is working on the emulator is probably because there are less processes in general on the emulator and for some reason it seems less aggressive about killing off processes.