zoukankan      html  css  js  c++  java
  • CheckBox:屏蔽setChecked方法对OnCheckedChangeListener的影响

    对于CheckBox的OnCheckedChangeListener,有两种情况下会被触发:
    (1)用户点击了一下CheckBox;
    (2)代码中调用了setChecked(boolean checked)方法,而且參数checked与CheckBox原始的选中状态不一致。
    有时候,须要仅仅监听(1)的事件。而忽略(2)的事件。

    其实,这样的需求十分常见。比如,页面中有一个列表,列表中有多个checkBox供用户选择,同一时候页面有一个全选功能的checkBox。

    (a)当用户将全选checkBox选上时。须要把列表中全部的checkBox都选上;

    (b)当用户将全选checkBox取消选择时,须要把列表中全部的checkBox都选取消选择。

    (c)假设当前是全选状态,仅仅要用户随意取消选择了列表中一个checkBox,则将全选button取消选择。

    这时候问题就出现了:运行(c)时,须要对全选的checkBox.setChecked(false),而这会调用全选button的OnCheckedChangeListener。因为(b)的原因。列表中全部的checkBox都会被取消选择,这不是期望的结果。

    为了解决问题,有两种方法:

    方案(1):

    程序中定义一个全局变量boolean ignoreChange,然后,调用setChecked方法时改变ignoreChange的值:

    ignoreChange = true;
    selectAllCB.setChecked(true);
    ignoreChange = false;
    

    然后在selectAllCB的OnCheckedChangeListener中对ignoreChange进行推断:

    selectAllCB.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
                @Override
                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
                    if (!ignoreChange) {
                        //do something
                    }
                }
            });
    方案(2):

    对于checkBox不注冊OnCheckedChangeListener,而直接注冊OnClickListener,

    checkBox.setOnClickListener(new View.OnClickListener() {
                @Override
                public void onClick(View v) {
                    boolean checked = ((CheckBox) v).isChecked();
                    Toast.makeText(CheckBoxTest.this, "isChecked?" + checked, Toast.LENGTH_SHORT).show();
                }
            });
    问题完美解决。

  • 相关阅读:
    【IoT平台北向API调用】使用Postman调用Https接口
    【LiteOS】LiteOS移植常见问题
    搞IT产品,请谨记Mobile First
    Modelarts与无感识别技术生态总结(浅出版)
    高性能Web动画和渲染原理系列(1)——CSS动画和JS动画
    使用蓝图构建Flask项目目录
    一统江湖的大前端(8)- velocity.js 运动的姿势(上)
    只需两步手把手教你玩转图像识别
    秉承初心,砥砺奋进!华为云助力锦江都城开启云服务时代
    HBase 索引创建
  • 原文地址:https://www.cnblogs.com/yjbjingcha/p/7189678.html
Copyright © 2011-2022 走看看