笔者的最近在做一个一个Android项目,在项目中要用到一个listview,要求是可以显示图片,后面还有有复选框。本文将详细介绍“如何实现带图片和checkbox的listview”。

项目要用到一个listview,要求是能够显现图片,后边还有有复选框。

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

Java代码

  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. }

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

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

Java代码

  1. <?xmlversion="1.0"encoding="utf-8"?>
  2. <LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="horizontal"
  4. android:layout_width="fill_parent"
  5. android:layout_height="fill_parent"
  6. >
  7. <ImageView
  8. android:id="@+id/img"
  9. android:layout_width="wrap_content"
  10. android:layout_height="wrap_content"
  11. android:layout_gravity="center_vertical"/>
  12. <TextView
  13. android:id="@+id/title"
  14. android:textSize="18dip"
  15. android:layout_weight="1"
  16. android:layout_width="wrap_content"
  17. android:layout_height="wrap_content"/>
  18. <CheckBox
  19. android:id="@+id/cb"
  20. android:layout_width="wrap_content"
  21. android:layout_height="wrap_content"
  22. android:focusable="false"
  23. android:focusableInTouchMode="false"
  24. android:clickable="false"
  25. android:checkMark="?android:attr/listChoiceIndicatorMultiple"/>
  26. </LinearLayout>

Android:layout_weight="1"这一句能够使中心的textview权重增大,然后后边的checkbok能够居右显现。

  1. android:focusable="false"
  2. android:focusableInTouchMode="false"
  3. android:clickable="false"

这三句很重要,假如不加就会呈现过错。

因为checkbox的点击事情优先级比listview的高,所以要在checkbox中增加android:focusable="false",使得checkbox初始的时分没有获取焦点。

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

Java代码

  1. <ListView
  2. android:id="@+id/lv"
  3. android:layout_width="fill_parent"
  4. android:layout_height="wrap_content"/>

接下来便是在activity中调用:

Java代码

  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. });

***看一下效果图:

Android开发:完成带图片和checkbox的listview(安卓中checkbox的使用)  checkbox listview Android 第1张

要获取哪些项目被挑选了,能够这样测验:

Java代码

  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),假如您对getview有什么新的运用心得能够发Email:zhousn@51cto.com,51CTO将与您一同共享!

【修改引荐】

  1. Android 诉苦它仍是拥抱它?
  2. Android触屏textview及listview比照验证
  3. Android ListView杂乱运用方法简略了解
转载请说明出处
知优网 » Android开发:完成带图片和checkbox的listview(安卓中checkbox的使用)

发表评论

您需要后才能发表评论