【发布时间】:2014-01-29 11:24:15
【问题描述】:
我想获得打电话给我的应用程序的电话号码。但是当我收到一个被屏蔽的号码时,我的应用程序崩溃了。我使用 onCallStateChanged()。我已经简化了我的测试代码。它仍然崩溃了。这是代码(它们在活动中):
public void onCreate() {
super.onCreate();
TelephonyManager manager = (TelephonyManager) getSystemService(Service.TELEPHONY_SERVICE);
manager.listen(listener, PhoneStateListener.LISTEN_CALL_STATE);
}
private PhoneStateListener listener = new PhoneStateListener(){
@Override
public void onCallStateChanged(int state, String incomingNumber){
switch (state) {
case TelephonyManager.CALL_STATE_RINGING:
if(incomingNumber.isEmpty()){
Log.i("PhoneStateListener incomingNumber", "void");
}else{
Log.i("PhoneStateListener incomingNumber", "not void");
}
break;
case TelephonyManager.CALL_STATE_IDLE:
break;
case TelephonyManager.CALL_STATE_OFFHOOK:
break;
default:
break;
}
}
};
还有我遇到的错误:
01-29 12:10:37.479: W/dalvikvm(7141): threadid=1: thread exiting with uncaught exception (group=0x41ddc700)
01-29 12:10:37.484: E/AndroidRuntime(7141): FATAL EXCEPTION: main
01-29 12:10:37.484: E/AndroidRuntime(7141): java.lang.NullPointerException
01-29 12:10:37.484: E/AndroidRuntime(7141): at com.aif.app.MonitorCallingService$1.onCallStateChanged(MonitorCallingService.java:77)
01-29 12:10:37.484: E/AndroidRuntime(7141): at android.telephony.PhoneStateListener$2.handleMessage(PhoneStateListener.java:454)
01-29 12:10:37.484: E/AndroidRuntime(7141): at android.os.Handler.dispatchMessage(Handler.java:99)
01-29 12:10:37.484: E/AndroidRuntime(7141): at android.os.Looper.loop(Looper.java:176)
01-29 12:10:37.484: E/AndroidRuntime(7141): at android.app.ActivityThread.main(ActivityThread.java:5419)
01-29 12:10:37.484: E/AndroidRuntime(7141): at java.lang.reflect.Method.invokeNative(Native Method)
01-29 12:10:37.484: E/AndroidRuntime(7141): at java.lang.reflect.Method.invoke(Method.java:525)
01-29 12:10:37.484: E/AndroidRuntime(7141): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1046)
01-29 12:10:37.484: E/AndroidRuntime(7141): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:862)
01-29 12:10:37.484: E/AndroidRuntime(7141): at dalvik.system.NativeStart.main(Native Method)
是否可能是函数 onCallStateChanged() 中存在内部错误,带有掩码?
有人可以帮助我吗?非常感谢。
【问题讨论】:
标签: android call telephonymanager phone-state-listener