</pre><pre code_snippet_id="1651469" snippet_file_name="blog_20160418_2_235831" name="code" class="html"><span style="font-family: Arial, Helvetica, sans-serif; background-color: rgb(255, 255, 255);"> 实现思路:由于列表类都是需要重复使用Item布局,所以这里不要监听CheckBox的CheckChange事件,不然问题会变得很复杂。只需要监听列表的单击事件,把点击事件</span>
绕过CheckBox传递到Item,步骤1、2的设置就是起到这种效果。CheckBox只是起到显示的作用,它的Check改变监听事件这里不会用到。接着通过监听Item的单击事件设置CheckBox是否选中,用setChecked
1、确保Item的布局有添加这个属性
android:descendantFocusability="blocksDescendants"
2、确保CheckBox添加这个属性
android:clickable="false"
3、处理Item的单击事件
(1)RecyclerView处理方式
class ViewHolder extends RecyclerView.ViewHolder implements View.OnClickListener { CheckBox cbTab; View view; public ViewHolder(View itemView, int viewType) { super(itemView); this.view = itemView; cbTab = (CheckBox) itemView.findViewById(R.id.cb_tab); view.setOnClickListener(this); } @Override public void onClick(View view) { int position=getAdapterPosition(); if (mTagList.get(position).isChecked()) { mTagList.get(position).setChecked(false); cbTab.setChecked(false); } else { mTagList.get(position).setChecked(true); cbTab.setChecked(true); } } }
(2)ListView或GridView的处理方式
gvTag.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
CheckBox cbTab= (CheckBox) view.findViewById(R.id.cb_tab);
if (mTagList.get(i).isChecked()) {
mTagList.get(i).setChecked(false);
cbTab.setChecked(false);
} else {
mTagList.get(i).setChecked(true);
cbTab.setChecked(true);
}
}
});