Android实现带有CheckBox的ListView


[html] view plain copy
  1. packagecom.zwq.umeng;
  2. importjava.util.ArrayList;
  3. importjava.util.HashMap;
  4. importjava.util.List;
  5. importjava.util.Map;
  6. importandroid.content.Context;
  7. importandroid.view.LayoutInflater;
  8. importandroid.view.View;
  9. importandroid.view.ViewGroup;
  10. importandroid.widget.BaseAdapter;
  11. importandroid.widget.CheckBox;
  12. importandroid.widget.ImageView;
  13. importandroid.widget.TextView;
  14. publicclassMyAdapterextendsBaseAdapter{
  15. privateLayoutInflatermInflater;
  16. privateList<Map<String,Object>>mData;
  17. publicstaticMap<Integer,Boolean>isSelected;
  18. publicMyAdapter(Contextcontext){
  19. mInflater=LayoutInflater.from(context);
  20. init();
  21. }
  22. //初始化
  23. privatevoidinit(){
  24. mData=newArrayList<Map<String,Object>>();
  25. for(inti=0;i<5;i++){
  26. Map<String,Object>map=newHashMap<String,Object>();
  27. map.put("img",R.drawable.icon);
  28. map.put("title","第"+(i+1)+"行的标题");
  29. mData.add(map);
  30. }
  31. //这儿定义isSelected这个map是记录每个listitem的状态,初始状态全部为false。
  32. isSelected=newHashMap<Integer,Boolean>();
  33. for(inti=0;i<mData.size();i++){
  34. isSelected.put(i,false);
  35. }
  36. }
  37. @Override
  38. publicintgetCount(){
  39. returnmData.size();
  40. }
  41. @Override
  42. publicObjectgetItem(intposition){
  43. returnnull;
  44. }
  45. @Override
  46. publiclonggetItemId(intposition){
  47. return0;
  48. }
  49. @Override
  50. publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
  51. ViewHolderholder=null;
  52. //convertView为null的时候初始化convertView。
  53. if(convertView==null){
  54. holder=newViewHolder();
  55. convertView=mInflater.inflate(R.layout.vlist,null);
  56. holder.img=(ImageView)convertView.findViewById(R.id.img);
  57. holder.title=(TextView)convertView.findViewById(R.id.title);
  58. holder.cBox=(CheckBox)convertView.findViewById(R.id.cb);
  59. convertView.setTag(holder);
  60. }else{
  61. holder=(ViewHolder)convertView.getTag();
  62. }
  63. holder.img.setBackgroundResource((Integer)mData.get(position).get(
  64. "img"));
  65. holder.title.setText(mData.get(position).get("title").toString());
  66. holder.cBox.setChecked(isSelected.get(position));
  67. returnconvertView;
  68. }
  69. publicfinalclassViewHolder{
  70. publicImageViewimg;
  71. publicTextViewtitle;
  72. publicCheckBoxcBox;
  73. }
  74. }


项目要用到一个listview,要求是可以显示图片,后面还有有复选框。

先新建一个MyAdapter类,继承自BaseAdapter。在MyAdapter中实现对数据的绑定,我这儿由于是测试的,所以把数据写死了。

Java代码

上面类中要注意getView()方法中对数据的处理。

接下要新建一个list.xml文件,这个就是布局image、textview、checkbox。

[html] view plain copy
  1. <TextView
  2. android:id="@+id/title"
  3. android:textSize="18dip"
  4. android:layout_weight="1"
  5. android:layout_width="wrap_content"
  6. android:layout_height="wrap_content"/>
  7. <CheckBox
  8. android:id="@+id/cb"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:focusable="false"
  12. android:focusableInTouchMode="false"
  13. android:clickable="false"
  14. android:checkMark="?android:attr/listChoiceIndicatorMultiple"/>
  15. </LinearLayout>

android:layout_weight="1"这一句可以使中间的textview权重增大,从而后面的checkbok可以居右显示。

[html] view plain copy
  1. android:focusable="false"
  2. android:focusableInTouchMode="false"
  3. android:clickable="false"

这三句很重要,如果不加就会出现错误。

由于checkbox的点击事件优先级比listview的高,所以要在checkbox中添加android:focusable="false",使得checkbox初始的时候没有获取焦点。

接下来在main.xml中添加Listview组件

Java代码

[html] view plain copy
  1. <ListView
  2. android:id="@+id/lv"
  3. android:layout_width="fill_parent"
  4. android:layout_height="wrap_content"/>

接下来就是在activity中调用:

Java代码

[html] view plain copy
  1. list=(ListView)findViewById(R.id.lv);
  2. MyAdapteradapter=newMyAdapter(this);
  3. list.setAdapter(adapter);
  4. list.setItemsCanFocus(false);
  5. list.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
  6. list.setOnItemClickListener(newOnItemClickListener(){
  7. @Override
  8. publicvoidonItemClick(AdapterView<?>parent,Viewview,
  9. intposition,longid){
  10. ViewHoldervHollder=(ViewHolder)view.getTag();
  11. //在每次获取点击的item时将对于的checkbox状态改变,同时修改map的值。
  12. vHollder.cBox.toggle();
  13. MyAdapter.isSelected.put(position,vHollder.cBox.isChecked());
  14. }
  15. });

最新看一下效果图:

带有CheckBox的ListView,实现删除和选中功能_第1张图片

要获取哪些项目被选择了,可以这样测试:

Java代码

[html] view plain copy
  1. OnClickListenerbPop=newOnClickListener(){
  2. @Override
  3. publicvoidonClick(Viewv){
  4. for(inti=0;i<list.getCount();i++){
  5. if(MyAdapter.isSelected.get(i)){
  6. ViewHoldervHollder=(ViewHolder)list.getChildAt(i).getTag();
  7. Log.i(TAG,"--onClick--"+vHollder.title.getText());
  8. }
  9. }
  10. }
  11. };

总结

1、数据可以在Activity中获取,在初始化Adapter的时候当做参数传递过去,这样就可以是list编程动态的。

2、对MyAdapter中getview的理解不够,尤其是convertView.setTag(holder),



ListView结合Checkbox实现删除功能

带有CheckBox的ListView,实现删除和选中功能_第2张图片

效果图


实现要点:

1Listview是一个动态的组件,实现监听Listview里的动作需要用到BaseAdapter类

2 数据存储结构ArrayList<HashMap<String, String>> list, 第一个string存放flag,用以判断是否选中;第二个string存放msg

3 一旦数据有变,必须使用mAdapter.notifyDataSetChanged(); 否则view无法得知数据变化,从而会报错


一共由以下文件组成(仅核心部分,参考慎用)

JAVA

[java] view plain copy
  1. ButtonbtnDelete;
  2. ListViewlv;
  3. ContextmContext;
  4. MyListAdapteradapter;
  5. privateArrayList<HashMap<String,String>>list;
  6. @Override
  7. publicvoidonCreate(BundlesavedInstanceState){
  8. super.onCreate(savedInstanceState);
  9. requestWindowFeature(Window.FEATURE_NO_TITLE);
  10. setContentView(R.layout.activity_carton_no_main);
  11. SysApplication.getInstance().addActivity(this);
  12. btnDelete=(Button)findViewById(R.id.ctn_no_scan_delete_btn);
  13. lv=(ListView)findViewById(R.id.carton_no_list);
  14. list=newArrayList<HashMap<String,String>>();
  15. mAdapter=newMyListAdapter(list,this);
  16. lv.setAdapter(mAdapter);
  17. //insertsomething
  18. HashMap<String,String>map=newHashMap<String,String>();
  19. map.put("content",'test');
  20. map.put("flag","false");
  21. list.add(map);
  22. btnDelete.setOnClickListener(newView.OnClickListener(){
  23. @Override
  24. publicvoidonClick(Viewv){
  25. Iterator<HashMap<String,String>>iterator=list.iterator();
  26. while(iterator.hasNext()){
  27. HashMap<String,String>temp=iterator.next();
  28. if(temp.get("flag").equals("true")){
  29. iterator.remove();
  30. }
  31. }
  32. checkNum=0;
  33. //ifyouhavechangedlist,pleaseexcutemAdapter.notifyDataSetChanged();
  34. dataChanged();
  35. }
  36. });
  37. lv.setOnItemClickListener(newOnItemClickListener(){
  38. @Override
  39. publicvoidonItemClick(AdapterView<?>arg0,Viewarg1,intarg2,
  40. longarg3){
  41. ViewHolderholder=(ViewHolder)arg1.getTag();
  42. holder.cb.toggle();
  43. //storecheckbox'sstatus
  44. if(holder.cb.isChecked()==true){
  45. list.get(arg2).put("flag","true");
  46. checkNum++;
  47. }else{
  48. list.get(arg2).put("flag","false");
  49. checkNum--;
  50. }
  51. }
  52. });
  53. }
  54. publicclassMyListAdapterextendsBaseAdapter{
  55. privateArrayList<HashMap<String,String>>list;
  56. privateContextcontext;
  57. privateLayoutInflaterinflater=null;
  58. publicMyListAdapter(ArrayList<HashMap<String,String>>list,Contextcontext){
  59. this.context=context;
  60. this.list=list;
  61. inflater=LayoutInflater.from(context);
  62. }
  63. @Override
  64. publicintgetCount(){
  65. returnlist.size();
  66. }
  67. @Override
  68. publicObjectgetItem(intposition){
  69. returnlist.get(position);
  70. }
  71. @Override
  72. publiclonggetItemId(intposition){
  73. returnposition;
  74. }
  75. @Override
  76. publicViewgetView(intposition,ViewconvertView,ViewGroupparent){
  77. ViewHolderholder=null;
  78. if(convertView==null){
  79. holder=newViewHolder();
  80. convertView=inflater.inflate(R.layout.activity_carton_no_list,null);
  81. holder.tv=(TextView)convertView.findViewById(R.id.carton_no_list_name);
  82. holder.cb=(CheckBox)convertView.findViewById(R.id.carton_no_list_checked);
  83. convertView.setTag(holder);
  84. }else{
  85. holder=(ViewHolder)convertView.getTag();
  86. }
  87. //initview
  88. holder.tv.setText(list.get(position).get("content").toString());
  89. holder.cb.setChecked(list.get(position).get("flag").equals("true"));
  90. returnconvertView;
  91. }
  92. finalclassViewHolder{
  93. TextViewtv;
  94. CheckBoxcb;
  95. }
  96. }
  97. privatevoiddataChanged(){
  98. mAdapter.notifyDataSetChanged();
  99. }


XML

1/2

[html] view plain copy
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:tools="http://schemas.android.com/tools"
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. android:background="@color/white"
  7. android:orientation="vertical">
  8. <LinearLayout
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:orientation="horizontal"
  12. android:descendantFocusability="blocksDescendants">
  13. <CheckBox
  14. android:id="@+id/carton_no_list_checked"
  15. android:layout_width="wrap_content"
  16. android:layout_height="wrap_content"
  17. android:clickable="false"
  18. android:focusable="false"
  19. android:focusableInTouchMode="false"
  20. android:gravity="center_vertical"/>
  21. <TextView
  22. android:id="@+id/carton_no_list_name"
  23. android:layout_width="fill_parent"
  24. android:layout_height="wrap_content"
  25. android:layout_gravity="center"
  26. android:layout_marginLeft="10dp"
  27. android:layout_weight="1"
  28. android:text="Name"
  29. android:textColor="@color/viewfinder_mask"
  30. android:textSize="20dp"/>
  31. </LinearLayout>
  32. </LinearLayout>

2/2

[html] view plain copy
  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:tools="http://schemas.android.com/tools"
  3. xmlns:android="http://schemas.android.com/apk/res/android"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent"
  6. android:background="@color/white"
  7. android:orientation="vertical">
  8. <LinearLayout
  9. android:orientation="vertical"
  10. android:layout_width="match_parent"
  11. android:layout_height="match_parent"
  12. android:layout_weight="0.1">
  13. <ListView
  14. android:id="@+id/carton_no_list"
  15. android:layout_width="match_parent"
  16. android:layout_height="fill_parent"/>
  17. </LinearLayout>
  18. <LinearLayout
  19. android:id="@+id/LinearLayout1"
  20. android:layout_width="match_parent"
  21. android:layout_height="match_parent"
  22. android:layout_weight="0.7"
  23. android:orientation="horizontal">
  24. <Button
  25. android:id="@+id/ctn_no_scan_delete_btn"
  26. android:layout_width="match_parent"
  27. android:layout_height="50dp"
  28. android:layout_weight="0.1"
  29. android:text="Delete"/>
  30. </LinearLayout>
  31. </LinearLayout>


同理,实现radiobox,也是一样的道理。

更多相关文章

  1. Android在代码中设置控件的drawableLeft,drawableRight,drawableTo
  2. Android中SQLite数据库中query或者rawquery查询失败闪退问题
  3. Android随笔--短小精悍的代码段(持续更新)
  4. 随想录(一个android原生app的代码赏析)
  5. Android中SQLite数据库操作(2)——使用SQLiteDatabase提供的方法操
  6. Android使用HttpURLConnection请求网络返回JSON数据并解析
  7. Loader和Fragment使用示例代码
  8. 【Android】数据库处理
  9. Eclipse中查看Android源代码

随机推荐

  1. android studio使用感受
  2. 【android】uses-permission和permission
  3. Android-0 Android studio编译报错相关
  4. android自定义对话框工具类
  5. Android深入浅出之Binder机制
  6. android状态栏一体化
  7. Android Applications Tutorial 23. HTTP
  8. android 获取信息和安装Apk
  9. android学习——android 常见的错误 和
  10. Android openGL hook