2013/11/22

「android.view.WindowManager$BadTokenException: Unable to add window -- 」エラーの対処

Androidアプリを制作中、Thread()を利用してshowDialog(int id)でダイアログを表示した場合、Activityが既に変わっていると下記のエラーが表示されました。

android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@42d617b8 is not valid; is your activity running?
    at android.view.ViewRootImpl.setView(ViewRootImpl.java:589)
    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:326)
    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:224)
    at android.view.WindowManagerImpl$CompatModeWrapper.addView(WindowManagerImpl.java:149)
    at android.view.Window$LocalWindowManager.addView(Window.java:547)
    at android.app.Dialog.show(Dialog.java:285)
    at android.app.Activity.showDialog(Activity.java:3052)
    at android.app.Activity.showDialog(Activity.java:3002)
    at jp.sample.SampleActivity.showReviewDialog(SampleActivity.java:98)
    at android.os.Handler.handleCallback(Handler.java:615)
    at android.os.Handler.dispatchMessage(Handler.java:92)
    at android.os.Looper.loop(Looper.java:213)
    at android.app.ActivityThread.main(ActivityThread.java:4786)
    at java.lang.reflect.Method.invokeNative(Native Method)
    at java.lang.reflect.Method.invoke(Method.java:511)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:789)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:556)
    at dalvik.system.NativeStart.main(Native Method)


そこで、対象のActivityが終了しているかどうかチェックを行うことで対応できます。

if ( isFinishing() == false ) {
            showDialog( DIALOG_ID );
}


ちなみに、showDialog() は、@Deprecated になっているので注意が必要です。


■参考サイト
progressdialog - Android: "BadTokenException: Unable to add window; is your activity running?" at showing dialog in PreferenceActivity - Stack Overflow

Android: android.view.WindowManager$BadTokenException & Android – Displaying Dialogs From Background Threads


0 件のコメント:

コメントを投稿