Android的搜索框架實(shí)例詳解
基礎(chǔ)知識
Android的搜索框架將代您管理的搜索對話框,您不需要自己去開發(fā)一個(gè)搜索框,不需要擔(dān)心要把搜索框放什么位置,也不需要擔(dān)心搜索框影響您當(dāng)前的界面。所有的這些工作都由SearchManager類來為您處理(以下簡稱“搜索管理器”),它管理的Android搜索對話框的整個(gè)生命周期,并執(zhí)行您的應(yīng)用程序?qū)l(fā)送的搜索請求,返回相應(yīng)的搜索關(guān)鍵字。
當(dāng)用戶執(zhí)行一個(gè)搜索,搜索管理器將使用一個(gè)專門的Intent把搜索查詢的關(guān)鍵字傳給您在配置文件中配置的處理搜索結(jié)果的Activity。從本質(zhì)上講,所有你需要的就是一個(gè)Activity來接收Intent,然后執(zhí)行搜索,并給出結(jié)果。具體來說,你需要的做的事就包括以下內(nèi)容:
一個(gè)搜索配置
我們用個(gè)XML配置文件來對搜索對話框進(jìn)行配置,包括一些功能的配置,如文本框,設(shè)置語音搜索和搜索建議中顯示的提示文字等。
一個(gè)用來處理搜索請求的Activity
這個(gè)Activity用來接收搜索查詢的內(nèi)容,然后搜索您的數(shù)據(jù)并顯示搜索結(jié)果。
一種用戶執(zhí)行搜索的途徑
默認(rèn)情況下,一旦你配置了一個(gè)可搜索的Activity,設(shè)備搜索鍵(如果有)將調(diào)用搜索對話框。然而,你應(yīng)該始終提供另一種手段,讓用戶可以調(diào)用搜索對話框,如在選項(xiàng)菜單中的搜索按鈕或其他用戶界面上的按鈕,因?yàn)椴皇撬械脑O(shè)備提供一個(gè)專門的搜索鍵。
創(chuàng)建一個(gè)搜索對話框配置文件
搜索框配置文件是一個(gè)用來配置您的應(yīng)用程序中搜索框的設(shè)置的XML文件,這個(gè)文件一般命名為searchable.xml,并且必須保存在項(xiàng)目的res/xml/目錄下。
配置文件的根節(jié)點(diǎn)必須為,可以有一個(gè)或多個(gè)屬性。如下所示:
<?xml version="1.0" encoding="utf-8"?> <searchable xmlns:android="http://schemas.android.com/apk/res/android" android:label="@string/searchLabel" android:hint="@string/searchHint"> </searchable>
上面的配置文件中,除android:hint屬性外,其它都是一個(gè)搜索對話框必須的配置項(xiàng),android:label是一個(gè)必須的屬性,它的值為一個(gè)string資源引用,不能直接用字符串,通常會是應(yīng)用程序的名稱(盡管它是一個(gè)必須的屬性,但通常情況下是不顯示出來的,除非你開啟了搜索建議功能)。android:hint是配置搜索框的輸入提示信息,也必須引用string.xml中配置的字符串資源,不能直接使用字符串。
可以配置很多的屬性,但大部分屬性都只是在使用搜索建議和語音搜索時(shí)進(jìn)行配置,盡管如此,我們建議你一定要配置android:hint,用于提示用戶需要輸入的信息。
接下來,你需要把這個(gè)配置文件放到你的應(yīng)用程序中。
創(chuàng)建一個(gè)可用于搜索的Activity
當(dāng)用戶從一個(gè)搜索框執(zhí)行搜索時(shí),搜索管理器(Search Manager)會通過ACTION_SEARCH Intent 把要搜索的內(nèi)容(關(guān)鍵字)發(fā)送到一個(gè)可執(zhí)行搜索的Activity。這個(gè)Acitivity查詢數(shù)據(jù)并顯示結(jié)果。
定義一個(gè)可搜索的Activity
如果你還沒有準(zhǔn)備好,那么就創(chuàng)建一個(gè)用來執(zhí)行搜索的Activity,聲明它可以響應(yīng)ACTION_SEARCH Intent ,并且增加搜索框配置信息。為此,你需要添加一個(gè)元素和一個(gè)元素在你的manifest文件中的節(jié)點(diǎn)。如下所示:
<application ... > <activity android:name=".MySearchableActivity" > <intent-filter> <action android:name="android.intent.action.SEARCH" /> </intent-filter> <meta-data android:name="android.app.searchable" android:resource="@xml/searchable"/> </activity> ... </application>
中的android:name屬性值必須為”android.app.searchable”,android:resource屬性值必須引用上面提到的res/xml/目錄下的搜索配置文件(本例中的res/xml/searchable.xml)。
請注意,只有配置了上面的meta-data節(jié)點(diǎn)的Activity的節(jié)點(diǎn)才能執(zhí)行搜索,如果想在整個(gè)應(yīng)用程序中都可以調(diào)用搜索框,可以進(jìn)行如下配置:
<application ... > <activity android:name=".MySearchableActivity" > <intent-filter> <action android:name="android.intent.action.SEARCH" /> </intent-filter> <meta-data android:name="android.app.searchable" android:resource="@xml/searchable"/> </activity> <activity android:name=".AnotherActivity" ... > </activity> <!—這個(gè)配置就可以讓你在整個(gè)應(yīng)用程序中調(diào)用搜索框 --> <meta-data android:name="android.app.default_searchable" android:value=".MySearchableActivity" /> ... </application>
上面代碼中android:name=”android.app.default_searchable” 定義一個(gè)響應(yīng)搜索框搜索請求的名稱,android:value指定是由哪個(gè)Activity響應(yīng)并執(zhí)行搜索。當(dāng)我們在應(yīng)用程序中的 OtherAcitivity中執(zhí)行搜索請求時(shí),MySearchableActivity將會被加載用于執(zhí)行搜索并顯示搜索結(jié)果。
執(zhí)行一個(gè)搜索
當(dāng)一個(gè)Activity聲明為可搜索時(shí),執(zhí)行實(shí)際的搜索包括三個(gè)步驟:接收查詢,檢索你的數(shù)據(jù),并提交結(jié)果。
通常情況下,你的搜索結(jié)果需要在一個(gè)ListView中展現(xiàn),所以你用于執(zhí)行搜索的Acitivity要繼承ListActivity,這樣,可以方便的訪問ListView的Api。
接收搜索查詢
當(dāng)從搜索對話框執(zhí)行搜索時(shí),剛才配置的可用于搜索的Acitivity將會被Intent激活,同時(shí)帶著一些搜索相關(guān)的參數(shù),你需要檢查Intent并做出搜索響應(yīng),如下所示:
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.search);
Intent intent = getIntent();
//判斷是否是搜索請求
if (Intent.ACTION_SEARCH.equals(intent.getAction())) {
//獲取搜索的查詢內(nèi)容(關(guān)鍵字)
String query = intent.getStringExtra(SearchManager.QUERY);
//執(zhí)行相應(yīng)的查詢動作
doMySearch(query);
}
}
doMySearch()方法將根據(jù)關(guān)鍵字查詢數(shù)據(jù)庫,或從網(wǎng)絡(luò)上查詢數(shù)據(jù),如果是耗時(shí)的搜索,你還需要使用進(jìn)度條,來告訴用戶搜索正在進(jìn)行,最后返回結(jié)果后,可以調(diào)用ListView的setAdapter()方法將結(jié)果顯示在ListView中。
調(diào)用搜索對話框
你可以從應(yīng)用程序中的任何一個(gè)地方調(diào)用onSearchRequested()方法激活搜索框,比如從菜單中或者一個(gè)按鈕等。你也要以在 onCreate()方法中調(diào)用setDefaultKeyMode(DEFAULT_KEYS_SEARCH_LOCAL),這樣,當(dāng)用戶按下鍵盤上的按鍵時(shí),將會自動激活搜索框。
搜索框和普通對話框一樣,浮動在屏幕的最上方,它不會改變?nèi)魏蜛ctivity堆棧狀態(tài),沒有任何Activity生命周期中的方法會被調(diào)用,只是當(dāng)搜索框出現(xiàn)就,正在運(yùn)行的Activity會失去輸入焦點(diǎn)。
如果你要在執(zhí)行搜索時(shí),進(jìn)行別的操作,可以重寫onSearchRequested()方法,如下所示:
@Override
public boolean onSearchRequested() {
//這個(gè)方法中干你想干的事,比如做一些被始化工作
pauseSomeStuff();
return super.onSearchRequested();
}
如果當(dāng)前的Activity就是響應(yīng)搜索請求的Activity時(shí),會有以下兩種情況:
默認(rèn)情況下,ACTION_SEARCH Intent將會創(chuàng)建一個(gè)新的Activity,并調(diào)用onCreate()方法,這個(gè)新的Activity會顯示在最前面,你將同時(shí)有兩個(gè) Activity實(shí)例。當(dāng)你按“返回”鍵里,會回到?jīng)]有執(zhí)行搜索前的一個(gè)Activity。
另一種情況是配置了android:launchMode=”singleTop”的Activity,這時(shí),我們需要在 onNewIntent(Intent)方法中處理搜索請求,如下所示:
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.search);
handleIntent(getIntent());
}
@Override
protected void onNewIntent(Intent intent) {
setIntent(intent);
handleIntent(intent);
}
private void handleIntent(Intent intent) {
if (Intent.ACTION_SEARCH.equals(intent.getAction())) {
String query = intent.getStringExtra(SearchManager.QUERY);
doMySearch(query);
}
}
相應(yīng)的Activity配置如下
<activity android:name=".MySearchableActivity" android:launchMode="singleTop" > <intent-filter> <action android:name="android.intent.action.SEARCH" /> </intent-filter> <meta-data android:name="android.app.searchable" android:resource="@xml/searchable"/> </activity>
如何給搜索框增加參數(shù)
要給搜索框傳遞參數(shù),我們需要重寫onSearchRequested()方法,如下所示:
@Override
public boolean onSearchRequested() {
Bundle appData = new Bundle();
appData.putBoolean(MySearchableActivity.JARGON, true);
startSearch(null, false, appData, false);
return true;
}
我們的Activity在收到搜索框的搜索請求時(shí),通過如下方法獲取參數(shù):
Bundle appData = getIntent().getBundleExtra(SearchManager.APP_DATA);
if (appData != null) {
boolean jargon = appData.getBoolean(MySearchableActivity.JARGON);
}
最后我們來看看如何使用android的語音搜索:
只需要對我們的搜索配置文件做如下改動,你的搜索就支持語音搜索了,配置文件如下所示:
<?xml version="1.0" encoding="utf-8"?> <searchable xmlns:android="http://schemas.android.com/apk/res/android" android:label="@string/searchLabel" android:hint="@string/searchHint" android:voiceSearchMode="showVoiceSearchButton|launchRecognizer"> </searchable>
以上所述是小編給大家介紹的Android的搜索框架實(shí)例詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時(shí)回復(fù)大家的!
相關(guān)文章
Android通過PHP服務(wù)器實(shí)現(xiàn)登錄功能
這篇文章主要為大家詳細(xì)介紹了Android通過PHP服務(wù)器實(shí)現(xiàn)登錄功能的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
詳解Android——藍(lán)牙技術(shù) 帶你實(shí)現(xiàn)終端間數(shù)據(jù)傳輸
藍(lán)牙技術(shù)在智能硬件方面有很多用武之地,本篇文章主要介紹了Android——藍(lán)牙技術(shù),實(shí)現(xiàn)兩個(gè)終端間數(shù)據(jù)的傳輸,有興趣的朋友可以了解一下。2016-12-12
SDL2和OpenGL使用踩坑筆記經(jīng)驗(yàn)分享
今天小編就為大家分享一篇關(guān)于SDL2和OpenGL使用踩坑筆記經(jīng)驗(yàn)分享,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧2018-12-12
Android框架Volley之利用Imageloader和NetWorkImageView加載圖片的方法
這篇文章主要介紹了Android框架Volley之利用Imageloader和NetWorkImageView加載圖片的實(shí)現(xiàn)方法,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值 ,需要的朋友可以參考下2019-05-05
直接可用的Android studio學(xué)生信息管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了直接可用的Android studio學(xué)生信息管理系統(tǒng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-01-01
Android判斷軟鍵盤的狀態(tài)和隱藏軟鍵盤的簡單實(shí)例
下面小編就為大家?guī)硪黄狝ndroid判斷軟鍵盤的狀態(tài)和隱藏軟鍵盤的簡單實(shí)例。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-10-10
Android自定義View 仿QQ側(cè)滑菜單的實(shí)現(xiàn)代碼
這篇文章主要介紹了Android自定義View 仿QQ側(cè)滑菜單的實(shí)現(xiàn)代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下2017-08-08
Android自定義時(shí)間軸的實(shí)現(xiàn)過程
這篇文章主要介紹了Android自定義時(shí)間軸的實(shí)現(xiàn)過程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01

