RecycleView中CheckBox全选、反选、单选

原创 2018年04月15日 18:12:20

思路:首先需要一个Map集合用于存储每一个条目的选中状态。选中哪个条目,则把该条目的位置添加进集合,并设置key为true,删除则设置Map集合中对应的位置的key为false。最后提交的时候,遍历map集合,即可得到所有选中的条目。全选是把Map集合中的key全部设置为true即可,而反选则需要遍历Map集合,判断每个key的状态并设置为相反的状态。

先上适配器的代码

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {
    /**

     * checkbox的Hashmap集合,一条数据对应一个checkbox状态

     */
    private final HashMap<Integer, Boolean> map;


    /**
     *数据源
     */
    private final List<String> list;


    public MyAdapter() {
        map = new HashMap<>();
        list = new ArrayList<>();
        for (int i = 0; i < 30; i++) {
            list.add("这是条目" + i);
            //Checkbox初始状态置为false
            map.put(i, false);
        }
    }


    /**
     * 全选,
     */
    public void selectAll() {
        Set<Map.Entry<Integer, Boolean>> entries = map.entrySet();
        boolean shouldall = false;
        for (Map.Entry<Integer, Boolean> entry : entries) {
            Boolean value = entry.getValue();
            if (!value) {
                shouldall = true;
                break;
            }
        }


        for (Map.Entry<Integer, Boolean> entry : entries) {
            entry.setValue(shouldall);
        }
        notifyDataSetChanged();
    }


    /**
     * 反选
     */
    public void neverAll() {
        Set<Map.Entry<Integer, Boolean>> entries = map.entrySet();
        for (Map.Entry<Integer, Boolean> entry : entries) {
            entry.setValue(!entry.getValue());
        }
        notifyDataSetChanged();
    }


    /**
     * 单选
     * @param postion
     */
    public void singleSelect(int postion) {
        Set<Map.Entry<Integer, Boolean>> entries = map.entrySet();
        for (Map.Entry<Integer, Boolean> entry : entries) {
            entry.setValue(false);
        }
        map.put(postion, true);
        notifyDataSetChanged();
    }


    @Override
    public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View inflate = LayoutInflater.from(parent.getContext()).inflate(R.layout.check, parent, false);
        return new MyViewHolder(inflate);
    }


    @Override
    public void onBindViewHolder(final MyViewHolder holder, final int position) {
        holder.txt.setText(list.get(position));
        //从map集合获取状态
        holder.checkBox.setChecked(map.get(position));


        holder.checkBox.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {
                map.put(position, !map.get(position));
                //刷新适配器
                notifyDataSetChanged();
                //单选
                singleSelect(position);
            }
        });
    }


    @Override
    public int getItemCount() {
        return list!=null ? list.size():0;
    }


    static class MyViewHolder extends RecyclerView.ViewHolder {
        View itemView;
        private TextView txt;
        private CheckBox checkBox;


        public MyViewHolder(View itemView) {
            super(itemView);
            this.itemView = itemView;
            txt = (TextView) itemView.findViewById(R.id.txt);
            checkBox = (CheckBox) itemView.findViewById(R.id.cbox);
        }
    }
}


Activity的代码:

public class MainActivity extends AppCompatActivity {


    private MyAdapter myAdapter;
    private LinearLayoutManager linearLayoutManager;


    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        //初始化控件
        RecyclerView recyclerView = (RecyclerView) findViewById(R.id.recyclerview);


        //在加载数据之前配置
        linearLayoutManager = new LinearLayoutManager(this);
        recyclerView.setLayoutManager(linearLayoutManager);


        //创建一个适配器
        myAdapter = new MyAdapter();
        recyclerView.setAdapter(myAdapter);
    }


    /**
     * 全选
     * @param view
     */
    public void btnAll(View view) {
        myAdapter.selectAll();
    }


    /**
     * 单选
     * @param view
     */
    public void btnner(View view) {
        myAdapter.neverAll();
    }
}

卸载3721网络实名的方法

    把3721称呼为病毒实不为过,这个家伙不仅非常讨厌,而且几乎无法卸载!本人毕竟对软件开发比较熟悉,特别看不惯一些软件强硬潜入自己机器的问题,终于软磨硬泡把3721搞定了,以下是卸载方法:   ...
  • killererer
  • killererer
  • 2001-08-24 15:11:00
  • 2138

RecycleView(CheckBox全选,反选,单选)

MainActiivity package com.bwie.day06; import android.support.v7.app.AppCompatActivity; import ...
  • Udsess
  • Udsess
  • 2017-09-05 20:50:03
  • 567

RecyclerView全选反选

//在主布局里         android:id="@+idtton2"         android:layout_width="0dp"         android:layout_we...
  • qq_35889484
  • qq_35889484
  • 2016-11-23 21:30:00
  • 1438

使用RecyclerView展示checkBox全选反选

使用时一定要在builde.gradle文件里添加依赖: compile 'com.android.support:recyclerview-v7:22.0.+'==================...
  • PowerSen
  • PowerSen
  • 2017-09-16 10:25:57
  • 434

关于Recyclerview 实现多选,单选,全选,反选,批量删除的功能的实现

效果图如下: Recyclerview 实现多选,单选,全选,反选,批量删除的步骤1.在Recyclerview布局中添加上底部的全选和反选按钮,删除按钮,和计算数量等控件 2.这里选中的控件...
  • guohaosir
  • guohaosir
  • 2017-05-17 16:18:36
  • 8351

checkbox全选、反选、单选(前端)

  • 2018年01月26日 16:22
  • 25KB
  • 下载

Vue.js实现checkbox的全选和反选

小颖之前写的代码存在一个bug,就是当你选择全选的时候去掉后面的一个选项,再点全选结果就是反的了.很感谢博客园的朋友帮我改了这个问题嘻嘻,下面一起来看看具体是怎么实现的吧. 1.html ...
  • qiupu4667
  • qiupu4667
  • 2017-04-18 20:05:27
  • 1052

ExtJs 中自定义checkbox ,单选,全选,反选

pageEncoding="UTF-8"%> Welcome to come here function showUrl(value) {     retu...
  • zhifeiyu2008
  • zhifeiyu2008
  • 2012-12-16 22:36:33
  • 1742

JS实现单选,多选,全选,反选,全不选

//单选 function deleteFee(id){ if(confirm("确定删除吗?")){ location.href="dele...
  • u014601106
  • u014601106
  • 2014-07-13 15:23:16
  • 1271

android完美解决ListView中CheckBox的全选、反选、批量删除的问题

效果图 前几天看到有朋友发帖问关于ListView的多选、反选、取消等问题,我自己想了一下,最好的解决方法应该是生成一个list来维系checkbox组的选择状态。利用listview的getChi...
  • selfreeyuan
  • selfreeyuan
  • 2016-02-24 12:04:16
  • 6321
收藏助手
不良信息举报
您举报文章:RecycleView中CheckBox全选、反选、单选
举报原因:
原因补充:

(最多只允许输入30个字)