Android开发:实现带图片和checkbox的listview

本文详细介绍了如何使用BaseAdapter类在Android中实现ListView展示图片及复选框的功能,包括数据绑定、布局文件设计以及交互事件处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://mobile.51cto.com/android-254823.htm

项目要用到一个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. });

最新看一下效果图:

效果图

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

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




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值