问题Main.log:
FATAL EXCEPTION: main
Process: com.android.phone, PID: 761
android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@1cb8bd0 is not valid; is your activity running?
at android.view.ViewRootImpl.setView(ViewRootImpl.java:562)
at android.view.WindowManagerGlobal.addView(WindowManagerGlobal.java:282)
at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:85)
at android.app.Dialog.show(Dialog.java:298)
at android.preference.DialogPreference.showDialog(DialogPreference.java:316)
at com.android.settings.EditPinPreference.showDialog(EditPinPreference.java:103)
at com.android.settings.IccLockSettings.handleGetRemainTimesResponse(IccLockSettings.java:174)
at com.android.settings.IccLockSettings.access$300(IccLockSettings.java:71)
at com.android.settings.IccLockSettings$1.handleMessage(IccLockSettings.java:156)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5345)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:947)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:742)
原因分析:
从错误信息我们也可以明白其原因,此问题根本原因就是由于将要弹出的dialog所要依附的View已经不存在导致的。
问题解决:
if(!isFinishing()){ //在showDialog之前,先对此Activity进行判断其是否依然存在,进行规避。
setDialogValues();
mPinDialog.showDialog(null);
}