【问题标题】:Problem with search Filter in my Database我的数据库中的搜索过滤器问题
【发布时间】:2019-06-19 23:33:04
【问题描述】:

我有一个搜索栏,可以搜索我的所有数据库。

    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;
}

我有一个警报对话框,用于过滤显示在我的 recyclerview 中的结果。

        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();
        }
    });

}

但是当我添加过滤器时,它会正确显示在我的 recyclerview 上,但是当我想在搜索栏中的过滤结果之间搜索时,它会在整个数据库中搜索。我想在过滤范围内搜索。有什么想法吗?

这就是我的 PS 对象的领域 DA 类:

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;
}

【问题讨论】:

  • 你需要保存你的状态,如果你的过滤器检查与否,然后 searchBox(String s) 和过滤器。或者手动搜索,迭代searchByFilter()返回的pslist

标签: android search realm full-text-search


【解决方案1】:

onQueryTextChange 中,您每次都创建一个新适配器。

您需要实例化一次适配器并将其引用保留在您的活动中,因此您可以为其设置数据并在其上调用getFilter().filter("") 以过滤您设置的数据。 要在适配器中使用过滤器,您可以实现 Filterable,但在 performFiltering 方法 (Filtering Realm object in 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 方法中完成。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2014-04-04
    • 1970-01-01
    • 2020-07-27
    • 2014-01-23
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2020-09-04
    相关资源
    最近更新 更多