Android中PreferenceFragment的使用詳解
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()); } }
到此這篇關於Android中PreferenceFragment的使用詳解的文章就介紹到這瞭,更多相關Android PreferenceFragment 內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- Android開發之自定義UI組件詳解
- Android 之Preference控件基本使用示例詳解
- Android顏色處理SweepGradient掃描及梯度渲染示例
- Android實現設置APP灰白模式效果
- Android應用實現點擊按鈕震動