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;
- }
- }
资源文件见附件源代码。