Pozostała zgodność wsteczna

SearchView i pasek działań są dostępne tylko na Androidzie 3.0 i nowszych. Aby obsługiwać starsze platformy, możesz wrócić do okna wyszukiwania. Okno wyszukiwania to interfejs systemu, który po wywołaniu nakłada się na aplikację.

Ustawianie minimalnych i docelowych poziomów interfejsu API

Aby skonfigurować okno wyszukiwania, najpierw zadeklaruj w pliku manifestu, że chcesz obsługiwać starsze urządzenia, ale chcesz kierować reklamy na Androida 3.0 lub nowszego. Gdy to zrobisz, aplikacja automatycznie korzysta z paska działań w Androidzie 3.0 lub nowszym, a na starszych urządzeniach korzysta z tradycyjnego systemu menu:

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

<application>
...

Wyświetl okno wyszukiwania dla starszych urządzeń

Aby wywołać okno wyszukiwania na starszych urządzeniach, wywołaj onSearchRequested() za każdym razem, gdy użytkownik wybierze z menu opcji pozycję wyszukiwania. Urządzenia z Androidem 3.0 i nowszym wyświetlają na pasku działań SearchView (jak pokazano w pierwszej lekcji), więc tylko wersje starsze niż 3.0 wywołują metodę onOptionsItemSelected() po kliknięciu przez użytkownika opcji wyszukiwania.

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

Sprawdzanie wersji kompilacji Androida w środowisku wykonawczym

W czasie działania aplikacji sprawdź wersję urządzenia, aby upewnić się, że funkcja SearchView nie występuje na starszych urządzeniach. W naszym przykładowym kodzie dzieje się to w metodzie 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;
}