首先,我們明確,preference是和資料存放區相關的。
其次,它能協助我們方便的進行資料存放區!為什麼這個地方一定要強調下方便的這個詞呢?原因是,我們可以根本就不使用,我們有另外的N種辦法可以實現同樣的功能!它的出現,相當於為我們提供了一個方便的工具,當然了,這個工具並不是必須的。
preference都應用在什麼情境呢?
這得從android對preference的實現說起,實際上,preference所儲存的資料最後都會以xml檔案格式的形式進行儲存,而且其只能 儲存一些基本格式的資料。例如string/boolean……。該xml檔案存放的位置在data/data/你應用的包名/shared_prefs 檔案夾下。
種種的限制與實現機製表明了,preference非常適合於參數設定功能。實際上,它也確實是幹這個的,我們通過使用preference可以迅速的將某些值儲存進xml檔案中,然後我們可以讀取這些設定資訊進行相應的操作。
為了簡化與preference相關的應用開發,android為我們提供了一系列的api來協助我們。主要有PreferenceActivity,ListPreference,EditTextPreference,CheckBoxPreference,RingtonePreference
下面我們簡單的介紹下ListPreference的用法:
我們選擇了山東,然後該頁面就會自動關閉,並且和山東所對應的值也已經寫入了背景xml檔案中。
java代碼:
package jason.demo;import android.os.Bundle;import android.preference.ListPreference;import android.preference.PreferenceActivity;import android.preference.PreferenceManager;import android.util.Log;/*** @description 有關喜好設定preferences的研究* 繼承了PreferenceActivity,我們可以方便的對preference進行操作。* 例如可以通過getPreferenceManager擷取喜好設定管理器* 那,我們可不可以不繼承PreferenceActivity呢?當然可以,實際上Activity類中* 就有個SharedPreferences getSharedPreferences(String name, int mode)方法呢,我們通過它* 也可以對preference進行操作。當然了,如果我們不繼承PreferenceActivity的話,那麼我們就要手動的* 對資料進行儲存了。而不是跟現在一樣,會自動的根據你的選擇項進行資料儲存。* 那麼,preference在這裡是怎麼樣進行自動儲存的呢,答案很簡單,那就是在addPreferencesFromResource方法的具體實現中!*/public class MyPreferencesActivity extends PreferenceActivity {@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);addPreferencesFromResource(R.xml.mylistpreference);/*** getPreferenceManager返回喜好設定管理器對象*/PreferenceManager manager = getPreferenceManager();// 根據android:key中指定的名稱(相當於id)來擷取喜好設定ListPreference listPreference = (ListPreference) manager.findPreference("myListPreference");Log.i("儲存的值為", ""+listPreference.getValue());}}
res/xml/mylistperference.xml布局檔案
<?xml version="1.0" encoding="utf-8"?><!--對於該檔案需要注意以下幾點第一:位置。該檔案的位置是在res/xml/下的。第二:格式,PreferenceScreen為根標籤,ListPreference為子標籤第三:標籤屬性含義android:key 唯一識別碼,和android:id相類似,PreferenceManager可以以其為參數通過findPreference擷取指定的preferenceandroid:title 整個螢幕的標題android:summary 選項的簡單說明android:entries 彈出的對話方塊中,列表顯示的常值內容,注意哦,這裡指定的是一個數組android:entryValues 與android:entries相對應的值android:defaultValue 當對應值不存在時的預設值android:dialogTitle 彈出的對話方塊中的標題資訊--><PreferenceScreenxmlns:android="http://schemas.android.com/apk/res/android"android:key="screen_list"android:title="標題"android:summary="說明摘要"><ListPreferenceandroid:key="myListPreference"android:title="標題"android:summary="說明摘要"android:entries="@array/list_entries"android:entryValues="@array/list_entries_value"android:dialogTitle="dialogTitle"android:defaultValue="@array/list_entries_value2"></ListPreference></PreferenceScreen>
res/values/arrays.xml檔案,為上面的檔案提供資料
<?xml version="1.0" encoding="utf-8"?><resources> <string-array name="list_entries"> <item>山東</item> <item>福建</item> <item>北京</item> <item>河北</item> </string-array> <string-array name="list_entries_value"> <item>shandong1</item> <item>fujian1</item> <item>beijing1</item> <item>hebei1</item> </string-array> <string-array name="list_entries_value2"> <item>shandong2</item> <item>fujian2</item> <item>beijing2</item> <item>hebei2</item> </string-array></resources>
當我們運行,並選擇了福建時,我們可以查看在shared_prefes下的xml檔案如下:
<?xml version='1.0' encoding='utf-8' standalone='yes' ?><map><string name="myListPreference">fujian1</string></map>