android - 在 SearchView [Inventory App] 中搜索项目时无法滑动删除

标签 android android-recyclerview

实际上,我正在尝试制作一个库存应用。

所以在扫描一些条形码后,我将它们添加到 ArrayList 中,然后在 recyclerView 中,我的 recyclerView 有一个过滤方法和searchView,因此用户应该能够搜索抛出的条形码,并且必须能够在滑动时删除搜索到的项目。

当我打开位于 dialogAlert 中的 recyclerView 并且如果我删除项目时一切正常,但是当我搜索一个项目并将其删除然后关闭时searchView 该项目仍然保留在 recyclerView 中。

我将在此处提供我的适配器代码,以及我在 Activity 中构建和删除项目的代码。

这是来自 Activity 的代码:

@SuppressLint("SetTextI18n")
@TargetApi(Build.VERSION_CODES.KITKAT)
public void alertDeleteSingleItem(final int position){
    final AlertDialog.Builder mBuilder = new AlertDialog.Builder(InventarioActivity.this);

    @SuppressLint("InflateParams") View mView = getLayoutInflater().inflate(R.layout.alert_confirm_delete, null);

    final Button yes = mView.findViewById(R.id.btnSI);
    final Button no = mView.findViewById(R.id.btnNO);
    final TextView text = mView.findViewById(R.id.textView);

    text.setText("ELIMINARE " + itemAdapter.getList().get(position).getCodiceArticolo() + " ?");

    mBuilder.setView(mView);
    final AlertDialog dialog = mBuilder.create();
    Objects.requireNonNull(dialog.getWindow()).setSoftInputMode(WindowManager.LayoutParams.SOFT_INPUT_STATE_VISIBLE);
    dialog.show();


    yes.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            itemAdapter.removeItem(position);
            dialog.dismiss();
        }
    });

    no.setOnClickListener(new View.OnClickListener() {
        @Override
        public void onClick(View view) {
            dialog.dismiss();
        }
    });

}

public void buildVariableRecycler(View view) {
    recyclerView = view.findViewById(R.id.rectclerItems);
    recyclerView.setHasFixedSize(true);
    RecyclerView.LayoutManager mLayoutManager = new LinearLayoutManager(this);
    itemAdapter = new ItemAdapter(itemModel);
    recyclerView.setLayoutManager(mLayoutManager);
    recyclerView.setAdapter(itemAdapter);


    new ItemTouchHelper(new ItemTouchHelper.SimpleCallback(0, ItemTouchHelper.LEFT | ItemTouchHelper.RIGHT) {
        @Override
        public boolean onMove(@NonNull RecyclerView recyclerView, @NonNull RecyclerView.ViewHolder viewHolder, @NonNull RecyclerView.ViewHolder target) {
            return false;
        }

        @Override
        public void onSwiped(@NonNull RecyclerView.ViewHolder viewHolder, int direction) {
            int position = viewHolder.getAdapterPosition();


            if (direction == ItemTouchHelper.RIGHT) {
                alertDeleteSingleItem(position);
            }

            if (direction == ItemTouchHelper.LEFT) {
                alertDeleteSingleItem(position);
            }

        }
    }).attachToRecyclerView(recyclerView);

}

虽然这是我的适配器:

    public class ItemAdapter extends RecyclerView.Adapter<ItemAdapter.ExampleViewHolder>  implements Filterable {


    private ArrayList<ItemModel> variantiConstructors;
    private List<ItemModel> mFilteredList;


    @NonNull
    @Override
    public ItemAdapter.ExampleViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        View v = LayoutInflater.from(parent.getContext()).inflate(R.layout.item_recycler,parent,false);
        RecyclerView.LayoutParams lp = new RecyclerView.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
        v.setLayoutParams(lp);
        return new ItemAdapter.ExampleViewHolder(v);
    }

    ItemAdapter(ArrayList<ItemModel> exampleList){
        variantiConstructors = exampleList;
        mFilteredList = variantiConstructors;
    }

    @Override
    public void onBindViewHolder(@NonNull final ItemAdapter.ExampleViewHolder holder, @SuppressLint("RecyclerView") final int position) {
        ItemModel item = variantiConstructors.get(position);

        holder.desc.setText(item.getCodiceArticolo());
        holder.qta.setText(item.getQta());

        holder.qta.addTextChangedListener(new TextWatcher() {
            @Override
            public void beforeTextChanged(CharSequence charSequence, int i, int i1, int i2) {
            }

            @Override
            public void onTextChanged(CharSequence charSequence, int i, int i1, int i2) {
                variantiConstructors.get(position).setQta(holder.qta.getText().toString());
            }

            @Override
            public void afterTextChanged(Editable editable) {
            }
        });


        if(position % 2 == 0 ){
            holder.itemView.setBackgroundColor(Color.parseColor("#5C5C5C"));

        }else if(position % 2 == 1){
            holder.itemView.setBackgroundColor(Color.parseColor("#9E9E9E"));
        }
    }


    @Override
    public Filter getFilter() {
        return new Filter() {
            @Override
            protected FilterResults performFiltering(CharSequence constraint) {
                final FilterResults oReturn = new FilterResults();
                final ArrayList<ItemModel> results = new ArrayList<>();
                if (mFilteredList == null)
                    mFilteredList = new ArrayList<>(variantiConstructors);
                if (constraint != null && constraint.length() > 0) {
                    if (mFilteredList != null && mFilteredList.size() > 0) {
                        for (final ItemModel cd : mFilteredList) {
                            if (cd.getCodiceArticolo().toLowerCase()
                                    .contains(constraint.toString().toLowerCase()))
                                results.add(cd);
                        }
                    }
                    oReturn.values = results;
                    oReturn.count = results.size(); //newly Aded by ZA
                } else {
                    oReturn.values = mFilteredList;
                    oReturn.count = mFilteredList.size(); //newly added by ZA
                }
                return oReturn;
            }

            @SuppressWarnings("unchecked")
            @Override
            protected void publishResults(final CharSequence constraint,
                                          FilterResults results) {
                variantiConstructors = new ArrayList<>((ArrayList<ItemModel>) results.values);
                notifyDataSetChanged();
            }
        };
    }

    @Override
    public int getItemCount() {
        return variantiConstructors.size();
    }

    public class ExampleViewHolder extends RecyclerView.ViewHolder {

        public TextView desc;
        public EditText qta;

        ExampleViewHolder(View itemView) {
            super(itemView);

            desc = itemView.findViewById(R.id.Desc);
            qta = itemView.findViewById(R.id.Qta);
        }
    }


    public ArrayList<ItemModel> getList(){
        return variantiConstructors;
    }


    public void removeItem(int position){

        variantiConstructors.remove(position);
        notifyDataSetChanged();
    }

}

在进行了一些测试后,当我搜索某个项目时,它在滑动时得到了位置 0,所以这就是问题所在,但我如何才能滑动到项目的正确位置?

最佳答案

检查getFilter() 方法中的代码。您可以很容易地看出发生这种情况是因为过滤器将项目列表保存在临时列表中。在过滤过程中,主列表被关闭。

当您从过滤列表中删除项目时,您是从临时列表中删除,而不是从主列表中删除。知道这一点后,您也许也可以通过过滤列表以某种方式实现删除,但我不会留下深刻印象,因为 getFilter()SearchView 并不适用于这个具体案例。

原因可能是 Delete 比当前 UI 更像是一个后端相关操作,而您的 UI 以上是一个库存应用。

因此,通过更多控制来实现您真正想要的东西的最佳方法是不使用 getFilter()SearchView。只需实现您自己的自定义搜索 View ,并使用相同的列表进行过滤并将 Delete 连接到您的后端。我已经为类似的库存应用程序这样做了,我发现它更方便。

关于android - 在 SearchView [Inventory App] 中搜索项目时无法滑动删除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52370536/

相关文章:

android - 回收站 View 不刷新

android - 回收者 View |具有共享转换的 OnItemClickListener

android - 带有 "select option"的微调器,但它应该显示为空白

android - Lollipop 中的软导航栏覆盖应用程序

java - 在 Android 中以字符串作为参数的 Switch 语句

iphone - Iphone 移动框架的建议?

Android如何获得用户滚动到项目的recyclerview的当前位置

java - 安卓 Pjsip : Audio Conference Call

android - 如何从 DialogFragment 上的按钮刷新 RecyclerView

android - Eclipse 的 Android SDK 文件夹结构中的 my\sdk\extras\android\m2repository\folder 在哪里?