SharedPreference是Android系统中轻量级存储数据的一种方式,操作简便快捷,它的本质是基于XML文件存储Key-Value键值对数据,适合存放程序状态的配置信息。
本文介绍了SharedPreference的概念与简单使用,同时介绍了可以作为设置界面的PreferenceActivity的使用。
详细代码:github.com/Baolvlv/LearnAndroid/tree/master/SharedPreference
1.SharedPreference简介
SharedPreference,轻型储存,基于xml文件储key-value储存键值对,储存位置在data/data/<包名>/shared_prefs目录下,本身只能获取数据而不支持储存与修改,通过传回的editor修改
sharedPreference对象与SQLite数据库相比,免去了创建数据库,创建表,写sql语句等操作,但不支持条件查询,作为SQLite数据库的一种补充
可以储存的数据类型有:boolean,int,float,long,String
2.SharedPreference的读写操作
首先声明sharedPreference与它的editor对象,必须在onCreate函数中实例化
//声明的sharedPreference
SharedPreferencespreferences;
//声明sharedPreference的editor
SharedPreferences.Editoreditor;
在onCreate的函数中通过getPreference()和eidt方法实例化
//获取当前Activity的sharedPreference,onCreate函数之前不能调用getPreference
preferences= getPreferences(Activity.MODE_PRIVATE);
//创建preference的editor对象
editor=preferences.edit();
通过editor的putString方法设置键值对的值并commit到sharedPreference
editor.putString(KEY,et.getText().toString());
if(editor.commit()){
Toast.makeText(getApplicationContext(),"写入成功",Toast.LENGTH_SHORT)
.show();
}
通过sharedPreference的getString方法获取值,如果没有值,通过第二个参数设置初值
//第二个参数为当前键不存在时,其默认的值
String in =preferences.getString(KEY,"当前值不存在");
Toast.makeText(getApplicationContext(),in,Toast.LENGTH_SHORT)
.show();
3.PreferenceActivity的使用
手机的设置界面,即通过PreferenceActivity实现。分组为PreferenceCategory,Wi-Fi右侧的开关为CheckBoxPreference,每次设置都会被preference保存下来,setting数据的持久化.
PreferenceActivity不使用layout文件作为布局,使用专有的preference.xml文件
Res目录下新建xml文件夹,在xml文件夹中,新建preference.xml文件
以PreferenceScreen为根布局,PreferenceCategory为分组
http://schemas.android.com/apk/res/android">
android:title="list title"
android:summary="list_summery"
android:defaultValue="@string/app_name"
android:entries="@array/list_preference"
android:entryValues="@array/list_preference"
android:dialogTitle="list_dialog_title"/>
android:title="edit title"
android:defaultValue="@string/app_name"
android:summary="edit_summery"/>
android:title="checkbox title"
android:defaultValue="false"
android:summary="checkbox summery"/>
其中,每种Preference的title为标题,summary为简介,defaultValue为没有设置summary时的默认值
key为每种preference的唯一标记值,相当于layout中的id,在xml与java文件中必须一致
ListPreference中entries与entryValue配合,为弹出对话框的列表,需要设置为数组
在res/values下新建array.xml,作为对话框列表数组在作为设置界面的activity中实现ui
使当前Activity继承自PreferenceActivity。
由于PreferenceActivity继承自ListActivity,所以在onCreate()函数中,不能执行setContentView方法
在android3.0之前,在onCreate函数中执行addPreferenceFromResource加载xml文件,
并通过findPreference通过键值查找并实例化组件
addPreferencesFromResource(R.xml.preference);
initPreference();
private voidinitPreference(){
lp= (ListPreference) findPreference(Keys.LIST_KEY);
etp= (EditTextPreference) findPreference(Keys.EDIT_KEY);
cp= (CheckBoxPreference) findPreference(Keys.CHECK_KEY);
}
在android3.0之后,创建PreferenceFragment,将preferenceFragment加载到activity中
实现OnSharedPreferenceChangeListener接口,复写onSharedPreferenceChanged方法,执行任何key对应的值改变的操作,通过sharedPreferences获取key所对应的值
implementsSharedPreferences.OnSharedPreferenceChangeListener {
//任何key的值改变时,更新Summery的值
@Override
public voidonSharedPreferenceChanged(SharedPreferences sharedPreferences,String key) {
if(key.equals(Keys.EDIT_KEY)){
etp.setSummary(sharedPreferences.getString(key,"text"));
}else if(key.equals(Keys.LIST_KEY)){
lp.setSummary(sharedPreferences.getString(key,""));
}
当重回Activity,activity恢复时,重设summery为上一次的值,并重新绑定Listener对象
//Activity恢复时执行,用于刷新的操作
@Override
protected voidonResume() {
super.onResume();
//设置summary的值
SharedPreferences sp = getPreferenceScreen().getSharedPreferences();
lp.setSummary(sp.getString(Keys.LIST_KEY,""));
etp.setSummary(sp.getString(Keys.EDIT_KEY,"text"));
//只要activity恢复时,重注册sharedPreferenceChangeListener
sp.registerOnSharedPreferenceChangeListener(this);
}
当Activity停止时,解除listener绑定
@Override
protected voidonPause() {
super.onPause();
//Activity停止时,解除Listener
getPreferenceScreen().getSharedPreferences()
.unregisterOnSharedPreferenceChangeListener(this);
}
xml设置布局,addPreferenceFromResource添加,通过sharedPrefernences获取值
如果使用PreferenceFragment,则新建类继承自PreferenceFragment,
重写onCreate函数,在onCreate函数中addPreferenceFromResource
public classMyPreferenceFragmentextendsPreferenceFragment {
@Override
public voidonCreate(@NullableBundle savedInstanceState) {
super.onCreate(savedInstanceState);
addPreferencesFromResource(R.xml.preference);
任何一个普通的Activity都可以加载PreferenceFragment
getFragmentManager().beginTransaction().replace(android.R.id.content,newMyPreferenceFragment())
.commit();
注意第一个参数为android.R.id.content(根布局)
如果使用普通的Activity,不能实例化子Preference,即不能改变summery