Android:Spinner 抛出无法添加窗口 - token null 不适用于应用程序异常

标签 android spinner android-viewpager

03-02 13:33:40.296: E/AndroidRuntime(525): FATAL EXCEPTION: main
03-02 13:33:40.296: E/AndroidRuntime(525): android.view.WindowManager$BadTokenException: Unable to add window -- token null is not for an application
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.view.ViewRoot.setView(ViewRoot.java:531)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:177)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.view.WindowManagerImpl.addView(WindowManagerImpl.java:91)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.app.Dialog.show(Dialog.java:241)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.app.AlertDialog$Builder.show(AlertDialog.java:802)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.widget.Spinner.performClick(Spinner.java:260)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.view.View$PerformClick.run(View.java:9080)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.os.Handler.handleCallback(Handler.java:587)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.os.Handler.dispatchMessage(Handler.java:92)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.os.Looper.loop(Looper.java:123)
03-02 13:33:40.296: E/AndroidRuntime(525):  at android.app.ActivityThread.main(ActivityThread.java:3683)
03-02 13:33:40.296: E/AndroidRuntime(525):  at java.lang.reflect.Method.invokeNative(Native Method)
03-02 13:33:40.296: E/AndroidRuntime(525):  at java.lang.reflect.Method.invoke(Method.java:507)
03-02 13:33:40.296: E/AndroidRuntime(525):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
03-02 13:33:40.296: E/AndroidRuntime(525):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
03-02 13:33:40.296: E/AndroidRuntime(525):  at dalvik.system.NativeStart.main(Native Method)

没有堆栈跟踪行引用我的应用程序中的一行。我阅读了此内容并在这里找到了对此问题的引用:Android 1.6: "android.view.WindowManager$BadTokenException: Unable to add window -- token null is not for an application"

他们建议在调用 AlertDialog 时使用 this 而不是 getApplicationContext()。以下是我对 Spinner 的调用方式:

mSpinner = (Spinner)layout.findViewById(R.id.s_freqs);
ArrayAdapter<CharSequence> alpha = ArrayAdapter.createFromResource(this, R.array.update_freqs, android.R.layout.simple_spinner_item); //Line in question I'm guessing.
alpha.setDropDownViewResource(android.R.layout.simple_spinner_dropdown_item);
mSpinner.setAdapter(alpha);
AdapterView.OnItemSelectedListener spinnerListener = new AdapterView.OnItemSelectedListener() {

    @Override
    public void onItemSelected(AdapterView<?> parent, View v, int position, long id) {
        SharedPreferences.Editor editor = mPrefs.edit();
        editor.putInt("update", position);
        editor.commit();
        startOrEditAlarm();
    }

    @Override
    public void onNothingSelected(AdapterView<?> arg0) {

    }

};

mSpinner.setOnItemSelectedListener(spinnerListener);

这里可能导致问题的一件事是,此代码所在的方法由 ViewPager 的 instatiateItem() 方法调用。我尝试对相关行进行以下更改:

ArrayAdapter<CharSequence> alpha = ArrayAdapter.createFromResource(getApplicationContext(), R.array.update_freqs, android.R.layout.simple_spinner_item);

ArrayAdapter<CharSequence> alpha = ArrayAdapter.createFromResource(mContext, R.array.update_freqs, android.R.layout.simple_spinner_item); //context member var

ArrayAdapter<CharSequence> alpha = ArrayAdapter.createFromResource(this, R.array.update_freqs, android.R.layout.simple_spinner_item); //activity member var

没有任何作用,总是与我上面发布的异常相同。

正如我上面所说,我认为问题在于这种布局的构建方式。我使用的是 ViewPager,因此 ViewPager 中的 instatiateItem() 方法调用以下代码来启动此 View :

layout = (LinearLayout) inflater.inflate(R.layout.settings, null, false);
initSettingsLayout(layout);

除此之外,这在所有其他方面都效果良好。还值得注意的是,我在同一个 ViewPager 中调用了 AlertDialog,它并没有出现异常行为。

有什么意见吗?谢谢!

编辑:我尝试删除 onItemSelected() 方法的代码。我将其更改为:

@Override
public void onItemSelected(AdapterView<?> parent, View v, int position, long id) {
    Log.e("test test", "test");
}

我得到了与前面的日志行相同的堆栈。

最佳答案

我认为@Roy 关于充气机的问题是正确的。我自己使用 LayoutInflater.from(..) 方法,并传入 getApplicationContext()。切换到“this”完全解决了我的问题。 YMMV。

另外一个注意事项,无论如何,对我来说,这只会在某些 Android 设备上引起问题,而不是在所有设备上。事实上,我的 Galaxy Nexus 运行 ICS 时表现良好,而其他许多则不然。

关于Android:Spinner 抛出无法添加窗口 - token null 不适用于应用程序异常,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/9541077/

相关文章:

android spinner - 如何删除当前选择?

android - ArrayAdapter getItem(position) - 我可以忽略这个 NullPointer 警告吗?

android - 抽屉导航犹豫

java - Android : using java socket. 来自 Android 应用程序中 Gottox 的 io 客户端

android - 如果 View 永远不可见,我应该在 View 生命周期的哪个点取消订阅?

android - 扩展 Spinner 以添加索引,错误膨胀类

android - 每次查看 FragmentStatePagerAdapter 中的 fragment 时执行代码

Android自定义 Intent 过滤器未接收广播?

android - google tag manager,哪里可以下载 android 的二进制容器?

Android Wear DotsPageIndicator 第一次淡化而不是始终可见