今天在实现ListView点击事件的时候,发现点击之后没有效果,查了下,发现是Item布局里面的CheckBox控件截取了焦点,只需要把CheckBox中的focusable属性设置为false即可
android:focusable="false"
由于系统自带的图标满足不了我的需求,然后又重新定制了属于自己的图标,过程如下:
1、在Drawable下面新建文件,比如checkbox_for_addpending_0.xml
<?xml version="1.0" encoding="UTF-8"?>
<selector xmlns:android="http://schemas.android.com/apk/res/android">
<!-- 点击之后的图标 -->
<item
android:state_checked="true"
android:drawable="@mipmap/priority_no"
/>
<!-- 点击之前的图标 -->
<item
android:state_checked="false"
android:drawable="@mipmap/priority_no_normal"
/>
</selector>
2、在布局文件中直接设置button属性指向这个文件即可
第一种写法:
<CheckBox
android:id="@+id/cb_is_finish_in_lv"
android:focusable="false"
android:layout_width="50dp"
android:layout_height="50dp"
android:button="@drawable/checkbox_for_addpending_0"
/>
如果按照上面的写法,你设置的图标不会再CheckBox的正中间显示,会垂直居中,而不会水平居中,并且当你点击的CheckBox控件的时候,会有灰色背景显示,很难看,按照下面的这种写法就可以解决上面的问题:
第二种写法:
<CheckBox
android:id="@+id/cb_is_finish_in_lv"
android:focusable="false"
android:layout_width="50dp"
android:layout_height="50dp"
android:button="@null"
android:drawableLeft="@drawable/checkbox_for_addpending_0"
android:drawablePadding="10dip"
android:paddingBottom="10dip"
android:paddingLeft="10dip"
android:paddingTop="10dip"
android:background="#FFFFFF"
/>
按照上面写的话也有一定的弊端,比如我想更换CheckBox图片按钮的时候,就会在左侧加上你更新的图片,会很丑陋,这个时候可以使用第一种写法,然后把背景设置的和父布局一致,让CheckBox向右移动下,也可以实现第二种写法的效果。
特此记录。
本文介绍了解决ListView点击事件无效的问题,通过调整CheckBox的focusable属性,并提供了自定义CheckBox图标的两种方法,解决了图标居中及灰色背景的问题。
1188

被折叠的 条评论
为什么被折叠?



