Получить ListPreference внутри PreferenceScreen - PullRequest
1 голос
/ 15 марта 2011

Как мне получить ListPreference внутри моего PreferenceScreen?

Я пытался со следующим, и они оба выдают исключение null.

findPreference (ключ) getPreferenceScreen (). findPreference (ключ)

private void loadLayout(int appWidgetId) {
SharedPreferences.Editor shared_config = prefs.edit();
Layout layout = db_adapter.fetchLayout(appWidgetId);

...

ListPreference widget_text_color = (ListPreference) findPreference("widget_text_color");
widget_text_color.setValue(String.valueOf(layout.getTextColor()));

...
shared_config.commit();

}

<PreferenceScreen
xmlns:android="http://schemas.android.com/apk/res/android">
...
<PreferenceCategory android:title="Layout/Output">
    ...
    <ListPreference
        android:key="widget_text_color"
        android:title="Text color"
        android:summary="Choose text color"
        android:entries="@array/colors"
        android:entryValues="@array/colors_rgb"
        android:dialogTitle="Choose a color" />
    ...
</PreferenceCategory>

03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): ИСКЛЮЧИТЕЛЬНОЕ ИСКЛЮЧЕНИЕ: основное 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): java.lang.RuntimeException: невозможно запустить действие ComponentInfo {com.feral.widget / com.feral.widget.Prefs}: java.lang.NullPointerException 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:1622) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.ActivityThread.handleLaunchActivity (ActivityThread.java:1638) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.ActivityThread.access $ 1500 (ActivityThread.java:117) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.ActivityThread $ H.handleMessage (ActivityThread.java:928) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.os.Handler.dispatchMessage (Handler.java:99) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.os.Looper.loop (Looper.java:123) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.ActivityThread.main (ActivityThread.java:3647) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на java.lang.reflect.Method.invokeNative (собственный метод) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): в java.lang.reflect.Method.invoke (Method.java:507) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на com.android.internal.os.ZygoteInit $ MethodAndArgsCaller.run (ZygoteInit.java:839) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на com.android.internal.os.ZygoteInit.main (ZygoteInit.java:597) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): в dalvik.system.NativeStart.main (собственный метод) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): вызвано: java.lang.NullPointerException 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на com.feral.widget.Prefs.loadLayout (Prefs.java:234) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на com.feral.widget.Prefs.loadPreference (Prefs.java:267) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на com.feral.widget.Prefs.onCreate (Prefs.java:77) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.Instrumentation.callActivityOnCreate (Instrumentation.java:1047) 03-15 17: 50: 42.250: ОШИБКА / AndroidRuntime (441): на android.app.ActivityThread.performLaunchActivity (ActivityThread.java:1586)

1 Ответ

1 голос
/ 15 марта 2011

Вы звоните addPreferencesFromResource(R.xml.preferences) в свой onCreate PreferenceActivity?

...