PreferenceActivity を使用してアプリケーションに設定を追加しようとしています (API レベル 8 をターゲットにしています)。1 つのチェックボックスのみで開始しました。
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<CheckBoxPreference
android:key="pref_fps"
android:title="FPS"
android:defaultValue="false" />
</PreferenceScreen>
私の PreferenceActivity サブクラスは、「onCreate」メソッドを 1 つだけ定義します。
@Override public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.preferences);
}
最初はすべて正常に動作しているように見えましたが、アプリケーションの再起動後に設定が失われていることに気付きました。ログを見ると、設定をディスクに保存できないようです。PreferenceActivity のチェックボックスをクリックするたびに、次の例外が発生します。
W/ApplicationContext( 9542): writeFileLocked: Got exception:
W/ApplicationContext( 9542): java.io.UnsupportedEncodingException: utf-8
W/ApplicationContext( 9542): at com.android.internal.util.FastXmlSerializer.setOutput(FastXmlSerializer.java:297)
W/ApplicationContext( 9542): at com.android.internal.util.XmlUtils.writeMapXml(XmlUtils.java:181)
W/ApplicationContext( 9542): at android.app.ContextImpl$SharedPreferencesImpl.writeFileLocked(ContextImpl.java:2928)
W/ApplicationContext( 9542): at android.app.ContextImpl$SharedPreferencesImpl.access$300(ContextImpl.java:2676)
W/ApplicationContext( 9542): at android.app.ContextImpl$SharedPreferencesImpl$EditorImpl.commit(ContextImpl.java:2861)
W/ApplicationContext( 9542): at android.preference.Preference.tryCommit(Preference.java:1198)
W/ApplicationContext( 9542): at android.preference.Preference.persistBoolean(Preference.java:1403)
W/ApplicationContext( 9542): at android.preference.CheckBoxPreference.setChecked(CheckBoxPreference.java:154)
W/ApplicationContext( 9542): at android.preference.CheckBoxPreference.onClick(CheckBoxPreference.java:143)
W/ApplicationContext( 9542): at android.preference.Preference.performClick(Preference.java:810)
W/ApplicationContext( 9542): at android.preference.PreferenceScreen.onItemClick(PreferenceScreen.java:198)
W/ApplicationContext( 9542): at android.widget.AdapterView.performItemClick(AdapterView.java:284)
W/ApplicationContext( 9542): at android.widget.ListView.performItemClick(ListView.java:3382)
W/ApplicationContext( 9542): at android.widget.AbsListView$PerformClick.run(AbsListView.java:1696)
W/ApplicationContext( 9542): at android.os.Handler.handleCallback(Handler.java:587)
W/ApplicationContext( 9542): at android.os.Handler.dispatchMessage(Handler.java:92)
W/ApplicationContext( 9542): at android.os.Looper.loop(Looper.java:144)
W/ApplicationContext( 9542): at android.app.ActivityThread.main(ActivityThread.java:4937)
W/ApplicationContext( 9542): at java.lang.reflect.Method.invokeNative(Native Method)
W/ApplicationContext( 9542): at java.lang.reflect.Method.invoke(Method.java:521)
W/ApplicationContext( 9542): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
W/ApplicationContext( 9542): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
W/ApplicationContext( 9542): at dalvik.system.NativeStart.main(Native Method)
W/ApplicationContext( 9542): Caused by: java.nio.charset.UnsupportedCharsetException: The unsupported charset name is "utf-8".
W/ApplicationContext( 9542): at java.nio.charset.Charset.forName(Charset.java:544)
W/ApplicationContext( 9542): at com.android.internal.util.FastXmlSerializer.setOutput(FastXmlSerializer.java:292)
W/ApplicationContext( 9542): ... 22 more
動作は、エミュレーターと実際のデバイスで同じです。
私は何を間違っていますか?