Intereting Posts
Удаленные файлы Android Gradle, скопированные в APK META-INF / license.txt Аутентификация веб-API ASP.NET Как добавить кнопку в PreferenceScreen Eclipse 3.6 часто останавливается во время Content Assist Фрагмент или фрагмент – Вложенные фрагменты против действий. Почему я должен использовать более одного действия? Почему я не могу установить текст в Android TextView? Android Studio не работает нормально с gradle 2.10 и плагин gradle 2.0.0-alpha5 Застрял с запуском Gradle Разная тема для разных версий Android SDK Предупреждение о безопасности на libdvm.so отмечено при развертывании приложений для Android «Невозможно выполнить это действие после onSaveInstanceState» – почему я получаю это исключение из метода onResume моей активности? Как я могу обновить ActionBar, когда onPrepareOptionsMenu переключил записи меню? Заголовок Content-Length уже присутствует RequiresApi vs TargetApi андроид андроид Слайд RecyclerView вверх по мере того, как вы прокручиваете его или пересказываете recyclerview вниз при прокрутке вниз

Просмотр списка фильтров Android

Я создал представление списка в android, и я хочу добавить текст редактирования над списком, и когда пользователь вводит текст, список будет отфильтрован в соответствии с пользовательским вводом

Может ли кто-нибудь сказать мне, пожалуйста, если есть способ фильтровать адаптер списка в Android?

Solutions Collecting From Web of "Просмотр списка фильтров Android"

Да. Добавьте EditText поверх своего списка в его макетном файле aml. И в вашей деятельности / фрагменте.

lv = (ListView) findViewById(R.id.list_view); inputSearch = (EditText) findViewById(R.id.inputSearch); // Adding items to listview adapter = new ArrayAdapter<String>(this, R.layout.list_item, R.id.product_name, products); lv.setAdapter(adapter); inputSearch.addTextChangedListener(new TextWatcher() { @Override public void onTextChanged(CharSequence cs, int arg1, int arg2, int arg3) { // When user changed the Text MainActivity.this.adapter.getFilter().filter(cs); } @Override public void beforeTextChanged(CharSequence arg0, int arg1, int arg2, int arg3) { } @Override public void afterTextChanged(Editable arg0) {} }); 

Основным здесь является добавление OnTextChangeListener в текст редактирования и внутри метода обратного вызова применить фильтр к адаптеру listview.

РЕДАКТИРОВАТЬ

Чтобы получить фильтр в пользовательский BaseAdapter, вам потребуется реализовать интерфейс Filterable.

 class CustomAdapter extends BaseAdapter implements Filterable { public View getView(){ ... } public Integer getCount() { ... } @Override public Filter getFilter() { Filter filter = new Filter() { @SuppressWarnings("unchecked") @Override protected void publishResults(CharSequence constraint, FilterResults results) { arrayListNames = (List<String>) results.values; notifyDataSetChanged(); } @Override protected FilterResults performFiltering(CharSequence constraint) { FilterResults results = new FilterResults(); ArrayList<String> FilteredArrayNames = new ArrayList<String>(); // perform your search here using the searchConstraint String. constraint = constraint.toString().toLowerCase(); for (int i = 0; i < mDatabaseOfNames.size(); i++) { String dataNames = mDatabaseOfNames.get(i); if (dataNames.toLowerCase().startsWith(constraint.toString())) { FilteredArrayNames.add(dataNames); } } results.count = FilteredArrayNames.size(); results.values = FilteredArrayNames; Log.e("VALUES", results.values.toString()); return results; } }; return filter; } } 

Внутри perfromFiltering () вам нужно выполнить фактическое сравнение поискового запроса с значениями в вашей базе данных. Он передаст свой результат publishResults () .

Внедрите свой адаптер.

 public class vJournalAdapter extends ArrayAdapter<JournalModel> implements Filterable{ private ArrayList<JournalModel> items; private Context mContext; .... 

Затем создайте свой класс Filter:

 private class JournalFilter extends Filter{ @Override protected FilterResults performFiltering(CharSequence constraint) { FilterResults result = new FilterResults(); List<JournalModel> allJournals = getAllJournals(); if(constraint == null || constraint.length() == 0){ result.values = allJournals; result.count = allJournals.size(); }else{ ArrayList<JournalModel> filteredList = new ArrayList<JournalModel>(); for(JournalModel j: allJournals){ if(j.source.title.contains(constraint)) filteredList.add(j); } result.values = filteredList; result.count = filteredList.size(); } return result; } @SuppressWarnings("unchecked") @Override protected void publishResults(CharSequence constraint, FilterResults results) { if (results.count == 0) { notifyDataSetInvalidated(); } else { items = (ArrayList<JournalModel>) results.values; notifyDataSetChanged(); } } } 

Таким образом, ваш адаптер Filterable, вы можете передать элемент фильтра в фильтр адаптера и выполнить работу. Надеюсь, это будет полезно.

В случае, если кто-то еще заинтересован в этом вопросе, я считаю, что наилучшим подходом для фильтрации списков является создание общего класса фильтра и его использование с использованием некоторых методов базового отражения / генериков, содержащихся в пакете SDK старой школы Java. Вот что я сделал:

 public class GenericListFilter<T> extends Filter { /** * Copycat constructor * @param list the original list to be used */ public GenericListFilter (List<T> list, String reflectMethodName, ArrayAdapter<T> adapter) { super (); mInternalList = new ArrayList<>(list); mAdapterUsed = adapter; try { ParameterizedType stringListType = (ParameterizedType) getClass().getField("mInternalList").getGenericType(); mCompairMethod = stringListType.getActualTypeArguments()[0].getClass().getMethod(reflectMethodName); } catch (Exception ex) { Log.w("GenericListFilter", ex.getMessage(), ex); try { if (mInternalList.size() > 0) { T type = mInternalList.get(0); mCompairMethod = type.getClass().getMethod(reflectMethodName); } } catch (Exception e) { Log.e("GenericListFilter", e.getMessage(), e); } } } /** * Let's filter the data with the given constraint * @param constraint * @return */ @Override protected FilterResults performFiltering(CharSequence constraint) { FilterResults results = new FilterResults(); List<T> filteredContents = new ArrayList<>(); if ( constraint.length() > 0 ) { try { for (T obj : mInternalList) { String result = (String) mCompairMethod.invoke(obj); if (result.toLowerCase().startsWith(constraint.toString().toLowerCase())) { filteredContents.add(obj); } } } catch (Exception ex) { Log.e("GenericListFilter", ex.getMessage(), ex); } } else { filteredContents.addAll(mInternalList); } results.values = filteredContents; results.count = filteredContents.size(); return results; } /** * Publish the filtering adapter list * @param constraint * @param results */ @Override protected void publishResults(CharSequence constraint, FilterResults results) { mAdapterUsed.clear(); mAdapterUsed.addAll((List<T>) results.values); if ( results.count == 0 ) { mAdapterUsed.notifyDataSetInvalidated(); } else { mAdapterUsed.notifyDataSetChanged(); } } // class properties private ArrayAdapter<T> mAdapterUsed; private List<T> mInternalList; private Method mCompairMethod; } 

И после этого единственное, что вам нужно сделать, это создать фильтр в качестве класса-члена (возможно, в представлении «onCreate»), передав ссылку на ваш адаптер, ваш список и метод, который нужно вызвать для фильтрации:

 this.mFilter = new GenericFilter<MyObjectBean> (list, "getName", adapter); 

Единственное, чего сейчас нет, это переопределить метод getFilter в классе адаптера:

 @Override public Filter getFilter () { return MyViewClass.this.mFilter; } 

Все сделано! Вы должны успешно отфильтровать свой список. Конечно, вы также должны реализовать алгоритм фильтра наилучшим образом, который описывает вашу потребность, ниже приведенный ниже код. , Надеюсь, это помогло, позаботьтесь.