ListView 自身提供了 CheckBox 只需要添加一行代码
getListView().setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
但是这种实现想要自己控制操作起来局限很多。所以我选择了自己添加CheckBox的方式。可以支持列表项的全选,删除,并保持数据的对应关系不会乱。
列表中的CheckBox选中状态与一个Map进行绑定,利用 adapter.notifyDataSetChanged();来更新界面。
效果如下:
下面直接看代码把。
main.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:background="#C9F1FF">
<ListView
android:id="@id/android:list"
android:layout_height="wrap_content"
android:layout_width="fill_parent"
android:fadingEdge="none"
android:cacheColorHint="#00000000"/>
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="40.0dip"
android:layout_alignParentBottom="true">
<CheckBox android:id="@+id/all_check_btn"
android:layout_width="40.0dip"
android:background="@drawable/bottom_back_bg"
android:layout_height="40.0dip"
android:layout_alignParentLeft="true"/>
</RelativeLayout>
</RelativeLayout>
item.xml
<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent" android:layout_height="wrap_content"
android:layout_marginRight="3.0dip" android:layout_weight="1.0"
android:orientation="horizontal" android:descendantFocusability="blocksDescendants">
<CheckBox android:id="@+id/isCheakBox" android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_alignParentLeft="true" />
<!-- 日报图片 -->
<ImageView android:id="@+id/dailyPic" android:contentDescription="dailyPic"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_marginTop="3.0dip" android:src="@drawable/reports"
android:layout_toRightOf="@id/isCheakBox" android:layout_centerVertical="true"/>
<!--附件名称 -->
<TextView
android:id="@+id/dailyName"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_toRightOf="@id/dailyPic"
android:text="日报名称" android:layout_centerVertical="true"
android:textColor="#000000"
android:textSize="12.0sp" />
<ImageButton android:id="@+id/deleteAttachment"
android:layout_width="wrap_content" android:layout_height="wrap_content"
android:layout_marginTop="3.0dip" android:background="@drawable/delete"
android:layout_centerVertical="true" android:focusable="false"
android:layout_alignParentRight="true" android:layout_marginRight="20dp"/>
<!--附件名称 -->
</RelativeLayout>
Activity代码
public class ListViewCheckBoxActivity extends ListActivity {
private static final String TAG = "ListViewCheckBoxActivity";
private List<Item> itemList;
private DraftDailyAdapter adapter;
private Map<Integer, Boolean> isCheckedMap;
private CheckBox allCheckBox;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
allCheckBox = (CheckBox)findViewById(R.id.all_check_btn);
itemList = new ArrayList<Item>();
isCheckedMap = new HashMap<Integer, Boolean>();
//初始化数据
for(int i=0;i<8;i++){
Item item = new Item();
item.id=i;
item.name = "第"+i+"篇日报";
itemList.add(item);
isCheckedMap.put(i,false);
}
adapter = new DraftDailyAdapter(this,itemList);
setListAdapter(adapter);
allCheckBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener(){
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
Set<Integer> set = isCheckedMap.keySet();
Iterator<Integer> iterator = set.iterator();
if(isChecked){
while(iterator.hasNext()){
Integer keyId = iterator.next();
isCheckedMap.put(keyId,true);
}
}else{
while(iterator.hasNext()){
Integer keyId = iterator.next();
isCheckedMap.put(keyId,false);
}
}
adapter.notifyDataSetChanged();
}
});
}
class DraftDailyAdapter extends BaseAdapter {
public List<Item> list;
private Context context;
LayoutInflater inflater;
public DraftDailyAdapter(Context context, List<Item> list) {
super();
this.list = list;
this.context = context;
inflater = LayoutInflater.from(this.context);
}
@Override
public int getCount() {
return list == null ? 0 : list.size();
}
@Override
public Object getItem(int location) {
return list.get(location);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder holder = null;
Item item = list.get(position);
//Item的位置
final int listPosition = position;
//这个记录item的id用于操作isCheckedMap来更新CheckBox的状态
final int id = item.id;
if(convertView == null){
holder = new ViewHolder();
convertView = inflater.inflate(R.layout.item, null);
holder.tvName = (TextView)convertView.findViewById(R.id.dailyName);
holder.deleteButton = (ImageButton)convertView.findViewById(R.id.deleteAttachment);
holder.cBox = (CheckBox)convertView.findViewById(R.id.isCheakBox);
convertView.setTag(holder);
}else{
holder = (ViewHolder) convertView.getTag();
}
Log.d(TAG, "id="+id);
holder.cBox.setChecked(isCheckedMap.get(id));
holder.tvName.setText(item.name);
holder.deleteButton.setOnClickListener(new OnClickListener() {
@Override
public void onClick(View paramView) {
//Log.d(TAG, "deletePosition="+listPosition+"");
//删除list中的数据
list.remove(listPosition);
//删除Map中对应选中状态数据
isCheckedMap.remove(id);
//通知列表数据修改
adapter.notifyDataSetChanged();
}
});
holder.cBox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener(){
@Override
public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
if(isChecked){
isCheckedMap.put(id,true);
}else{
isCheckedMap.put(id,false);
}
}
});
return convertView;
}
public final class ViewHolder {
public TextView tvName;
public ImageButton deleteButton;
public CheckBox cBox;
}
}
class Item {
private Integer id;
private String name;
}
}
资源文件见附件源代码。
- 大小: 76.7 KB
分享到:
相关推荐
Android ListView 带CheckBox框,点击选择,反选,全选,全不选等功能,并且显示选择的数量。
安卓Android源码——ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能.rar
安卓Android源码——ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能.zip
实现 全选 、 全不选 、 删除等功能项目安卓应用源码Android应用源码之ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能项目安卓应用源码 1.适合学生毕业设计研究参考 2.适合个人学习研究参考 3....
ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能
android ListView中的checkBox全选和反选Demo
安卓开发-ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能
实现 全选 、 全不选 、 删除等功能.zip项目安卓应用源码下载ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能.zip项目安卓应用源码下载 1.适合学生毕业设计研究参考 2.适合个人学习研究参考 3.适合...
实现 全选 、 全不选 、 删除等功能.zip安卓程序源码资源下载ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能.zip安卓程序源码资源下载 1.学生做毕业设计用 2.程序员学习研究用 3.小公司换皮做新...
Android应用源码之ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能_全选
Android应用源码之ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能.zip
listview带可全选全不选删除checkbox,不会错位
在ListView中添加CheckBox,实现多选条目
Android高级应用源码-ListView+CheckBox UI 完美版。实现 全选 、 全不选 、 删除等功能.zip
Android开发——listview中嵌套checkBox复选框实现单选、全选删除列表内容 详情可以看我的博客http://blog.csdn.net/jxnk25/article/details/50358231
Android 长按Listview显示CheckBox,实现批量删除,具体功能请参考: http://blog.csdn.net/ddxxll2008/article/details/49125759
带CheckBox的listView 支持多选,全选,反选, 的功能,网上有好多遇见的这种需求做起来有bug,在这里都完美解决了
可想而知,要支持批量选择,那CheckBox的使用是不可或缺的,下面,就使用ListView结合CheckBox实现数据的批量选择。 先看下效果图,有图有真相: 先说明接下来要实现的ListView+CheckBox支持的功能: 1. 外部...