後方互換性を維持する

SearchView とアクションバーは、Android 3.0 以降でのみご利用いただけます。 後で説明しますそれより古いプラットフォームをサポートするには、検索ダイアログを代用することができます。検索ダイアログは 呼び出されたときにアプリ上にオーバーレイするシステム提供の UI。

最小 API レベルと対象 API レベルを設定する

検索ダイアログを設定するには、まずマニフェストで古いバージョンをサポートすることを宣言します ただし Android 3.0 以降のバージョンをターゲットに設定したい場合。この操作を行うと、 Android 3.0 以降では自動的にアクションバーが使用され、 古いデバイスの場合:

<uses-sdk android:minSdkVersion="7" android:targetSdkVersion="15" />

<application>
...

古いデバイスの場合に検索ダイアログを提供する

古いデバイスで検索ダイアログを呼び出すには、ユーザーが検索を選択するたびに onSearchRequested() を呼び出します。 オプション メニューから選択します。Android 3.0 以降のデバイスでは (最初のレッスンで説明したように)SearchView、バージョンのみ 場合、onOptionsItemSelected() を呼び出します。 ユーザーが検索メニュー項目を選択したとき。

Kotlin

override fun onOptionsItemSelected(item: MenuItem): Boolean {
    return when (item.itemId) {
        R.id.search -> {
            onSearchRequested()
            true
        }
        else -> false
    }
}

Java

@Override
public boolean onOptionsItemSelected(MenuItem item) {
    switch (item.getItemId()) {
        case R.id.search:
            onSearchRequested();
            return true;
        default:
            return false;
    }
}

実行時に Android ビルド バージョンをチェックする

実行時にデバイスのバージョンをチェックして、古いデバイスだった場合に、サポートされていない SearchView を使用しないようにします。このコード例では、この処理を onCreateOptionsMenu() メソッドを使用します。

Kotlin

override fun onCreateOptionsMenu(menu: Menu): Boolean {

    menuInflater.inflate(R.menu.options_menu, menu)

    if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
        val searchManager = getSystemService(Context.SEARCH_SERVICE) as SearchManager
        (menu.findItem(R.id.search).actionView as SearchView).apply {
            setSearchableInfo(searchManager.getSearchableInfo(componentName))
            setIconifiedByDefault(false)
        }
    }
    return true
}

Java

@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;
}