編寫:Lin-H - 原文:http://developer.android.com/training/search/backward-compat.html
SearchView和action bar只在Android 3.0以及以上版本可用。為了支持舊版本平臺,你可以回到搜索對話框。搜索框是系統(tǒng)提供的UI,在調(diào)用時會覆蓋在你的應(yīng)用的最頂端。
要設(shè)置搜索對話框,首先在你的manifest中聲明你要支持舊版本設(shè)備,并且目標(biāo)平臺為Android 3.0或更新版本。當(dāng)你這么做之后,你的應(yīng)用會自動地在Android 3.0或以上使用action bar,在舊版本的設(shè)備使用傳統(tǒng)的目錄系統(tǒng):
<uses-sdk android:minSdkVersion="7" android:targetSdkVersion="15" />
<application>
...
要在舊版本設(shè)備中調(diào)用搜索對話框,可以在任何時候,當(dāng)用戶從選項目錄中選擇搜索項時,調(diào)用[onSearchRequested()](reference/android/app/Activity.html#onSearchRequested())。因為Android 3.0或以上會在action bar中顯示SearchView(就像在第一節(jié)課中演示的那樣),所以當(dāng)用戶選擇目錄的搜索項時,只有Android 3.0以下版本的會調(diào)用onOptionsItemSelected()。
@Override
public boolean onOptionsItemSelected(MenuItem item) {
switch (item.getItemId()) {
case R.id.search:
onSearchRequested();
return true;
default:
return false;
}
}
在運(yùn)行時,檢查設(shè)備的版本可以保證在舊版本設(shè)備中,不使用不支持的SearchView。在我們這個例子中,這一操作在onCreateOptionsMenu()方法中:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
MenuInflater inflater = getMenuInflater();
inflater.inflate(R.menu.options_menu, menu);
if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
SearchManager searchManager =
(SearchManager) getSystemService(Context.SEARCH_SERVICE);
SearchView searchView =
(SearchView) menu.findItem(R.id.search).getActionView();
searchView.setSearchableInfo(
searchManager.getSearchableInfo(getComponentName()));
searchView.setIconifiedByDefault(false);
}
return true;
}