Я пытаюсь заставить работать ToggleButton, но у меня есть несколько проблем.1. Кажется, он возвращается к значению по умолчанию при нажатии и переходе к другому экрану.2. Я попытался перенести его значение isChecked () в другое действие, используя SharedPreferences, и теперь оно вылетает.
<ToggleButton
android:id="@+id/togBTN"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_below="@+id/homeBtn"
android:layout_centerHorizontal="true"
android:layout_marginTop="106dp"
android:text="Voice Alerts"
android:textOff="OFF"
android:textOn="ON" />
Приведенный выше код находится в моем XML-файле.Код ниже - это код onClickListener для него.
case R.id.togBTN:
SharedPreferences.Editor editor = preferences.edit();
editor.putBoolean("tgpref", tg.isChecked()); // value to store
editor.commit();
break;
}
И этот код - то, где я пытаюсь получить значение
SharedPreferences preferences = getPreferences(MODE_PRIVATE);
boolean tgpref = preferences.getBoolean("tgpref", true); //default is true
if (tgpref = true) //if (tgpref) may be enough, not sure
{
speakValue = true;
}
else
{
speakValue = false;
}
Это то, что я получаю в Logcat
:
02-21 14:49:09.587: W/dalvikvm(483): threadid=1: thread exiting with uncaught exception (group=0x40015560)
02-21 14:49:09.597: E/AndroidRuntime(483): FATAL EXCEPTION: main
02-21 14:49:09.597: E/AndroidRuntime(483): java.lang.NullPointerException
02-21 14:49:09.597: E/AndroidRuntime(483): at ohalleran.stephanie.Traffic.SettingsActivity.onClick(SettingsActivity.java:45)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.view.View.performClick(View.java:2485)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.widget.CompoundButton.performClick(CompoundButton.java:99)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.view.View$PerformClick.run(View.java:9080)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.os.Handler.handleCallback(Handler.java:587)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.os.Handler.dispatchMessage(Handler.java:92)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.os.Looper.loop(Looper.java:130)
02-21 14:49:09.597: E/AndroidRuntime(483): at android.app.ActivityThread.main(ActivityThread.java:3683)
02-21 14:49:09.597: E/AndroidRuntime(483): at java.lang.reflect.Method.invokeNative(Native Method)
02-21 14:49:09.597: E/AndroidRuntime(483): at java.lang.reflect.Method.invoke(Method.java:507)
02-21 14:49:09.597: E/AndroidRuntime(483): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839)
02-21 14:49:09.597: E/AndroidRuntime(483): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597)
02-21 14:49:09.597: E/AndroidRuntime(483): at dalvik.system.NativeStart.main(Native Method)
Буду очень признателен за помощь.