这几天正好需要处理关于列表批量删除的问题,因此在网上找了大量的资料,但是始终
没找到什么好的例子。于是针对网上的一个例子进行了修改,最终实现了批量删除操作。故
而在此分享一下,以帮助需要的人。
首先,写个item的xml布局,里面放置一张图片、一个TextView和一个CheckBox。要
注意的是,这里设置了CheckBox没有焦点,这样的话,无法单独点击checkbox,而是在点
击listview的条目后,Checkbox会响应操作。
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="fill_parent" android:layout_height="fill_parent" android:orientation="horizontal" > <ImageView android:id="@+id/item_iv" android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_gravity="center_vertical" android:src="@drawable/ic_launcher"/> <TextView android:id="@+id/item_tv" android:layout_width="0dp" android:layout_height="wrap_content" android:layout_weight="1" android:gravity="center_vertical" /> <CheckBox android:id="@+id/item_cb" android:layout_width="wrap_content" android:layout_height="wrap_content" android:clickable="false" android:focusable="false" android:focusableInTouchMode="false" android:gravity="center_vertical" /> </LinearLayout>
注:下面这三句是实现设置CheckBox没有焦点的。
android:clickable="false" android:focusable="false" android:focusableInTouchMode="false"
下面就写一个Adapter类,依然继承BaseAdapter类。
package com.myandroid.listedittest; import java.util.ArrayList; import java.util.HashMap; import android.content.Context; import android.view.LayoutInflater; import android.view.View; import android.view.ViewGroup; import android.widget.BaseAdapter; import android.widget.CheckBox; import android.widget.ImageView; import android.widget.TextView; public class MyAdapter extends BaseAdapter{ // 填充数据的list private ArrayList<HashMap<String, String>> list; // 上下文 private Context context; // 用来导入布局 private LayoutInflater inflater = null; // 构造器 public MyAdapter(ArrayList<HashMap<String, String>> list, Context context){ this.context = context; this.list = list; inflater = LayoutInflater.from(context); } @Override public int getCount() { // TODO Auto-generated method stub return list.size(); } @Override public Object getItem(int position) { // TODO Auto-generated method stub return list.get(position); } @Override public long getItemId(int position) { // TODO Auto-generated method stub return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder holder = null; if (convertView == null) { // 获得ViewHolder对象 holder = new ViewHolder(); // 导入布局并赋值给convertview convertView = inflater.inflate(R.layout.listviewitem, null); holder.tv = (TextView) convertView.findViewById(R.id.item_tv); holder.cb = (CheckBox) convertView.findViewById(R.id.item_cb); holder.img = (ImageView) convertView.findViewById(R.id.item_iv); // 为view设置标签 convertView.setTag(holder); } else { // 取出holder holder = (ViewHolder) convertView.getTag(); } // 设置list中TextView的显示 holder.tv.setText(list.get(position).get("content").toString()); // 根据flag来设置checkbox的选中状况 holder.cb.setChecked(list.get(position).get("flag").equals("true")); return convertView; } final class ViewHolder{ TextView tv; CheckBox cb; ImageView img; } }
holder.cb.setChecked(list.get(position).get("flag").equals("true")
这句是实现复选框是否被选中的操作,其中“flag”是放在list里的。
在Activity中除了放置一个ListView,TextView(用于记录选中的数目)还放置了四个按钮,分别实现全选,取消,反选和删除。
看下Activity类的代码:
package com.myandroid.listedittest; import java.util.ArrayList; import java.util.HashMap; import java.util.Iterator; import android.app.Activity; import android.os.Bundle; import android.view.View; import android.view.View.OnClickListener; import android.widget.AdapterView; import android.widget.AdapterView.OnItemClickListener; import android.widget.Button; import android.widget.ListView; import android.widget.TextView; import android.widget.Toast; import com.myandroid.listedittest.MyAdapter.ViewHolder; public class MainActivity extends Activity { private ListView lv; private MyAdapter mAdapter; private ArrayList<HashMap<String, String>> list; private Button bt_selectall; private Button bt_cancel; private Button bt_deselectall; private Button bt_confirmdelete; private int checkNum; // 记录选中的条目数量 private TextView tv_show;// 用于显示选中的条目数量 static String str[] = { "data1", "data2", "data3", "data4", "data5", "data6", "7", "data8", "data9", "data10", "data11", "data12", "data13" }; /** Called when the activity is first created. */ @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); /* 实例化各个控件 */ lv = (ListView) findViewById(R.id.lv); bt_selectall = (Button) findViewById(R.id.bt_selectall); bt_cancel = (Button) findViewById(R.id.bt_cancelselectall); bt_deselectall = (Button) findViewById(R.id.bt_deselectall); bt_confirmdelete = (Button) findViewById(R.id.bt_confirmdelete); tv_show = (TextView) findViewById(R.id.tv); list = new ArrayList<HashMap<String, String>>(); // 为Adapter准备数据 initDate(); // 实例化自定义的MyAdapter mAdapter = new MyAdapter(list, this); // 绑定Adapter lv.setAdapter(mAdapter); // 全选按钮的回调接口 bt_selectall.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 遍历list的长度,将MyAdapter中的map值全部设为true for (int i = 0; i < list.size(); i++) { list.get(i).put("flag", "true"); } // 数量设为list的长度 checkNum = list.size(); // 刷新listview和TextView的显示 dataChanged(); } }); // 取消按钮的回调接口 bt_cancel.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 遍历list的长度,将已选的按钮设为未选 for (int i = 0; i < list.size(); i++) { if (list.get(i).get("flag").equals("true")) { list.get(i).put("flag", "false"); checkNum--;// 数量减1 } } // 刷新listview和TextView的显示 dataChanged(); } }); // 反选按钮的回调接口 bt_deselectall.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { // 遍历list的长度,将已选的设为未选,未选的设为已选 for (int i = 0; i < list.size(); i++) { if (list.get(i).get("flag").equals("true")) { list.get(i).put("flag", "false"); checkNum--; } else { list.get(i).put("flag", "true"); checkNum++; } } // 刷新listview和TextView的显示 dataChanged(); } }); // 确认删除的回调接口 bt_confirmdelete.setOnClickListener(new OnClickListener() { @Override public void onClick(View v) { Iterator<HashMap<String, String>> iterator = list.iterator(); while (iterator.hasNext()) { HashMap<String, String> temp = iterator.next(); if (temp.get("flag").equals("true")) { iterator.remove(); } } checkNum = 0; // 通知列表数据修改 dataChanged(); } }); // 绑定listView的监听器 lv.setOnItemClickListener(new OnItemClickListener() { @Override public void onItemClick(AdapterView<?> arg0, View arg1, int arg2, long arg3) { Toast.makeText(MainActivity.this, "当前位置:" + arg2, Toast.LENGTH_SHORT); // 取得ViewHolder对象,这样就省去了通过层层的findViewById去实例化我们需要的cb实例的步骤 ViewHolder holder = (ViewHolder) arg1.getTag(); // 改变CheckBox的状态 holder.cb.toggle(); // 将CheckBox的选中状况记录下来 // 调整选定条目 if (holder.cb.isChecked() == true) { list.get(arg2).put("flag", "true"); checkNum++; } else { list.get(arg2).put("flag", "false"); checkNum--; } // 用TextView显示 tv_show.setText("已选中" + checkNum + "项"); } }); } // 初始化数据 private void initDate() { for (int i = 0; i < str.length; i++) { HashMap<String, String> map = new HashMap<String, String>(); map.put("content", str[i]); map.put("flag", "false"); list.add(map); } } // 刷新listview和TextView的显示 private void dataChanged() { // 通知listView刷新 mAdapter.notifyDataSetChanged(); // TextView显示最新的选中数目 tv_show.setText("已选中" + checkNum + "项"); } }
下面这句话用于初始化checkbox的选中状态。
map.put("flag", "false");
而这句话是用来改变checkbox的状态
list.get(i).put("flag", "false");
而其他几个Button的点击事件,都是通过遍历list的长度来设置“flag”的值,进而通知listview根据已经变化的 adapter刷新,来实现Checkbox的对应选中状态。因为对listview的处理中使用了ViewHolder来优化ListView 的效率.
下面是几张截图:
全选的效果:
删除的只剩三项啦!
好了,写的差不多了!源码里的注释已经很清楚了,如过还不明白的话,可以给我留言。
如果想要源码的话,可以去CSDN下载。
下载地址:http://download.csdn.net/detail/ouyangjiangtao/5170422
注:我在点点网上的原文博客链接:http://oyjt001.diandian.com/post/2013-03-22/40049884545
欢迎访问我的个人博客网站:http://www.cnpath.com
注:本文是在网上其他博客的基础上修改的,原文链接:http://www.eoeandroid.com/forum.php?mod=viewthread&tid=188776