Проблема с поисковым фильтром в моей базе данных - PullRequest
0 голосов
/ 26 января 2019

У меня есть панель поиска, которая выполняет поиск по всей моей базе данных.

    searchView.setOnQueryTextListener(new SearchView.OnQueryTextListener() {
@Override
public boolean onQueryTextSubmit(String s) {

    return false;
}

@Override
public boolean onQueryTextChange(String s) {
    psList = ps_da.searchBox(s);
    adapterPS = new AdapterPS(ActivityPS.this,psList);
    recyclerView.setLayoutManager(new LinearLayoutManager(ActivityPS.this));
    recyclerView.setAdapter(adapterPS);
    return false;
}

, и у меня есть диалоговое окно Alert, которое фильтрует мой результат, который отображается в моем окне повторной проверки.

        imgFilter.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View v) {
            Dialog dialog = new Dialog(ActivityPS.this);
            dialog.setContentView(R.layout.dialog_filter_layout);
            Button btnfliter =dialog.findViewById(R.id.btncheckFilter);
            CheckBox chkActive = dialog.findViewById(R.id.chkActiveDirectory);
            CheckBox chkDNS = dialog.findViewById(R.id.chkDND);
            CheckBox chkDHCP = dialog.findViewById(R.id.chkDHCP);
            CheckBox chkVPN = dialog.findViewById(R.id.chkVPN);
            CheckBox IP = dialog.findViewById(R.id.IP);
            RadioGroup radioGroup = dialog.findViewById(R.id.radiogroupk);
            radioGroup.setOnCheckedChangeListener(new RadioGroup.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(RadioGroup group, int checkedId) {
                    RadioButton rd = group.findViewById(checkedId);
                    if (rd.isChecked()){
                        if (rd.getText().equals("Client")){
                            chkActive.setEnabled(false);
                            chkDHCP.setEnabled(false);
                            chkVPN.setEnabled(false);
                            chkDNS.setEnabled(false);
                        }else if (rd.getText().equals("All")){
                            chkActive.setEnabled(true);
                            chkDHCP.setEnabled(true);
                            chkVPN.setEnabled(true);
                            chkDNS.setEnabled(true);

                        }else if (rd.getText().equals("Server")){
                            chkActive.setEnabled(true);
                            chkDHCP.setEnabled(true);
                            chkVPN.setEnabled(true);
                            chkDNS.setEnabled(true);
                        }
                    }
                }
            });
            btnfliter.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {

                    if (!IP.isChecked()){
                        if (chkActive.isChecked()){
                            acvtiveDirectory = chkActive.getText().toString();
                        }if (chkDHCP.isChecked()){
                            DHCP =chkDHCP.getText().toString();
                        }if (chkDNS.isChecked()){
                            DNS = chkDNS.getText().toString();
                        }if (chkVPN.isChecked()){
                            VPN = chkVPN.getText().toString();
                        }   psList =ps_da.searchByFilter(acvtiveDirectory,DNS,DHCP,VPN);
                            adapterPS = new AdapterPS(ActivityPS.this,psList);
                            recyclerView.setAdapter(adapterPS);
                            adapterPS.notifyDataSetChanged();
                            dialog.dismiss();
                    }else {
                        psList = ps_da.findAll();
                        adapterPS = new AdapterPS(ActivityPS.this,psList);
                        recyclerView.setAdapter(adapterPS);
                        dialog.dismiss();
                    }
                }
            });
            dialog.show();
        }
    });

}

но я, когда я добавляю свой фильтр, он корректно отображается в моем окне просмотра, но когда я хочу искать между отфильтрованными результатами в строке поиска, он ищет во всей базе данных. Я хочу искать в отфильтрованном диапазоне.Любая идея?

А это мой класс DA для моего объекта PS:

public RealmResults<PS> findAll(){
    pslist = myrealm.where(PS.class).findAll();
    return pslist;
}

public RealmResults<PS> searchBox(String s){
    pslist = myrealm.where(PS.class).contains("commandName",s, Case.INSENSITIVE).findAll();
    return pslist;
}

public RealmResults<PS> searchByFilter(String Active,String DNS,String DHCP,String VPN){
    pslist = myrealm.where(PS.class).beginGroup().equalTo("commandName",Active)
            .or()
            .equalTo("commandName",DHCP)
            .or()
            .equalTo("commandName",DNS)
            .or()
            .equalTo("commandName",VPN)
            .endGroup().findAll();


    return pslist;
}

1 Ответ

0 голосов
/ 26 января 2019

В onQueryTextChange вы каждый раз создаете новый адаптер.

Вам нужно создать экземпляр адаптера один раз и сохранить его ссылку в своей деятельности, чтобы вы могли установить для него данные и вызвать getFilter().filter("") для него, чтобы отфильтровать данные, которые вы установили. Чтобы использовать фильтр в своем адаптере, вы можете реализовать Filterable, но вернуть результаты в методе performFiltering ( Фильтрация объекта области в Android ).

Вот пример (не проверял)

public class MyAdapter extends BaseAdapter<ArticleEntity> implements Filterable{

private RealmResults<ArticleEntity> items;
private RealmResults<ArticleEntity> filteredItems;
private ArticleFilter filter;

public MyAdapter(RealmResults<ArticleEntity> items) {
    this.items = items;
    filter = new ArticleFilter();
    filter.filter("");
}

public void setItems(RealmResults<ArticleEntity> items) {
    this.items = items;
    filter.filter("");
}

@Override
public int getCount() {
    return filteredItems.size();
}

@Override
public ArticleEntity getItem(int position) {
    return null;
}

@Override
public long getItemId(int position) {
    return position;
}

@Override
public Filter getFilter() {
    return filter;
}

private class ArticleFilter extends Filter {

    @Override
    protected FilterResults performFiltering(CharSequence constraint) {
        return new FilterResults();
    }

    @Override
    @SuppressWarnings("unchecked")
    protected void publishResults(CharSequence constraint, FilterResults results) {
        filteredItems = items.where()
                .equalTo("your_field", "value")
                .sort("name")
                .findAll();
        notifyDataSetChanged();
    }
}

}

Таким образом, фильтрация по флажкам должна выполняться методом publishResults.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...