先参考此处,
实现带图标的ListView Item,在此基础上,即ListItem 的布局文件上添加 CheckBox 即可
<CheckBox android:layout_y="16dip"
android:id="@+id/chkTodo" android:layout_width="40dip"
android:layout_height="40dip" android:layout_x="8dip"
/>
同时适当的调整一下其他组件的位置,就可以了
在程序运行过程中会发现,整个 ListView 无法响应 onItemClick,onItemLongClick 或是 onCreateContextMenu 事件,原因在于,CheckBox 是拥有焦点的,它的优先级比 ListItem 的焦点优先级更高
所以解决方法就是,让CheckBox 不能获得焦点,在以上代码中添加属性
android:focusable="false"
添加后问题就解决了。
随后,我们需要实现 CheckBox 的状态变化,在前文的 Holder 类中添加 CheckBox,随后在 adapter 内将其 OnCheckedChange 事件绑定
holder.chkTodo.setOnCheckedChangeListener( new OnCheckedChangeListener(){
@Override
public void onCheckedChanged(CompoundButton buttonView,
boolean isChecked) {
item.setChecked(isChecked);
}});
当前 item 所属的类中,需要添加一个成员,即 boolean checked;
到此,已经成功的在 ListView 中添加了一个 CheckBox
<CheckBox android:layout_y="16dip"
android:id="@+id/chkTodo" android:layout_width="40dip"
android:layout_height="40dip" android:layout_x="8dip"
/>
同时适当的调整一下其他组件的位置,就可以了
在程序运行过程中会发现,整个 ListView 无法响应 onItemClick,onItemLongClick 或是 onCreateContextMenu 事件,原因在于,CheckBox 是拥有焦点的,它的优先级比 ListItem 的焦点优先级更高
所以解决方法就是,让CheckBox 不能获得焦点,在以上代码中添加属性
android:focusable="false"
添加后问题就解决了。
随后,我们需要实现 CheckBox 的状态变化,在前文的 Holder 类中添加 CheckBox,随后在 adapter 内将其 OnCheckedChange 事件绑定
holder.chkTodo.setOnCheckedChangeListener( new OnCheckedChangeListener(){
@Override
public void onCheckedChanged(CompoundButton buttonView,
boolean isChecked) {
item.setChecked(isChecked);
}});
当前 item 所属的类中,需要添加一个成员,即 boolean checked;
到此,已经成功的在 ListView 中添加了一个 CheckBox