Znalezienie rozwiązania tego problemu zajęło trochę czasu, ale okazało się, że jest to najłatwiejszy sposób, aby to zadziałało w sposób, który opisałeś. Mogłyby być lepsze sposoby, aby to zrobić, ale ponieważ nie opublikowałeś kodu aktywności, będę musiał improwizować i założyć, że masz taką listę na początku swojej aktywności:
private List<String> items = db.getItems();
ExampleActivity.java
private List<String> items;
private Menu menu;
@Override
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.example, menu);
this.menu = menu;
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
SearchManager manager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
SearchView search = (SearchView) menu.findItem(R.id.search).getActionView();
search.setSearchableInfo(manager.getSearchableInfo(getComponentName()));
search.setOnQueryTextListener(new OnQueryTextListener() {
@Override
public boolean onQueryTextChange(String query) {
loadHistory(query);
return true;
}
});
}
return true;
}
@TargetApi(Build.VERSION_CODES.HONEYCOMB)
private void loadHistory(String query) {
if(Build.VERSION.SDK_INT >= Build.VERSION_CODES.HONEYCOMB) {
String[] columns = new String[] { "_id", "text" };
Object[] temp = new Object[] { 0, "default" };
MatrixCursor cursor = new MatrixCursor(columns);
for(int i = 0; i < items.size(); i++) {
temp[0] = i;
temp[1] = items.get(i);
cursor.addRow(temp);
}
SearchManager manager = (SearchManager) getSystemService(Context.SEARCH_SERVICE);
final SearchView search = (SearchView) menu.findItem(R.id.search).getActionView();
search.setSuggestionsAdapter(new ExampleAdapter(this, cursor, items));
}
}
Teraz musisz utworzyć adapter rozszerzony z CursorAdapter
:
ExampleAdapter.java
public class ExampleAdapter extends CursorAdapter {
private List<String> items;
private TextView text;
public ExampleAdapter(Context context, Cursor cursor, List<String> items) {
super(context, cursor, false);
this.items = items;
}
@Override
public void bindView(View view, Context context, Cursor cursor) {
text.setText(items.get(cursor.getPosition()));
}
@Override
public View newView(Context context, Cursor cursor, ViewGroup parent) {
LayoutInflater inflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
View view = inflater.inflate(R.layout.item, parent, false);
text = (TextView) view.findViewById(R.id.text);
return view;
}
}
Lepszym sposobem na to jest, jeśli dane listy pochodzą z bazy danych, można przekazać Cursor
zwracane przez funkcje bazy danych bezpośrednio do ExampleAdapter
i użyć odpowiedniego selektora kolumny, aby wyświetlić tekst kolumny w elemencie, do którego TextView
odwołuje się adapter.
Uwaga: podczas importowania CursorAdapter
nie importuj wersji obsługi systemu Android, android.widget.CursorAdapter
zamiast tego zaimportuj standard .
Adapter będzie również wymagał niestandardowego układu:
res / layout / item.xml
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TextView
android:id="@+id/item"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</RelativeLayout>
Teraz można dostosowywać elementy listy, dodając do układu dodatkowe widoki tekstu lub obrazów i wypełniając je danymi w adapterze.
To powinno być wszystko, ale jeśli jeszcze tego nie zrobiłeś, potrzebujesz elementu menu SearchView:
res / menu / example.xml
<menu xmlns:android="http://schemas.android.com/apk/res/android">
<item
android:id="@+id/search"
android:title="@string/search"
android:showAsAction="ifRoom"
android:actionViewClass="android.widget.SearchView" />
</menu>
Następnie utwórz konfigurację z możliwością wyszukiwania:
res / xml / searchable.xml
<searchable xmlns:android="http://schemas.android.com/apk/res/android"
android:label="@string/search"
android:hint="@string/search" >
</searchable>
Na koniec dodaj to wewnątrz odpowiedniego tagu aktywności w pliku manifestu:
AndroidManifest.xml
<intent-filter>
<action android:name="android.intent.action.SEARCH" />
</intent-filter>
<meta-data
android:name="android.app.default_searchable"
android:value="com.example.ExampleActivity" />
<meta-data
android:name="android.app.searchable"
android:resource="@xml/searchable" />
Uwaga: @string/search
ciąg znaków użyty w przykładach powinien być zdefiniowany w values / strings.xml , nie zapomnij również zaktualizować odniesienia do com.example
swojego projektu.