文件夾
前言
轉來轉去又回到了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();
}
}
}