PreferenceFragment簡介
在我們寫一個項目的時候,基本都有選項設置界面,這類設置界面的原理基本都是本地的一些個性化設置,通過讀取本地設置來改變某些差異顯示(例如字體大小,主題顏色,WIFI自動下載等)。這些設置一般都會使用Preference來保存,Android專門爲這種Activity提供了便捷的基類PreferenceActivity(如果是Fragment,使用PreferenceFragment,現在推薦使用v7包下的PreferenceFragmentCompat),這些類內部封裝了Preference,會幫我們自動讀寫設置,方便開發者便捷完成這類功能。
PreferenceFragment使用
PreferenceFragment
位於android.preference
包下,現在推薦使用v7包下的,這裏還是使用這個來說明,原理是一樣的。
先來使用下:
- 在res目錄下創建xml目錄
- 在xml目錄下創建xml文件(文件名自己定義即可)
這裏演示的文件是pref_setting.xml
<?xml version="1.0" encoding="utf-8"?>
<PreferenceScreen xmlns:android="http://schemas.android.com/apk/res/android">
<CheckBoxPreference
android:defaultValue="false"
android:key="setting_no_img"
android:summary="僅在WIFI環境下顯示圖片"
android:title="無圖模式" />
<PreferenceCategory android:title="設置">
<EditTextPreference
android:hint="設置用戶名"
android:key="setting_name"
android:title="設置用戶名" />
<Preference
android:key="setting_font_size"
android:summary="設置字體大小"
android:title="設置字體大小" />
</PreferenceCategory>
<SwitchPreference
android:defaultValue="false"
android:key="setting_switch"
android:title="設置模式-Switch" />
<RingtonePreference
android:key="setting_ring"
android:title="設置模式-Ringtone" />
</PreferenceScreen>
- 繼承PreferenceFragment,在onCreate方法中調用
addPreferencesFromResource
方法加載xml目錄下的資源即可
public class PreferenceTestFragment extends PreferenceFragment {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.pref_setting);//加載xml文件
}
}
運行效果:
pref_setting.xml
中使用的控件可以查看android.preference
包下,這裏面有幾個常用的屬性:
屬性名 | 用途 |
---|---|
android:key | 存儲key,這個就是SharedPreferences存儲時的key |
android:title | 標題 |
android:defaultValue | 默認值 |
設置點擊事件
findPreference("setting_no_img").setOnPreferenceClickListener(new Preference.OnPreferenceClickListener() {
@Override
public boolean onPreferenceClick(Preference preference) {
//todo
return true;
}
});
findPreference
中的key就是xml中聲明的key。
可以使用registerOnSharedPreferenceChangeListener
來監聽SharedPreferences值改變。
getPreferenceScreen().getSharedPreferences().registerOnSharedPreferenceChangeListener(this);
PreferenceFragment 擴展
可以通過繼承Preference
來實現自定義控件
public class ThemePreference extends Preference {
private CircleView circleImageView;
public ThemePreference(Context context, AttributeSet attrs) {
super(context, attrs);
// 加載佈局文件
setWidgetLayoutResource(R.layout.item_theme_preference_preview);
}
// 綁定視圖
@Override
protected void onBindView(View view) {
super.onBindView(view);
int color = CommonSettingUtil.getInstance().getThemeColor();
circleImageView = (CircleView) view.findViewById(R.id.iv_preview);
circleImageView.setBackgroundColor(color);
}
/**
* 刷新顏色顯示
*/
public void updateColor() {
circleImageView.setBackgroundColor(CommonSettingUtil.getInstance().getThemeColor());
}
}