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();
                }
            });
    问题完美解决。

  • 相关阅读:
    垃圾回收的整个过程
    实验:老年代空闲空间放不下minorgc晋升的对象发生fullgc
    实验: survivor放不下的对象进入老年代
    实验: 动态对象年龄判定
    永久代、栈内存大小怎么设置
    如何设置高并发系统的jvm堆内存大小
    Bin、App_Data等文件夹详述(转自http://blog.csdn.net/zzjiadw/article/details/6801506)
    谈谈并行、并发或多线程
    SQL---存储过程---存储过程编写案例
    SQL---存储过程---sp_addextendedproperty表字段加描述
  • 原文地址:https://www.cnblogs.com/yjbjingcha/p/7189678.html
Copyright © 2011-2022 走看看