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