Android PreferenceActivity与PreferenceFragment详解及简单实例
android preferenceactivity与preferencefragment
前言
转来转去又回到了android,闲话少说,这里是参考android原生的settings应用来介绍一下preferenceactivity、preferencefragment和headers的使用。
preferenceactivity
我们先通过一个简单的例子来学习一下preferenceactivity的使用。
preferences_scenario_1.xml
我们先通过xml文件来定义一个简单的preference界面,res/xml/preference_scenario_1.xml:
<?xml version="1.0" encoding="utf-8"?> <preferencescreen xmlns:android="http://schemas.android.com/apk/res/android" > <preferencescreen android:summary="@string/next_screen_title" android:title="@string/next_screen_summary" > <checkboxpreference android:key="@+id/next_screen_checkbox_preference" android:summary="@string/checkbox_summary" android:title="@string/checkbox_title" /> </preferencescreen> <preferencecategory android:title="@string/category_title" android:summary="@string/category_title"> <checkboxpreference android:defaultvalue="false" android:key="pref_otificationskey" android:title="@string/checkbox_title" > </checkboxpreference> <listpreference android:entries="@array/people_name" android:entryvalues="@array/people_value" android:key="pref_syncfrequencykey" android:summary="@string/list_summary" android:title="@string/list_title" > </listpreference> </preferencecategory> </preferencescreen>
涉及到的string.xml内容如下:
<?xml version="1.0" encoding="utf-8"?> <resources> <string name="next_screen_title">下一屏选项</string> <string name="next_screen_summary">下一屏</string> <string name="checkbox_summary">我很帅</string> <string name="checkbox_title">我刷吗?</string> <string name="category_title">我喜欢</string> <string name="list_title">人名列表</string> <string name="list_summary">我喜欢的人名</string> </resources>
preference activity
在android3.0之前,preferenceactivity是用来呈现preference screens的,所以如果要支持android3.0之前的系统,还是要继承preferenceactivity类来呈现preference screens。示例代码如下:
import android.os.bundle; import android.preference.preferenceactivity; public class custompreferenceactivity extends preferenceactivity{ @override protected void oncreate(bundle savedinstancestate) { // todo auto-generated method stub super.oncreate(savedinstancestate); addpreferencesfromresource(r.xml.preference_scenario_1); } }
重写oncreate方法,并且调用addpreferencesfromresource方法来加载xml布局文件。
别忘了,需要在androidmanifest.xml中声明这个custompreferenceactivity。
注意:
preferenceactivity的addpreferencesfromresource方法已经在android3.0(api level 11)之后废弃了。android3.0之后,推荐使用preferencefragment来呈现preference screen。
演示
在其他activity里,可以通过startactivity来启动这个preferenceactivity,演示图如下:
preferencefragment
xml布局文件
xml文件我们可以复用上面preferenceactivity的布局文件。
preference fragment
示例代码如下:
import android.os.bundle; import android.preference.preferencefragment; public class custompreferencefragment extends preferencefragment{ @override public void oncreate(bundle savedinstancestate) { super.oncreate(savedinstancestate); addpreferencesfromresource(r.xml.preference_scenario_1); } }
preference activity管理fragment
示例代码如下:
import android.os.bundle; import android.preference.preferenceactivity; public class custompreferenceactivity extends preferenceactivity{ @override protected void oncreate(bundle savedinstancestate) { // todo auto-generated method stub super.oncreate(savedinstancestate); getfragmentmanager().begintransaction().replace(android.r.id.content, new custompreferencefragment()).commit(); } }
适配
为了同时适配android3.0之前之后的系统,我们可以通过build.version.sdk_int在代码里自动判断来决定如何呈现preference screen。示例代码如下:
import android.os.build; import android.os.bundle; import android.preference.preferenceactivity; public class custompreferenceactivity extends preferenceactivity{ @override protected void oncreate(bundle savedinstancestate) { // todo auto-generated method stub super.oncreate(savedinstancestate); if (build.version.sdk_int < build.version_codes.honeycomb) { addpreferencesfromresource(r.xml.preference_scenario_1); } else { getfragmentmanager().begintransaction().replace(android.r.id.content, new custompreferencefragment()).commit(); } } }
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!