Sono nuovo nell'utilizzo di PreferenceActivity.PreferenceActivity fornisce NullPointerException quando l'opzione è selezionata da ListPreference
Task: Consenti all'utente di scegliere il layout del programma da Preferenze
Problema: selezionando un'opzione nella PreferenceList provoca un NullPointerException nasce
Eccezione: A android.preference.ListPreference .onDialogClosed()
(abbreviato) Codice:
private static final String PREF_LAYOUT_KEY = "PrefLayout";
private static final int DEFAULT_LAYOUT = LayoutHelper.LAYOUT_DOUBLE ;
private static int mListLayout = DEFAULT_LAYOUT ;
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
SharedPreferences pref = PreferenceManager.getDefaultSharedPreferences(this);
pref.registerOnSharedPreferenceChangeListener(this);
mListLayout = pref.getInt(PREF_LAYOUT_KEY, DEFAULT_LAYOUT);
}
@Override
public void onSharedPreferenceChanged(SharedPreferences pref,
String key) {
Log.v(TAG, "OnSharedPreferencesChanged run"); // TODO Testing Purposes
if(key.equals(PREF_LAYOUT_KEY)){
mListLayout = pref.getInt(key, DEFAULT_LAYOUT);
}
}
[PreferenceActivity]
public class Preferences extends PreferenceActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.pref);
}
}
[res/xml/pref.xml]
<PreferenceCategory
android:title="@string/pref_cat1_title">
<ListPreference
android:title="@string/pref_layout_name"
android:summary="@+id/pref_chosen_layout"
android:key="PrefLayout"
android:entries="@array/prefLayoutOptions"
android:entryValues="@array/prefLayoutOptionsValues"
/>
</PreferenceCategory>
[strings.xml]
<string name="pref_cat1_title">Layout</string>
<string name="pref_layout_name">"Layout of list"</string>
<array name="prefLayoutOptions">
<item>Layout 1 (single)</item>
<item>Layout 2 (double)</item>
<item>Layout 3 (triple)</item>
<item>Layout 4 (quad)</item>
</array>
<array name="prefLayoutOptionsValues">
<item>50</item>
<item>51</item>
<item>52</item>
<item>53</item>
</array>
Il bit di codice che registra OnSharedPreferencesChanged in esecuzione mai arriva.
Qualcuno può vedere dove ho sbagliato?
MODIFICA. Ecco la parte superiore della traccia dello stack:
E/AndroidRuntime(2707): java.lang.NullPointerException
E/AndroidRuntime(2707): at android.preference.ListPreference.onDialogClosed(ListPreference.java:218)
E/AndroidRuntime(2707): at android.preference.DialogPreference.onDismiss(DialogPreference.java:384)
E/AndroidRuntime(2707): at android.app.Dialog$ListenersHandler.handleMessage(Dialog.java:1047)
E/AndroidRuntime(2707): at android.os.Handler.dispatchMessage(Handler.java:99)
Lei dice che l'eccezione è in .onDialogClosed(), ma non riesco a vedere questo metodo nel codice ... – Sephy
Puoi pubblicare un Uscita LogCat? –
Appena aggiunta la traccia dello stack. @Sephy: L'onDialogClosed proviene da ListPreference, non dal mio codice – HXCaine