Próbuję dodać obsługę SearchView
paska ActionBar systemu Android 3.0+, ale nie mogę go uruchomić OnCloseListener
.
Oto mój kod:
@Override
public boolean onCreateOptionsMenu(Menu menu) {
getMenuInflater().inflate(R.menu.menu, menu);
searchView = (SearchView) menu.findItem(R.id.search_textbox).getActionView();
searchView.setOnQueryTextListener(new OnQueryTextListener() {
@Override
public boolean onQueryTextChange(String newText) {
searchLibrary(newText);
return false;
}
@Override
public boolean onQueryTextSubmit(String query) { return false; }
});
searchView.setOnCloseListener(new OnCloseListener() {
@Override
public boolean onClose() {
System.out.println("Testing. 1, 2, 3...");
return false;
}
});
return true;
}
Wyszukiwanie działa świetnie i wszystko działa, z wyjątkiem OnCloseListener
. Nic nie jest drukowane do Logcat. Oto Logcat, kiedy naciskam przycisk „Zamknij”:
02-17 13:01:52.914: I/TextType(446): TextType = 0x0
02-17 13:01:57.344: I/TextType(446): TextType = 0x0
02-17 13:02:02.944: I/TextType(446): TextType = 0x0
Przejrzałem dokumentację i próbki, ale wydawało się, że nic tego nie zmienia. Używam go na Asus Transformer Prime i Galaxy Nexus, oba na Ice Cream Sandwich. Jakieś pomysły?
Aktualizacja:
Tak - System.out.println()
ma pracę. Oto dowód:
@Override
public boolean onQueryTextChange(String newText) {
System.out.println(newText + "hello");
searchLibrary(newText);
return false;
}
Wyniki w tym Logcat:
02-17 13:04:20.094: I/System.out(21152): hello
02-17 13:04:24.914: I/System.out(21152): thello
02-17 13:04:25.394: I/System.out(21152): tehello
02-17 13:04:25.784: I/System.out(21152): teshello
02-17 13:04:26.064: I/System.out(21152): testhello