初心者がPreferenceFragmentのサブクラスFragmentを使用する場合
PreferenceFragmentは、設定画面を表示する専用Fragmentサブクラスです。設定項目のリストを表示し、デフォルトのレイアウトとインタラクション動作を提供します。
PreferenceFragmentを使用する手順は以下の通りです。
- PreferenceFragmentを継承するサブクラスを作成します。
public class MyPreferenceFragment extends PreferenceFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
// 加载设置项布局文件
addPreferencesFromResource(R.xml.preferences);
}
}
- 設定項目の構造とスタイルを定義するレイアウトルートXML/preferences.xmlを作成します。
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<PreferenceCategory android:title="General">
<CheckBoxPreference
android:key="pref_key_vibrate"
android:title="Vibrate"
android:summary="Enable vibration"
android:defaultValue="true"/>
<ListPreference
android:key="pref_key_ringtone"
android:title="Ringtone"
android:summary="Choose a ringtone"
android:entries="@array/ringtone_entries"
android:entryValues="@array/ringtone_values"
android:defaultValue="1"/>
</PreferenceCategory>
</PreferenceScreen>
- Activity 内で PreferenceFragment を用いて設定画面を表示する。
public class MainActivity extends AppCompatActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
// 创建PreferenceFragment实例
MyPreferenceFragment fragment = new MyPreferenceFragment();
// 替换Activity中的内容视图为PreferenceFragment
getFragmentManager().beginTransaction().replace(android.R.id.content, fragment).commit();
}
}
それらの手順を完遂後、アプリケーションを実行すると設定項目のリストが現れます。ユーザーは設定項目をクリックして設定でき、設定した値は自動的に保存・ロードされます。