android 切换 preferencefragment,Android PreferenceActivity与PreferenceFragment详解及简单实例_Android_脚本之家...

Android  PreferenceActivity与PreferenceFragment

前言

转来转去又回到了Android,闲话少说,这里是参考Android原生的Settings应用来介绍一下PreferenceActivity、PreferenceFragment和headers的使用。

PreferenceActivity

我们先通过一个简单的例子来学习一下PreferenceActivity的使用。

preferences_scenario_1.xml

我们先通过xml文件来定义一个简单的preference界面,res/xml/preference_scenario_1.xml:

android:summary="@string/next_screen_title"

android:title="@string/next_screen_summary" >

android:key="@+id/next_screen_checkbox_preference"

android:summary="@string/checkbox_summary"

android:title="@string/checkbox_title" />

android:summary="@string/category_title">

android:defaultValue="false"

android:key="pref_otificationskey"

android:title="@string/checkbox_title" >

android:entries="@array/people_name"

android:entryValues="@array/people_value"

android:key="pref_SyncFrequencykey"

android:summary="@string/list_summary"

android:title="@string/list_title" >

涉及到的string.xml内容如下:

下一屏选项

下一屏

我很帅

我刷吗?

我喜欢

人名列表

我喜欢的人名

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,演示图如下:

5a1d02054f77e4a6d04c75386fa1872b.png

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();

}

}

}

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值