現(xiàn)在,取代硬編碼搜索字符串,南昌APP開發(fā)公司-百恒網(wǎng)絡(luò)教你來實現(xiàn)用戶在SearchView中輸入并提交的查詢指令。在PhotoGallery應(yīng)用中,一次只有一個激活的查詢。應(yīng)用應(yīng)該保存這個查詢,即使應(yīng)用或設(shè)備重啟也不會丟失。要實現(xiàn)這個目標(biāo),可以把查詢字符串寫入shared preferences。只要用戶提交查詢,就把它寫入shared preferences,覆蓋掉之前保持的字符串。實際搜索Flickr時,就從sharedpreferences中取出查詢字符串,把它作為text參數(shù)值。
shared preferences本質(zhì)上就是文件系統(tǒng)中的文件,可使用SharedPreferences類讀寫它。SharedPreferences實例用起來更像一個鍵值對倉庫(類似于Bundle),但它可以通過持久化存儲保存數(shù)據(jù)。鍵值對中的鍵為字符串,而值是原子數(shù)據(jù)類型。進(jìn)一步查看shared preferences文件可知,它們實際上是一種簡單的XML文件,但SharedPreferences類已屏蔽了讀寫文件的實現(xiàn)細(xì)節(jié)。shared preferences文件保存在應(yīng)用沙盒中,所以,類似密碼這樣的敏感信息不應(yīng)該用它來保存。
要獲得定制的SharedPreferences 實例, 可使用Context.getSharedPreferences (String,int)方法。然而,在實際開發(fā)中,我們并不關(guān)心具體是什么樣的SharedPreferences實例,只要它能共享于整個應(yīng)用就可以了。這種情況下,最好使用PreferenceManager.getDefaultSharedPreferences(Context)方法,該方法會返回具有私有權(quán)限和默認(rèn)名稱的實例(僅在當(dāng)前應(yīng)用內(nèi)可用)。
如下圖代碼清單所示,添加一個名為QueryPreferences的新類,用于讀取和寫入查詢字符串。
PREF_SEARCH_QUERY用作查詢字符串的存儲key,讀取和寫入時都要用到它。
getStoredQuery(Context)方法返回shared preferences中保存的查詢字符串值。不過,它首先要找到指定context 中的默認(rèn)SharedPreferences 。( QueryPreferences 類沒有自己的Context,所以該方法的調(diào)用者必須傳入一個。)
取出查詢字符串值非常簡單,調(diào)用SharedPreferences.getString(...)就可以了。如果是其他類型數(shù)據(jù),就調(diào)用對應(yīng)的取值方法,比如getInt(...),SharedPreferences.getString (PREF_SEARCH_QUERY, null)方法的第二個參數(shù)指定默認(rèn)返回值;如果找不到PREF_SEARCH_QUERY對應(yīng)的值,就返回null值。
setStoredQuery(Context)方法向指定context的默認(rèn)shared preferences寫入查詢輸入值。在以上代碼中,調(diào)用SharedPreferences.edit()方法,可獲取一個SharedPreferences.Editor實例。它就是在SharedPreferences中保存查詢信息要用到的類。與FragmentTransaction的
使用類似,利用SharedPreferences.Editor,可將一組數(shù)據(jù)操作放入一個事務(wù)中。如有一批數(shù)據(jù)要更新,在一個事務(wù)中進(jìn)行批量數(shù)據(jù)存儲寫入操作就可以了。
完成所有數(shù)據(jù)的變更準(zhǔn)備后,調(diào)用SharedPreferences.Editor的apply()異步方法寫入數(shù)據(jù)。這樣,該SharedPreferences文件的其他用戶就能看到寫入的數(shù)據(jù)了。apply()方法首先在內(nèi)存中執(zhí)行數(shù)據(jù)變更,然后在后臺線程上真正把數(shù)據(jù)寫入文件。
QueryPreferences是PhotoGallery應(yīng)用的數(shù)據(jù)存儲引擎。既然已經(jīng)搞定了查詢信息的讀取和寫入方法,現(xiàn)在就來在PhotoGalleryFragment中應(yīng)用它們。
首先是保存用戶提交的查詢信息,如下圖代碼所示。
接下來,在用戶從溢出菜單選擇Clear Search選項時清除存儲的查詢信息(設(shè)置為null),如下圖代碼所示。
發(fā)現(xiàn)沒有?和第二張圖片代碼中的做法一樣,更新完查詢信息,updateItems()方法會被調(diào)用。這很有必要,可以確保RecyclerView中顯示最新的搜素結(jié)果。
最后,別忘了更新FetchItemsTask,來使用保存的查詢字符串(終于可以不用硬編碼字符串了)。在FetchItemsTask中添加一個定制版構(gòu)造方法,用于接收查詢信息并保存在一個成員變量中備用。更新updateItems()方法,從shared preferences中取出保存的查詢信息,用它創(chuàng)建一個FetchItemsTask新實例,如下圖代碼所示。
搜索功能現(xiàn)在應(yīng)該可以正常使用了。運(yùn)行PhotoGallery應(yīng)用,嘗試進(jìn)行一些搜索并查看返回結(jié)果。
了解更多南昌APP開發(fā)、微信開發(fā)等技術(shù)資訊,歡迎來電咨詢百恒網(wǎng)絡(luò),或者訪問百恒網(wǎng)絡(luò)官網(wǎng)查看,網(wǎng)址:http://syshcw.cn/