1. ホーム
  2. android

[解決済み] Unable to add window -- android.os.BinderProxy is not valid; is your activity running?

2022-06-16 18:33:02

質問

Facebook APIを使ってFacebookに接続したいのですが、以下のような例があります。 https://github.com/facebook/facebook-android-sdk/tree/master/examples/simple

全てOKなのですが、コードを編集しようとすると、ログイン成功後にダイアログの投稿メッセージをこのように表示させたいということなのです。

public void onAuthSucceed() {
        mText.setText("You have logged in! ");   
        //This is the code to call the post message dialog.                     
        mFacebook.dialog(Example.this, "feed",new SampleDialogListener());   
    }

logcatにこのようなエラーが表示されます。

03-02 13:32:08.629: E/AndroidRuntime(14991): android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@405180f8 is not valid; is your activity running?
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.view.ViewRoot.setView(ViewRoot.java:532)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:177)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.view.Window$LocalWindowManager.addView(Window.java:424)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.app.Dialog.show(Dialog.java:241)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.Facebook.dialog(Facebook.java:780)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.Facebook.dialog(Facebook.java:737)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.Example$SampleAuthListener.onAuthSucceed(Example.java:113)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.SessionEvents.onLoginSuccess(SessionEvents.java:78)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.Example$LoginDialogListener.onComplete(Example.java:88)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.Facebook$1.onComplete(Facebook.java:320)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.facebook.android.FbDialog$FbWebViewClient.shouldOverrideUrlLoading(FbDialog.java:144)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.webkit.CallbackProxy.uiOverrideUrlLoading(CallbackProxy.java:218)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.webkit.CallbackProxy.handleMessage(CallbackProxy.java:337)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.os.Handler.dispatchMessage(Handler.java:99)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.os.Looper.loop(Looper.java:130)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at android.app.ActivityThread.main(ActivityThread.java:3687)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at java.lang.reflect.Method.invokeNative(Native Method)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at java.lang.reflect.Method.invoke(Method.java:507)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:625)
03-02 13:32:08.629: E/AndroidRuntime(14991):    at dalvik.system.NativeStart.main(Native Method)

何か思い当たることは?

どのように解決するのですか?

これは、もはや存在しないコンテキストのダイアログを表示するときに発生する可能性があります。よくあるケースは、'show dialog' 操作が非同期操作の後にあり、その操作中に元のアクティビティ (ダイアログの親であること) が破棄される場合です。良い説明は、このブログ記事とコメントを参照してください。

http://dimitar.me/android-displaying-dialogs-from-background-threads/

上記のスタックトレースから、facebook ライブラリが認証操作を非同期でスピンオフしているように見えますが、このシナリオを簡単に作成できる Handler - Callback メカニズム (onComplete がリスナーに呼び出される) を持っています。

私のアプリでこの報告があったとき、それはかなりまれで、ブログ投稿の経験に一致します。アクティビティに何か問題が発生したか、AsyncTask の作業中に破壊されたのです。あなたの修正がどのように毎回この結果になるのか分かりませんが、おそらく、コードが実行されるまでに常に破棄されるダイアログのコンテキストとしてアクティビティを参照しているのでしょうか。

また、アクティビティが実行されているかどうかを判断するのに最適な方法かどうかはわかりませんが、そうするための1つの方法として、この回答を参照してください。

アクティビティがアクティブかどうかを確認する