Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發 >> 高級開發 >> Android開發:實現帶圖片和checkbox的listview

Android開發:實現帶圖片和checkbox的listview

編輯:高級開發

項目要用到一個listvIEw,要求是可以顯示圖片,後面還有有復選框。

先新建一個MyAdapter類,繼承自BaseAdapter。在MyAdapter中實現數據的綁定,我這兒由於是測試的,所以把數據寫死了。

Java代碼

  1. package com.zwq.umeng;
  2. import Java.util.ArrayList;
  3. import Java.util.HashMap;
  4. import Java.util.List;
  5. import Java.util.Map;
  6. import android.content.Context;
  7. import android.vIEw.LayoutInflater;
  8. import android.view.VIEw;
  9. import android.view.VIEwGroup;
  10. import android.widget.BaseAdapter;
  11. import android.widget.CheckBox;
  12. import android.widget.ImageVIEw;
  13. import android.widget.TextVIEw;
  14. public class MyAdapter extends BaseAdapter {
  15. private LayoutInflater mInflater;
  16. private List<Map<String, Object>> mData;
  17. public static Map<Integer, Boolean> isSelected;
  18. public MyAdapter(Context context) {
  19. mInflater = LayoutInflater.from(context);
  20. init();
  21. }
  22. //初始化
  23. private void init() {
  24. mData=new ArrayList<Map<String, Object>>();
  25. for (int i = 0; i < 5; i++) {
  26. Map<String, Object> map = new HashMap<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 = new HashMap<Integer, Boolean>();
  33. for (int i = 0; i < mData.size(); i++) {
  34. isSelected.put(i, false);
  35. }
  36. }
  37. @Override
  38. public int getCount() {
  39. return mData.size();
  40. }
  41. @Override
  42. public Object getItem(int position) {
  43. return null;
  44. }
  45. @Override
  46. public long getItemId(int position) {
  47. return 0;
  48. }
  49. @Override
  50. public View getVIEw(int position, View convertView, VIEwGroup parent) {
  51. VIEwHolder holder = null;
  52. //convertView為null的時候初始化convertVIEw。
  53. if (convertVIEw == null) {
  54. holder = new VIEwHolder();
  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. return convertVIEw;
  68. }
  69. public final class VIEwHolder {
  70. public ImageVIEw img;
  71. public TextVIEw title;
  72. public CheckBox cBox;
  73. }
  74. }

上面類中要注意getVIEw()方法中對數據的處理。

接下要新建一個list.XML文件,這個就是布局image、textvIEw、checkbox。

Java代碼

  1. <?XML version="1.0" encoding="utf-8"?>
  2. <LinearLayout XMLns: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. MyAdapter adapter=new MyAdapter(this);
  3. list.setAdapter(adapter);
  4. list.setItemsCanFocus(false);
  5. list.setChoiceMode(ListVIEw.CHOICE_MODE_MULTIPLE);
  6. list.setOnItemClickListener(new OnItemClickListener(){
  7. @Override
  8. public void onItemClick(AdapterView<?> parent, View vIEw,
  9. int position, long id) {
  10. ViewHolder vHollder = (ViewHolder) vIEw.getTag();
  11. //在每次獲取點擊的item時將對於的checkbox狀態改變,同時修改map的值。
  12. vHollder.cBox.toggle();
  13. MyAdapter.isSelected.put(position, vHollder.cBox.isChecked());
  14. }
  15. });

最新看一下效果圖:

效果圖

要獲取哪些項目被選擇了,可以這樣測試:

Java代碼

  1. OnClickListener bPop = new OnClickListener() {
  2. @Override
  3. public void onClick(VIEw v) {
  4. for(int i=0;i<list.getCount();i++){
  5. if(MyAdapter.isSelected.get(i)){
  6. ViewHolder vHollder = (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:[email protected],51CTO將與您一起分享!

  1. 上一頁:
  2. 下一頁:
熱門文章
閱讀排行版
Copyright © Android教程網 All Rights Reserved