在Android系统源码中,绝大多数应用程序的UI布局采用了Preference的布局结构,而不是我们平时在模拟器中构建应用程序时使用的View布局结构,例如,Setting模块中布局。当然,凡事都有例外,FMRadio应用程序中则使用了View布局结构(可能是该应用程序是marvel公司提供的,如果由google公司做,那可说不准)。归根到底,Preference布局结构和View的布局结构本质上还是大同小异,Preference的优点在于布局界面的可控性和高效率以及可存储值的简洁性(每个PreferenPreferencece存储在相对应下的SharedPreference文件夹下)。
下面,我们对比Preference和View下得各个子控件,对他们的家庭元素在宏观上有个更好的把握性。
单一控件:
Preference 控件家庭 View控件家庭 控件含义
Preference TextView 文本框
CheckPreference CheckBox 单选框
EditTextPreference EditText 输入文本框
ListPreference ListView 列表框
RingtonePreference —— 铃声
其实在Android源码系统中还有很多的”未完工”的Preference, 没有为它们提供PI接口,例如SeekBarPreference,
有兴趣的同学可以参考源码,具体路径为:frameworks/base/core/java/preference。
组合控件:
PreferenceCategory :类似于LinearLayou、RelativeLayout,用于组合一组Preference,使布局更具备层次感 。
PreferenceScreen : 所有Preference元素的根节点。
显示Preference布局结构的方法为:
使我们的Activity继承PreferenceActivity,然后在onCreate()方法中通过
addPreferencesFromResource(R.xml.custom_preference) (我们自定义的Preference 布局)。
怎么样,是不是似曾相识?稍后会用一个Demo来为您详述。
Preference元素的通用XML Attributes说明:
android:key:
每个Preference控件独一无二的”ID”,唯一表示此Preference。
android:defaultValue:
默认值。 例如,CheckPreference的默认值可为”true”,默认为选中状态;
EditTextPreference的默认值可为”110” 。
android:enabled:
表示该Preference是否可用状态。
android:title:
每个Preference在PreferenceScreen布局上显示的标题——大标题
android:summary:
每个Preference在PreferenceScreen布局上显示的标题——小标题(可以没有)
android:persistent:
表示Preference元素所对应的值是否写入sharedPreferen文件中,如果是true,则表示写
入;否则,则表示不写入该Preference元素的值。
android:dependency:
表示一个Preference(用A表示)的可用状态依赖另外一个Preference(用B表示)。B可用,
则A可用;B不可用,则A不可用。
android:disableDependentsState: 与android:dependency相反。B可用,则A不可用;B不可用,则A可用。
常用的方法则包括:
getKey() setKey()
getSummary() setSummary()
getText()setText()
getXXX()代表取得xxx属性的值。
一个简易的效果图如下:
Preference的跳转:
方法一:在配置每个Preference元素节点时,我们可以显示为点击它时所跳转的Intent。点击该Preference,跳转至目标Intent。除非在onPreferenceTreeClick()方法中进行抉择。在xml中配置如下:
-
<Preferenceandroid:key="wifi_setting"android:title="Wi-Fi设置"
-
android:summary="设置和管理无线接入点"android:dependency="apply_wifi">
-
<!--点击时自定义一个默认跳转Intentaction指定隐式Intent-->
-
<!--action指定隐式Intent;targetPackage和targetClass指定显示Intent-->
-
<intentandroid:action="com.feixun.action.seemAction"
-
android:targetPackage="com.feixun.qin"android:targetClass="com.feixun.qin.MainActivity"/>
-
</Preference>
方法二:可以在onPreferenceTreeClick()创建新的intent显示的进行跳转。
接下来,对每个Preference的的独有XML Attributes和方法进行一下总结,使大家有更好的深入理解。
1、EditPreference
方法:
getEditText() 返回的是我们在该控件中输入的文本框值
getText() 返回的是我们之前sharedPreferen文件保存的值
效果图:
2、ListPreference
XML Attributes:
android:dialogTitle:弹出控件对话框时显示的标题
android:entries:类型为array,控件欲显示的文本
android:entryValues:类型为array,与文本相对应的key-value键值对,value保存至sharedPreference文件
说明:entries和entryValue属性使用的数组为定义在资源文件arrays.xml的数组名:
方法:
CharSequence[]getEntries():
返回的是控件显示文本的一个”key”数组,对应于属性android:entries
CharSequence[]getEntryValues():返回的一个”value”数组,对应于属性android:
entryValues
CharSequencegetEntry():
返回当前选择文本
String
getValue() :返回当前选中文本选中的value 。
与之对应的还有它们所对应的setXXX()方法,可以参考SDK进行分析。效果图:
采用的数组为:
-
<?xmlversion="1.0"encoding="utf-8"?>
-
<resources>
-
<string-arrayname="department">
-
<item>IT</item>
-
<item>Commerce</item>
-
<item>HR</item>
-
</string-array>
-
<string-arrayname="department_value">
-
<item>001</item>
-
<item>002</item>
-
<item>003</item>
-
</string-array>
-
</resources>
3、RingtonePreference
XML Attributes:
android:ringtoneType:响铃的铃声类型,主要有:ringtone(音乐)、notification(通知)、alarm(闹铃)
、all(所有可用声 音类型)。
android:showDefault:默认铃声,可以使用系统(布尔值---true,false)的或者自定义的铃声
android:showSilent
:指定铃声是否为静音。指定铃声包括系统默认铃声或者自定义的铃声
效果图:
重点:分析Preference事件
★在PreferenceActivity方法中,一个比较重要的监听点击事件方法为:
public booleanonPreferenceTreeClick (PreferenceScreen preferenceScreen, Preference preference)
说 明 :当Preference控件被点击时,触发该方法。
参数说明: preference 点击的对象。
返回值: true 代表点击事件已成功捕捉,无须执行默认动作或者返回上层调用链。 例如,不跳转至默认Intent。
false 代表执行默认动作并且返回上层调用链。例如,跳转至默认Intent。
在我们继承PreferenceActivity的Activity可以重写该方法,来完成我们对Preference事件的捕捉。
相信通过前面的介绍,你一定知道了如何使用了Preference家族并且对其触发方法。下面我们抛出另外两枚——
Preference相关的两个重要监听接口。
★Preference.OnPreferenceChangeListener 该监听器的一个重要方法如下:
boolean onPreferenceChange(Preferencepreference,ObjectobjValue)
说明: 当Preference的元素值发送改变时,触发该事件。
返回值:true 代表将新值写入sharedPreference文件中。
false 则不将新值写入sharedPreference文件
★Preference.OnPreferenceClickListener 该监听器的一个重要方法如下:
public booleanonPreferenceClick(Preference preference)
说明:当点击控件时触发发生,可以做相应操作。
那么当一个Preference控件实现这两个接口时,当被点击或者值发生改变时,触发方法是如何执行的呢?事实上,
它的触发规则如下:
1先调用onPreferenceClick()方法,如果该方法返回true,则不再调用onPreferenceTreeClick方法 ;
如果onPreferenceClick方法返回false,则继续调用onPreferenceTreeClick方法。
2onPreferenceChange的方法独立与其他两种方法的运行。也就是说,它总是会运行。
那么,开始我们的实战之旅吧! 下面给您最火热的战场。
1,新建我们的preference.xml文件。
① 在res文件夹下,新建xml文件夹。
② 在新建的xml文件夹下,新建Android XML File。命名为mypeference.xml 。类型选择为Preference。
③打开我们的mypeference.xml,视图选择Structure。可以手动配置我们的布局文件。可选的Preference空间如下:
Demo中mypeference.xml的布局文件如下:
-
<?xmlversion="1.0"encoding="utf-8"?>
-
<PreferenceScreenxmlns:android="http://schemas.android.com/apk/res/android">
-
-
<PreferenceCategoryandroid:title="我的位置"
-
android:key="set_local"/>
-
<CheckBoxPreferenceandroid:key="apply_wireless"
-
android:title="使用无线网络"android:summary="使用无线网络在应用程序(例如Google地图)中查看位置"
-
android:defaultValue="true">
-
</CheckBoxPreference>
-
<CheckBoxPreferenceandroid:key="apply_gps"
-
android:title="使用GPS"android:summary="定位到街道级别(需要消耗更多的电量以及天气允许)">
-
</CheckBoxPreference>
-
-
<PreferenceCategoryandroid:title="无线和网络设置"></PreferenceCategory>
-
-
<CheckBoxPreferenceandroid:key="apply_fly"
-
android:title="飞行模式"android:summary="禁用所有无线连接">
-
</CheckBoxPreference>
-
-
<CheckBoxPreferenceandroid:key="apply_internet"
-
android:title="Internet共享"android:summary="禁用通过USB共享Internet连接">
-
</CheckBoxPreference>
-
-
<CheckBoxPreferenceandroid:key="apply_wifi"
-
android:title="Wi-Fi"android:summary="打开Wi-Fi">
-
</CheckBoxPreference>
-
<Preferenceandroid:key="wifi_setting"android:title="Wi-Fi设置"
-
android:summary="设置和管理无线接入点"android:dependency="apply_wifi">
-
<!--点击时自定义一个默认跳转Intentaction指定隐式Intent-->
-
<!--action指定隐式Intent;targetPackage和targetClass指定显示Intent-->
-
<intentandroid:action="com.feixun.action.seemAction"
-
android:targetPackage="com.feixun.qin"android:targetClass="com.feixun.qin.MainActivity"/>
-
</Preference>
-
<CheckBoxPreferenceandroid:key="apply_bluetooth"
-
android:title="蓝牙"android:summary="启用蓝牙">
-
</CheckBoxPreference>
-
<Preferenceandroid:key="bluetooth_setting"android:title="蓝牙设置"
-
android:summary="管理连接、设备设备名称和可检测性"android:dependency="apply_bluetooth">
-
</Preference>
-
<EditTextPreferenceandroid:key="number_edit"
-
android:title="输入电话号码"android:defaultValue="123">
-
</EditTextPreference>
-
<ListPreferenceandroid:key="depart_value"
-
android:title="部门设置"android:dialogTitle="选择部门"android:entries="@array/department"
-
android:entryValues="@array/department_value">
-
</ListPreference>
-
<RingtonePreferenceandroid:key="ring_key"
-
android:title="铃声"android:ringtoneType="all"android:showDefault="true"
-
android:showSilent="true">
-
</RingtonePreference>
-
</PreferenceScreen>
2,新建一个HelloActivity继承PreferenceActivity,代码如下:
-
packagecom.feixun.qin;
-
-
importandroid.content.Intent;
-
importandroid.content.SharedPreferences;
-
importandroid.os.Bundle;
-
importandroid.preference.CheckBoxPreference;
-
importandroid.preference.EditTextPreference;
-
importandroid.preference.ListPreference;
-
importandroid.preference.Preference;
-
importandroid.preference.PreferenceActivity;
-
importandroid.preference.PreferenceManager;
-
importandroid.preference.PreferenceScreen;
-
importandroid.preference.Preference.OnPreferenceClickListener;
-
importandroid.util.Log;
-
-
publicclassHelloPreferenceextendsPreferenceActivityimplements
-
Preference.OnPreferenceClickListener,
-
Preference.OnPreferenceChangeListener{
-
privatestaticStringTAG="HelloPreference";
-
privateCheckBoxPreferencemapply_wifiPreference;
-
privateCheckBoxPreferencemapply_internetPreference;
-
privateListPreferencedepart_valuePreference;
-
privateEditTextPreferencenumber_editPreference;
-
privatePreferencemwifi_settingPreference;
-
privateStringoldDeptId;
-
-
publicvoidonCreate(BundlesavedInstanceState){
-
super.onCreate(savedInstanceState);
-
addPreferencesFromResource(R.xml.mypreference);
-
-
mapply_wifiPreference=(CheckBoxPreference)findPreference("apply_wifi");
-
mapply_internetPreference=(CheckBoxPreference)findPreference("apply_internet");
-
depart_valuePreference=(ListPreference)findPreference("depart_value");
-
number_editPreference=(EditTextPreference)findPreference("number_edit");
-
mwifi_settingPreference=(Preference)findPreference("wifi_setting");
-
-
-
mapply_internetPreference.setOnPreferenceClickListener(this);
-
mapply_internetPreference.setOnPreferenceChangeListener(this);
-
depart_valuePreference.setOnPreferenceClickListener(this);
-
depart_valuePreference.setOnPreferenceChangeListener(this);
-
number_editPreference.setOnPreferenceClickListener(this);
-
number_editPreference.setOnPreferenceChangeListener(this);
-
mwifi_settingPreference.setOnPreferenceClickListener(this);
-
-
-
SharedPreferencesshp=PreferenceManager.getDefaultSharedPreferences(this);
-
booleanapply_wifiChecked=shp.getBoolean("apply_wifi",false);
-
}
-
-
-
privatevoidoperatePreference(Preferencepreference){
-
if(preference==mapply_wifiPreference){
-
Log.i(TAG,"WifiCB,andisCheckd="+mapply_wifiPreference.isChecked());
-
}elseif(preference.getKey().equals("apply_internet")){
-
Log.i(TAG,"internetCB,andisCheckd="+mapply_internetPreference.isChecked());
-
}elseif(preference==depart_valuePreference){
-
Log.i(TAG,"departmentCB,andselectValue="+depart_valuePreference.getValue()+",Text="+depart_valuePreference.getEntry());
-
}elseif(preference.getKey().equals("wifi_setting")){
-
mwifi_settingPreference.setTitle("itsturnme.");
-
}elseif(preference==number_editPreference)
-
Log.i(TAG,"OldValue="+number_editPreference.getText()+",NewValue="+number_editPreference.getEditText().toString());
-
}
-
-
@Override
-
publicbooleanonPreferenceClick(Preferencepreference){
-
-
Log.i(TAG,"onPreferenceClick----->"+String.valueOf(preference.getKey()));
-
-
operatePreference(preference);
-
returnfalse;
-
}
-
-
publicbooleanonPreferenceTreeClick(PreferenceScreenpreferenceScreen,
-
Preferencepreference){
-
Log.i(TAG,"onPreferenceTreeClick----->"+preference.getKey());
-
-
operatePreference(preference);
-
if(preference.getKey().equals("wifi_setting")){
-
-
-
-
Intenti=newIntent(HelloPreference.this,OtherActivity.class);
-
i.putExtra("type","wifi");
-
startActivity(i);
-
returntrue;
-
}
-
returnfalse;
-
}
-
-
-
publicbooleanonPreferenceChange(Preferencepreference,ObjectobjValue){
-
Log.i(TAG,"onPreferenceChange----->"+String.valueOf(preference.getKey()));
-
if(preference==mapply_wifiPreference){
-
Log.i(TAG,"WifiCB,andisCheckd="+String.valueOf(objValue));
-
}elseif(preference.getKey().equals("apply_internet")){
-
Log.i(TAG,"internetCB,andisCheckd="+String.valueOf(objValue));
-
returnfalse;
-
}elseif(preference==depart_valuePreference){
-
Log.i(TAG,"OldValue"+depart_valuePreference.getValue()+"NewDeptName"+objValue);
-
}elseif(preference.getKey().equals("wifi_setting")){
-
Log.i(TAG,"change"+String.valueOf(objValue));
-
mwifi_settingPreference.setTitle("itsturnme.");
-
}elseif(preference==number_editPreference){
-
Log.i(TAG,"OldValue="+String.valueOf(objValue));
-
returnfalse;
-
}
-
returntrue;
-
}
-
}
3,AndroidManifest 文件如下:
-
<?xmlversion='1.0'encoding='utf-8'standalone='yes'?>
-
-
<map>
-
-
<booleanname="apply_wifi"value="true"/>
-
-
<booleanname="apply_internet"value="true"/>
-
-
<stringname="number_edit">45677</string>
-
<stringname="ring_key">content:
-
-
<booleanname="apply_bluetooth"value="true"/>
-
-
<booleanname="apply_fly"value="true"/>
-
-
<stringname="depart_value">001</string>
-
-
<booleanname="apply_gps"value="true"/>
-
-
<booleanname="apply_wireless"value="false"/>
-
-
</map>
程序运行后,效果如上所示,是不是很给力呀!
sharedPreference文件
前面我们说过,Android系统会将Preference元素的值存储在sharedPreference文件中。该文件存放路径位于
DDMS视图下的data/data/[packgename]/shared_prefs/文件下,命名约定为:packagename_preferencse.xml。
我们的com.feixun.qin_preferences.xm保存的值为:
-
<?xmlversion='1.0'encoding='utf-8'standalone='yes'?>
-
-
<map>
-
-
<booleanname="apply_wifi"value="true"/>
-
-
<booleanname="apply_internet"value="true"/>
-
-
<stringname="number_edit">45677</string>
-
<stringname="ring_key">content:
-
-
<booleanname="apply_bluetooth"value="true"/>
-
-
<booleanname="apply_fly"value="true"/>
-
-
<stringname="depart_value">001</string>
-
-
<booleanname="apply_gps"value="true"/>
-
-
<booleanname="apply_wireless"value="false"/>
-
-
</map>
已一个键值对的形式保存,name为Preference的key值,value为Preference的value值。
在应用程序中,我们可以通过代码的方式来访问该sharedPreference文件,继而可以对其进行读取甚至任何操作。
代码如下:
-
-
SharedPreferencesshp=PreferenceManager.getDefaultSharedPreferences(this);
-
booleanapply_wifiChecked=shp.getBoolean("apply_wifi",false);
代码下载地址:http://download.csdn.net/detail/qinjuning/3807077
转自:http://blog.csdn.net/qinjuning
分享到:
相关推荐
Android中preference的使用,使用详解.
android Preference自定义样式
上篇博文代码实现了Android自带的preference组件,本文将通过实例讲解自定义preference组件。 主要通过以下几步来实现: 1.定义需要的layout布局res->layout->xml文件; 2.通过继承Preference类,来实现自定义...
Android提供preference这个键值对的方式来处理这种情况,自动保存这些数据,并立时生效,同时Android提供一种类似的layout的方式来进行Preference的布局。 Preference组件有ListPreference,EditTextPreference,...
Preference,比如系统设置、短信都可以使用,简单而又好使用,而且Google原生Android代码中大量的使用了Preference组件。简单说, Preference组件其实就是Android常见UI组件与SharePreferences的组合封装实现。
android各种Preference的使用
这是Pro Android学习系列中preference部分的例子源代码。
Android程序 Preference应用 注册案例
安卓Android源码——Preference_Demo.rar
android-support-v7-preference.jar
此DEMO内含基本的android preference framework的简单介绍,包括CheckboxPreference, RingtonePreference, EditTextPreference以及...主要探究了一下android 怎么通过使用preference从而达到对用户定制的数据进行保存。
Android Preference Framework源码~~~~~~~~~~~~~~~~~
Material Preference Library uses com.android.support:preference-v7:x.x.x support library widgets. Also it includes a color chooser dialog widget, that can be used to select accent color . Header is ...
声明简单,但是如何从PreferenceScreen或者PreferenceCategory中删除一个Preference会简单么.为什么有些人写的就无法删除成功呢?本文将从Android源码实现来分析一下. 声明文件 代码如下: <?xml version=”1.0″ ...
Based on support-preference from Android Support Library, adding a lot of exciting features. Sample How to use add dependencies // replace with version above implementation 'moe.shizuku.preference...
android程序的一个demo,演示Preference保存设置的功能
android中PreferenceActivity详解
NULL 博文链接:https://sunney2012.iteye.com/blog/1158214
Android应用源码之Preference_Demo.zip项目安卓应用源码下载Android应用源码之Preference_Demo.zip项目安卓应用源码下载 1.适合学生毕业设计研究参考 2.适合个人学习研究参考 3.适合公司开发项目技术参考