2012-03-02 10 views
2
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"Android:Spinner throwingウィンドウを追加できません - トークンnullはアプリケーション例外ではありません。

彼らはthis代わりのgetApplicationContextを(使用をお勧めします)AlertDialogを呼び出すとき。ここで私はスピナーを呼び出しています方法です。ここで問題を引き起こしている可能性があり

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()メソッドは、このビューを起動するには、次のコードを呼び出す:

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

これは、他のすべての面で正常に動作しますが、これ。私はこの同じViewPagerでAlertDialogを呼び出し、それは間違いではないことに注意する価値があります。

入力がありますか?ありがとうございました!

EDIT:onItemSelected()メソッドのコードを削除しようとしました。私はそれを次のように変更しました:

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

私はそれに先行するそのログ行で同じスタックを取得します。

+0

私は 'mPrefs'行の宣言が間違っていると思います、あなたはそれを制御できますか?たぶん、あなたの内側のメソッドはそれを呼び出すことはできません。 –

+0

メソッドを変更して1つのログ行しか含まないようにすると、ログ行は表示されますが、エラーは継続します。私は元の質問をこれで更新します。 – JMRboosties

+0

質問を理解していない - あなたが入るとき私にping? – Graeme

答えて

1

インフルエーターについての質問で@Royが正しいと思っています。私はLayoutInflater.from(..)メソッドを自分で使い、getApplicationContext()を渡していました。 「this」に切り替えると、問題が完全に修正されました。 YMMV。

もう1つのサイドノートは、とにかく、これは一部のAndroid搭載端末でのみ問題で、すべてではありませんでした。実際、Galaxy NexusはICSを走らせていたが、他の多くはそうではなかった。

関連する問題