2011-07-10 29 views
1

私はこれが難しいとは思えません。私は、私がonClickListenerを実装するために必要なものはすべて持っていると確信しています。私は何かを逃しているのですが、なぜこれが強制終了するのでしょうか?私は見てスタックを提供しています。どんな助けも素晴らしいだろう。これは、ユーザー設定を保存する単純な活動であると考えられていました。このコードをコメントアウトすると、アクティビティにアクティビティが表示されます。setOnPreferenceClickListenerヘルプ、アクティビティが開始されるときに強制する

Preference customPref = (Preference) findPreference("customPref"); 

customPref.setOnPreferenceClickListener(new OnPreferenceClickListener() { //this line forcecloses every time i run the activity. 
    @Override 
    public boolean onPreferenceClick(Preference preference) { 
     Toast.makeText(getBaseContext(), 
         "The custom preference has been clicked", 
         Toast.LENGTH_LONG) 
      .show(); 
     SharedPreferences customSharedPreference = getSharedPreferences(
       "myCustomSharedPrefs", Activity.MODE_PRIVATE); 
     SharedPreferences.Editor editor = customSharedPreference.edit(); 
     editor.putString("myCustomPref", "The preference has been clicked"); 
     editor.commit(); 
     return true; 
    } 
}); 

ログ:

07-10 16:36:47.137: WARN/System.err(1042): java.lang.NullPointerException 
07-10 16:36:47.147: WARN/System.err(1042):  at com.nyneaxis.android.mpg.Preferences.onCreate(Preferences.java:22) 
07-10 16:36:47.147: WARN/System.err(1042):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1047) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2459) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2512) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread.access$2200(ActivityThread.java:119) 
07-10 16:36:47.157: WARN/System.err(1042):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1863) 
07-10 16:36:47.167: WARN/System.err(1042):  at android.os.Handler.dispatchMessage(Handler.java:99) 
07-10 16:36:47.167: WARN/System.err(1042):  at android.os.Looper.loop(Looper.java:123) 
07-10 16:36:47.167: WARN/System.err(1042):  at android.app.ActivityThread.main(ActivityThread.java:4363) 
07-10 16:36:47.167: WARN/System.err(1042):  at java.lang.reflect.Method.invokeNative(Native Method) 
07-10 16:36:47.177: WARN/System.err(1042):  at java.lang.reflect.Method.invoke(Method.java:521) 
07-10 16:36:47.177: WARN/System.err(1042):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:860) 
07-10 16:36:47.177: WARN/System.err(1042):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:618) 
07-10 16:36:47.177: WARN/System.err(1042):  at dalvik.system.NativeStart.main(Native Method) 
+0

'findPreference(" customPref ")'が 'null'を返すように見えます。これを確認できますか? –

答えて

4

あなたcustomPref変数がnullであるように見えます。あなたの好みのxml(あなたが1つを使用する場合)にキーcustomPrefの設定を持っていることを確認するか、そこにキーのスペルを間違えたかもしれません。

+0

私はそれがそれほど単純であることを知っていました。 –

関連する問題