0

最初はオプションのリストを正しく入力するスピナーがあります。次に、アクティビティを切り替えて戻ってスピナーをタップすると、アプリがクラッシュします(以下のログを参照)。

        spinner1 = (Spinner) view.findViewById(R.id.fldWithSpinner1);


        ArrayAdapter<?> aa = new ArrayAdapter<Object>(LocationsUI.this,
                android.R.layout.simple_spinner_item, 
                availableLocations);
        aa.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
                spinner1.setAdapter(aa);

LocationsUIに切り替えるたびに、スピナーが作成されます。スピナーは、LocationsUIが最初に表示されたときにのみ正常に機能します。その後、LocationsUIが再表示された後にスピナーをタップするたびに、クラッシュします。

        10-11 22:35:20.060: E/AndroidRuntime(30904): FATAL EXCEPTION: main
    10-11 22:35:20.060: E/AndroidRuntime(30904): android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@407f6d50 is not valid; is your activity running?
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.view.ViewRoot.setView(ViewRoot.java:538)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:203)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:117)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.view.Window$LocalWindowManager.addView(Window.java:424)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.app.Dialog.show(Dialog.java:241)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.app.AlertDialog$Builder.show(AlertDialog.java:823)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.widget.Spinner.performClick(Spinner.java:261)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.view.View$PerformClick.run(View.java:9249)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.os.Handler.handleCallback(Handler.java:587)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.os.Handler.dispatchMessage(Handler.java:92)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.os.Looper.loop(Looper.java:130)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at android.app.ActivityThread.main(ActivityThread.java:3691)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at java.lang.reflect.Method.invokeNative(Native Method)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at java.lang.reflect.Method.invoke(Method.java:507)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:907)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:665)
    10-11 22:35:20.060: E/AndroidRuntime(30904):    at dalvik.system.NativeStart.main(Native Method)
    10-11 22:35:20.080: E/InputDispatcher(139): channel '40abf270 com.sw.android/com.sw.MyLocAppActivity (server)' ~ Consumer closed input channel or an error occurred.  events=0x8
    10-11 22:35:20.080: E/InputDispatcher(139): channel '40abf270 com.sw.android/com.sw.MyLocAppActivity (server)' ~ Channel is unrecoverably broken and will be disposed!

この問題を解決するための正しい方向性を教えていただけますか?

4

1 に答える 1

1

あなたのLogcatが言うように: android.view.WindowManager$BadTokenException: Unable to add window -- token android.os.BinderProxy@407f6d50 is not valid; is your activity running?

これは、存在しなくなったコンテキストのダイアログを表示しているときに発生する可能性があります。これがあなたが間違っていることを正確に説明できるリンクです:http://dimitar.me/android-displaying-dialogs-from-background-threads/

そしてここに同じリンクからあなたを助けるコードがあります:

private Handler myHandler = new Handler() {
  @Override
  public void handleMessage(Message msg) {
    switch (msg.what) {
      case DISPLAY_DLG:
        if (!isFinishing()) {
        showDialog(MY_DIALOG);
        }
      break;
    }
  }
};
于 2012-10-12T04:46:25.670 に答える