現(xiàn)在,取代硬編碼搜索字符串,徐州APP開(kāi)發(fā)公司-酷優(yōu)網(wǎng)絡(luò)教你來(lái)實(shí)現(xiàn)用戶(hù)在SearchView中輸入并提交的查詢(xún)指令。在PhotoGallery應(yīng)用中,一次只有一個(gè)激活的查詢(xún)。應(yīng)用應(yīng)該保存這個(gè)查詢(xún),即使應(yīng)用或設(shè)備重啟也不會(huì)丟失。要實(shí)現(xiàn)這個(gè)目標(biāo),可以把查詢(xún)字符串寫(xiě)入shared preferences。只要用戶(hù)提交查詢(xún),就把它寫(xiě)入shared preferences,覆蓋掉之前保持的字符串。實(shí)際搜索Flickr時(shí),就從sharedpreferences中取出查詢(xún)字符串,把它作為text參數(shù)值。
shared preferences本質(zhì)上就是文件系統(tǒng)中的文件,可使用SharedPreferences類(lèi)讀寫(xiě)它。SharedPreferences實(shí)例用起來(lái)更像一個(gè)鍵值對(duì)倉(cāng)庫(kù)(類(lèi)似于Bundle),但它可以通過(guò)持久化存儲(chǔ)保存數(shù)據(jù)。鍵值對(duì)中的鍵為字符串,而值是原子數(shù)據(jù)類(lèi)型。進(jìn)一步查看shared preferences文件可知,它們實(shí)際上是一種簡(jiǎn)單的XML文件,但SharedPreferences類(lèi)已屏蔽了讀寫(xiě)文件的實(shí)現(xiàn)細(xì)節(jié)。shared preferences文件保存在應(yīng)用沙盒中,所以,類(lèi)似密碼這樣的敏感信息不應(yīng)該用它來(lái)保存。
要獲得定制的SharedPreferences 實(shí)例, 可使用Context.getSharedPreferences (String,int)方法。然而,在實(shí)際開(kāi)發(fā)中,我們并不關(guān)心具體是什么樣的SharedPreferences實(shí)例,只要它能共享于整個(gè)應(yīng)用就可以了。這種情況下,最好使用PreferenceManager.getDefaultSharedPreferences(Context)方法,該方法會(huì)返回具有私有權(quán)限和默認(rèn)名稱(chēng)的實(shí)例(僅在當(dāng)前應(yīng)用內(nèi)可用)。
如下圖代碼清單所示,添加一個(gè)名為QueryPreferences的新類(lèi),用于讀取和寫(xiě)入查詢(xún)字符串。

PREF_SEARCH_QUERY用作查詢(xún)字符串的存儲(chǔ)key,讀取和寫(xiě)入時(shí)都要用到它。
getStoredQuery(Context)方法返回shared preferences中保存的查詢(xún)字符串值。不過(guò),它首先要找到指定context 中的默認(rèn)SharedPreferences 。( QueryPreferences 類(lèi)沒(méi)有自己的Context,所以該方法的調(diào)用者必須傳入一個(gè)。)
取出查詢(xún)字符串值非常簡(jiǎn)單,調(diào)用SharedPreferences.getString(...)就可以了。如果是其他類(lèi)型數(shù)據(jù),就調(diào)用對(duì)應(yīng)的取值方法,比如getInt(...),SharedPreferences.getString (PREF_SEARCH_QUERY, null)方法的第二個(gè)參數(shù)指定默認(rèn)返回值;如果找不到PREF_SEARCH_QUERY對(duì)應(yīng)的值,就返回null值。
setStoredQuery(Context)方法向指定context的默認(rèn)shared preferences寫(xiě)入查詢(xún)輸入值。在以上代碼中,調(diào)用SharedPreferences.edit()方法,可獲取一個(gè)SharedPreferences.Editor實(shí)例。它就是在SharedPreferences中保存查詢(xún)信息要用到的類(lèi)。與FragmentTransaction的
使用類(lèi)似,利用SharedPreferences.Editor,可將一組數(shù)據(jù)操作放入一個(gè)事務(wù)中。如有一批數(shù)據(jù)要更新,在一個(gè)事務(wù)中進(jìn)行批量數(shù)據(jù)存儲(chǔ)寫(xiě)入操作就可以了。
完成所有數(shù)據(jù)的變更準(zhǔn)備后,調(diào)用SharedPreferences.Editor的apply()異步方法寫(xiě)入數(shù)據(jù)。這樣,該SharedPreferences文件的其他用戶(hù)就能看到寫(xiě)入的數(shù)據(jù)了。apply()方法首先在內(nèi)存中執(zhí)行數(shù)據(jù)變更,然后在后臺(tái)線程上真正把數(shù)據(jù)寫(xiě)入文件。
QueryPreferences是PhotoGallery應(yīng)用的數(shù)據(jù)存儲(chǔ)引擎。既然已經(jīng)搞定了查詢(xún)信息的讀取和寫(xiě)入方法,現(xiàn)在就來(lái)在PhotoGalleryFragment中應(yīng)用它們。
首先是保存用戶(hù)提交的查詢(xún)信息,如下圖代碼所示。

接下來(lái),在用戶(hù)從溢出菜單選擇Clear Search選項(xiàng)時(shí)清除存儲(chǔ)的查詢(xún)信息(設(shè)置為null),如下圖代碼所示。

發(fā)現(xiàn)沒(méi)有?和第二張圖片代碼中的做法一樣,更新完查詢(xún)信息,updateItems()方法會(huì)被調(diào)用。這很有必要,可以確保RecyclerView中顯示最新的搜素結(jié)果。
最后,別忘了更新FetchItemsTask,來(lái)使用保存的查詢(xún)字符串(終于可以不用硬編碼字符串了)。在FetchItemsTask中添加一個(gè)定制版構(gòu)造方法,用于接收查詢(xún)信息并保存在一個(gè)成員變量中備用。更新updateItems()方法,從shared preferences中取出保存的查詢(xún)信息,用它創(chuàng)建一個(gè)FetchItemsTask新實(shí)例,如下圖代碼所示。

搜索功能現(xiàn)在應(yīng)該可以正常使用了。運(yùn)行PhotoGallery應(yīng)用,嘗試進(jìn)行一些搜索并查看返回結(jié)果。