фильтровать представление Recycler с помощью searchview

Я пытаюсь отфильтровать RecyclerView, разместив SearchView на панели инструментов. Я следовал этому руководству. из его 25 минут, так как он выражает именно то, что я ищу, после реализации из учебника они использовали «ArrayList newList= new ArrayList‹>()», который отлично работает, но я хочу реализовать его, используя эту форму «ArrayList> newList = новый ArrayList‹ >()", так как это формат, который я прошел через проект. Я попытался сделать это следующим образом:

/// Мероприятия

public class MainActivity extends AppCompatActivity implements    SearchView.OnQueryTextListener {
// DB Class to perform DB related operations
DBController controller = new DBController(MainActivity.this);
// Progress Dialog Object
ArrayList<HashMap<String, String>> arrayList= new ArrayList<HashMap<String, String>> ();
private RecyclerView recyclerView;
private LinearLayoutManager layoutManager;
private UsersAdapter adapter;
@Override
  protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
 setContentView(R.layout.activity_main);
 Toolbar toolbar = (Toolbar) findViewById(R.id.toolbar);
 setSupportActionBar(toolbar);
 // Get User records from SQLite DB
    ArrayList<HashMap<String, String>> userList = controller.getAllUsers();
    // If users exists in SQLite DB
    if (userList.size() != 0) {
        recyclerView = (RecyclerView) findViewById(R.id.usersList);
        recyclerView.setHasFixedSize(true);
        layoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(layoutManager);
        controller = new DBController(MainActivity.this);
        ArrayList<HashMap<String, String>> users = controller.getAllUsers();
        adapter = new UsersAdapter(users,this);
        recyclerView.setAdapter(adapter);
        adapter.notifyDataSetChanged();
    }
     }
@Override
public boolean onCreateOptionsMenu(Menu menu) {
    MenuInflater inflater = getMenuInflater();
    inflater.inflate(R.menu.menu_main, menu);
    final MenuItem searchItem = menu.findItem(R.id.action_search);
    final SearchView searchView = (SearchView) MenuItemCompat.getActionView(searchItem);
  searchView.setOnQueryTextListener(this);
    return true;

}
@Override
public boolean onOptionsItemSelected(MenuItem item) {
    // Handle action bar item clicks here.
    int id = item.getItemId();
    return super.onOptionsItemSelected(item);
}

@Override
public boolean onQueryTextSubmit(String query) {
    return false;
}

    @Override
      public boolean onQueryTextChange(String newText) {
    newText = newText.toLowerCase();
    ArrayList<HashMap<String, String>> newList= new ArrayList<>();
    for(  HashMap<String, String> entry : arrayList){
        String name= entry.put("userName",newText);
        if(name.contains(newText)){
      newList.add(entry);
    }}
    adapter.setFilter(newList);
     return  true;
    }
     }

///Класс адаптера

    public class UsersAdapter extends RecyclerView.Adapter<UsersAdapter.UserViewHolder> {
ArrayList<HashMap<String, String>> mDataSet= new ArrayList<HashMap<String, String>> ();
        Context ctx;
       public UsersAdapter(ArrayList<HashMap<String, String>> mDataSet,Context ctx)      {
       this.mDataSet = mDataSet;
       this.ctx=ctx;
        }
      @Override
      public UserViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
         View v =    LayoutInflater.from(parent.getContext()).inflate(R.layout.user_row, parent,       false);
      UserViewHolder userViewHolder = new UserViewHolder(v,mDataSet,ctx);
       return userViewHolder;
         }
        @Override
     public void onBindViewHolder(UserViewHolder holder, int position) {
    holder.name_entry.setText(mDataSet.get(position).get("userId"));
    holder.email_entry.setText(mDataSet.get(position).get("userName"));
    holder.icon_entry.setText(""+mDataSet.get(position).get("number"));
          }
         @Override
        public int getItemCount() {
              return mDataSet.size();
           }

     public static class UserViewHolder extends RecyclerView.ViewHolder  {
    CardView cardView;
    TextView name_entry, email_entry, icon_entry;
    Context ctx;
        ArrayList<HashMap<String, String>> mDataSet= new   ArrayList<HashMap<String, String>> ();
        public UserViewHolder(View itemView, ArrayList<HashMap<String,  String>>        mDataSet,Context ctx) {
            super(itemView);
            this.mDataSet=mDataSet;
         this.ctx= ctx;
         cardView = (CardView) itemView.findViewById(R.id.user_layout);
         name_entry = (TextView) itemView.findViewById(R.id.name_entry);
         email_entry = (TextView) itemView.findViewById(R.id.email_entry);
         icon_entry = (TextView) itemView.findViewById(R.id.icon_entry);
              }
               }

        @Override
       public void onAttachedToRecyclerView(RecyclerView recyclerView) {
    super.onAttachedToRecyclerView(recyclerView);
           }

       public void setFilter(ArrayList<HashMap<String, String>> newList){
        //we have used hashmap,  find how to use it here
    mDataSet= new ArrayList<HashMap<String, String>>();
    mDataSet.addAll(newList);
    notifyDataSetChanged();
        }

      }

но когда я нажимаю значок поиска, представление ресайклера исчезает со всеми данными, пока я не возобновлю работу приложения. С моей точки зрения, я добавляю пустые данные, хотя не уверен, так как я новичок в Android. Любая идея о том, где я ошибся и как я могу заставить это работать. Я знаю, что есть это решение, но я его не понял Что ж.


person F.joel    schedule 16.03.2017    source источник
comment
@pskink, когда я использую этот новый класс, это означает, что я должен изменить весь класс адаптера на коды, которые вы предоставляете, проблема в моем классе адаптера, я представил такие вещи, как прослушиватель щелчка элемента, который я не могу понять, как я могу их использовать используя ваше решение. На самом деле я новичок в Android, поэтому я сложил   -  person F.joel    schedule 17.03.2017


Ответы (1)


Вы объявили в своем классе Activity:

ArrayList<HashMap<String, String>> arrayList= new ArrayList<HashMap<String, String>> ();

но вы не назначили его. Так должно быть

 arrayList = controller.getAllUsers();

Потому что у вас есть фильтр по этому полю и там всегда есть данные. И лучше переименовать эту переменную из arrayList в userList :)

person A. Shevchuk    schedule 16.03.2017
comment
спасибо @A.Shevchuk, я изменил коды в методе onQueryTextChange, и он работает, но единственное, что остается, это то, что когда я нажимаю значок поиска, искомое значение ключа исчезает, и когда я набираю его, чтобы найти значение соответствия, оно повторяется до тех пор, пока не появится слово при поиске полный. я думаю, что это связано с этим кодом здесь String name= entry.put(userName,newText); который устанавливает, который устанавливает их пустыми и ждет ввода пользователя. Как я могу решить это? - person F.joel; 17.03.2017
comment
я изменил его на String name= entry.get(number).toLowerCase(), и он отлично работает, спасибо @@A.Shevchuk - person F.joel; 17.03.2017