亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

ListView的Adapter使用(綁定數(shù)據(jù)) 之 自定義每一項的布局去綁定數(shù)據(jù)

 更新時間:2013年06月05日 12:14:01   作者:  
之前寫的綁定數(shù)據(jù)是只是簡單的綁定了字符串,這次我們將一次綁定多條數(shù)據(jù)并且嘗試用自定義的布局。在這篇文章中首先講解的是用Hashmap 去綁定數(shù)據(jù),第二個例子,講解自定義布局然后綁定數(shù)據(jù)
大家先看第一個例子顯示:

這個界面相信大家都看到過的,這次比上一個例子多的是ListView 的每一項綁定的是不再是單純的一個字符串了,ListView 的每一個條目我們需要顯示兩個信息,編號和姓名.可以看到,我們綁定了十條數(shù)據(jù),用了一個for 循環(huán),每一條綁定的時候創(chuàng)建一個HashMap,然后往里面放數(shù)據(jù),放的數(shù)據(jù)有相對應的key, 即id,name,到時候我們?nèi)?shù)據(jù)的時候就根據(jù)這個key 找到我們放進去的數(shù)據(jù),有點類似與鍵值對的意思,不知道這樣解釋大家明白不明白。

貼上源代碼,然后接下來講解:

復制代碼 代碼如下:

/**  *  
 */ package com.cz.list.demo; 
 import java.util.ArrayList; 
import java.util.HashMap;  
import android.app.Activity; import android.os.Bundle; 
import android.widget.ListView; import android.widget.SimpleAdapter; 
 /** 
 * @author CZ  *  
 */ public class SimpleAdapterListDemo extends Activity { 
    private ListView listView;  
    /*      * (non-Javadoc) 
     *       * @see android.app.Activity#onCreate(android.os.Bundle) 
     */     @Override 
    protected void onCreate(Bundle savedInstanceState) {         // TODO Auto-generated method stub 
        super.onCreate(savedInstanceState);         setContentView(R.layout.array_list_layout); 
        listView = (ListView) findViewById(R.id.array_list);  
        SimpleAdapter simpleAdapter = new SimpleAdapter(                 SimpleAdapterListDemo.this, getHashMapData(), 
                android.R.layout.simple_list_item_2, new String[] { "id",                         "name" }, new int[] { android.R.id.text1, 
                        android.R.id.text2 });         listView.setAdapter(simpleAdapter); 
    }  
    /**      *  
     * @return Year:2011 Date:2011-10-23 Time:下午05:45:38 Author:CZ TODO      *         寫一個方法去綁定十條數(shù)據(jù) 
     */     private ArrayList<HashMap<String, Object>> getHashMapData() { 
        ArrayList<HashMap<String, Object>> hashData = new ArrayList<HashMap<String, Object>>();         for (int i = 0; i < 10; i++) { 
            HashMap<String, Object> mItem = new HashMap<String, Object>();             mItem.put("id", "當前的id是" + i); 
            mItem.put("name", "名字是美女" + i);             hashData.add(mItem); 
        }         return hashData; 
     } 
}

這個Adapter直接用的是SimpleAdapter,構(gòu)造函數(shù)中有五個參數(shù),可以看下:

android.widget.SimpleAdapter.SimpleAdapter(Context context, List<? extends Map<String, ?>> data, int resource, String[] from, int[] to)

構(gòu)造函數(shù)中有五個參數(shù),

第一個是context引用對象,
第二個參數(shù)就是我們要顯示的數(shù)據(jù)集List,
第三個參數(shù)是int 類型的,是我們每一條的自定義布局,程序中我們用到的是android中自帶的布局,所以用android.R.layout.list_item_2來引用,如果是我們自定義的布局,就直接用R.layout.XX引用就好。
第四個參數(shù)跟第五個參數(shù)需要一起理解,從字面的意思理解,from to 就是把第四個參數(shù)里面的數(shù)據(jù)顯示到第五個參數(shù)中。 第二個參數(shù)是我們要顯示的數(shù)據(jù)集,每條數(shù)據(jù)都是用哈希Map 來定義的,里面有定義的作為key 的字段,id,name, 有這樣一個映射的關(guān)系,第四個參數(shù)中的key 值映射到第五個參數(shù)中相對應的TextView 上面,那么這些TextView 是從哪里來的,是第三個參數(shù)中 布局文件中的TextView,這四個參數(shù)中可以這樣理解.

希望大家這時候可以理解。

接下來是自定義布局的例子,但是因為我第一次寫完提交的時候提示字符超過8萬,粘有貼錯了東西,讓我不禁在心里發(fā)下牢騷,編輯器有待提高啊..

接下來是自定義布局的例子,我們大家先看下程序出來的效果圖:

代碼是:

1.     首先自定義布局,我們命名一個custom_list_layout.xml的布局文件,代碼如下:

復制代碼 代碼如下:

<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent" android:layout_height="fill_parent"> <ImageView android:id="@+id/imageView" android:layout_width="48dip"
android:layout_height="48dip" android:scaleType="fitCenter" android:adjustViewBounds="true" android:layout_alignParentLeft="true"
android:layout_margin="5dip"></ImageView> <TextView android:id="@+id/number" android:layout_width="wrap_content"
android:layout_height="wrap_content" android:textSize="14dip" android:layout_toRightOf="@+id/imageView" android:layout_alignTop="@+id/imageView"></TextView>
<TextView android:id="@+id/name" android:layout_width="wrap_content" android:layout_height="wrap_content" android:textSize="10dip"
android:layout_toRightOf="@+id/imageView" android:layout_below="@+id/number"></TextView> </RelativeLayout>


2. 我們程序中的代碼:

復制代碼 代碼如下:

/** *
*/ package com.cz.list.demo;
import java.util.ArrayList;
import java.util.HashMap;
import android.app.Activity; import android.content.Context;
import android.os.Bundle; import android.util.Log;
import android.view.LayoutInflater; import android.view.View;
import android.view.ViewGroup; import android.widget.ImageView;
import android.widget.ListView; import android.widget.SimpleAdapter;
import android.widget.TextView;
/** * @author CZ
* */
public class CustomSimpleAdapterDemo extends Activity { private ListView listView;
@Override
protected void onCreate(Bundle savedInstanceState) { // TODO Auto-generated method stub
super.onCreate(savedInstanceState); setContentView(R.layout.array_list_layout);
listView = (ListView) findViewById(R.id.array_list);
CustomSimpleAdapter customSimpleAdapter = new CustomSimpleAdapter( CustomSimpleAdapterDemo.this, getHashMapData(),
R.layout.custom_list_layout);
listView.setAdapter(customSimpleAdapter); }
/**
* * @author CZ
* 自定義的類去繼承SimpleAdapter */
private class CustomSimpleAdapter extends SimpleAdapter { private Context context;
private ArrayList<HashMap<String, Object>> data; private int layoutResource;
/**
* @param context * @param data
* @param resource * @param from
* @param to 構(gòu)造函數(shù) */
public CustomSimpleAdapter(Context context, ArrayList<HashMap<String, Object>> data, int resource) {
super(context, data, resource, null, null); this.context = context;
this.data = data; this.layoutResource = resource;
}
class ViewHolder { ImageView picture;
TextView number; TextView name;
}
/* * (non-Javadoc)
* * @see android.widget.SimpleAdapter#getView(int, android.view.View,
* android.view.ViewGroup) */
@Override public View getView(int position, View convertView, ViewGroup parent) {
LayoutInflater layoutInflater = (LayoutInflater) getSystemService(LAYOUT_INFLATER_SERVICE); View layoutView = layoutInflater.inflate(layoutResource, null);
ViewHolder viewHolder = new ViewHolder(); viewHolder.picture = (ImageView) layoutView
.findViewById(R.id.imageView); viewHolder.number = (TextView) layoutView.findViewById(R.id.number);
viewHolder.name = (TextView) layoutView.findViewById(R.id.name);
viewHolder.picture.setImageResource(Integer.parseInt(data.get( position).get("imageView").toString()));
viewHolder.number.setText(data.get(position).get("id").toString()); Log.e("id", data.get(position).get("name").toString());
viewHolder.name.setText(data.get(position).get("name").toString()); return layoutView;
} }
/**
* * @return
* Year:2011 Date:2011-10-23 Time:下午05:46:45 * Author:CZ
* TODO 自定義的方法綁定數(shù)據(jù),為了避免圖片全部都一樣,我們讓三張圖片循環(huán)綁定。 */
private ArrayList<HashMap<String, Object>> getHashMapData() { ArrayList<HashMap<String, Object>> hashData = new ArrayList<HashMap<String, Object>>();
for (int i = 0; i < 10; i++) { HashMap<String, Object> mItem = new HashMap<String, Object>();
mItem.put("id", "當前的編號是:" + i); mItem.put("name", "名字是美女" + i);
switch (i % 3) { case 0:
mItem.put("imageView", R.drawable.test1); break;
case 1: mItem.put("imageView", R.drawable.test2);
break; case 2:
mItem.put("imageView", R.drawable.test3); break;
default: mItem.put("imageView", R.drawable.test4);
break; }
hashData.add(mItem); }
return hashData;
}
}


有了之前的例子做基礎,這時候看起來是不是會清楚一些呢,綁定數(shù)據(jù)是一樣的,只不過是多綁定了圖片的數(shù)據(jù)。

然后我們重寫了SimpleAdapter, 構(gòu)造函數(shù)我們自己定義參數(shù),需要說明的是:

1) getView() 方法返回是的是一個View值,我們綁定完數(shù)據(jù)之后,把這個View返回

2) 我們自己寫的layout,要先通過轉(zhuǎn)化,轉(zhuǎn)化成為一個View, 找到她里面對應的TextView,然后取出List 表中相對應位置的HashMap,取出數(shù)據(jù)顯示到相應的ImageView 和TextView上面.

希望對新手有所幫助..

相關(guān)文章

  • Android中的dumpsys命令詳解

    Android中的dumpsys命令詳解

    本文詳細講解了Android中的dumpsys命令,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-04-04
  • 手把手教你用Android自定義餅狀圖

    手把手教你用Android自定義餅狀圖

    最近在項目中需要用到簡單的餅形圖統(tǒng)計,我們就沒必要去找什么開源的,可以嘗試自己畫一下?,F(xiàn)在將實現(xiàn)的過程分享給大家,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10
  • Android 利用廣播監(jiān)聽usb連接狀態(tài)(變化情況)

    Android 利用廣播監(jiān)聽usb連接狀態(tài)(變化情況)

    這篇文章主要介紹了Android 利用廣播監(jiān)聽usb連接狀態(tài),需要的朋友可以參考下
    2017-06-06
  • Android實現(xiàn)可瀏覽和搜索的聯(lián)系人列表

    Android實現(xiàn)可瀏覽和搜索的聯(lián)系人列表

    這篇文章主要為大家詳細介紹了Android實現(xiàn)可瀏覽和搜索的聯(lián)系人列表的相關(guān)代碼,瀏覽所有聯(lián)系人和根據(jù)名稱搜索聯(lián)系人,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 詳解關(guān)于AndroidQ獲取不到imsi解決方案

    詳解關(guān)于AndroidQ獲取不到imsi解決方案

    這篇文章主要介紹了詳解關(guān)于AndroidQ獲取不到imsi解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-11-11
  • Android14(U)適配攻略

    Android14(U)適配攻略

    本文主要介紹了Android14(U)適配攻略,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-06-06
  • Android基于OkHttp實現(xiàn)下載和上傳圖片

    Android基于OkHttp實現(xiàn)下載和上傳圖片

    這篇文章主要為大家詳細介紹了Android基于OkHttp實現(xiàn)下載和上傳圖片功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • Android實現(xiàn)調(diào)用系統(tǒng)分享功能示例的總結(jié)

    Android實現(xiàn)調(diào)用系統(tǒng)分享功能示例的總結(jié)

    這篇文章主要介紹了通過Android調(diào)用系統(tǒng)分享文本信息、單張圖片、多個文件和指定分享到微信、QQ,同時分享圖片和文字的功能示例,小編覺得挺不錯,一起跟隨小編過來看看吧
    2018-05-05
  • 詳解Android 教你打造高效的圖片加載框架

    詳解Android 教你打造高效的圖片加載框架

    本篇文章主要介紹了詳解Android 教你打造高效的圖片加載框架,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-12-12
  • Android SurfaceView與TextureView使用方法詳細講解

    Android SurfaceView與TextureView使用方法詳細講解

    SurfaceView和TextureView都繼承View,與普通的View不同的是,它倆可以在獨立線程中繪制渲染,性能更高,所以常被應用在對繪制速率要求比較高的場景,比如相機預覽,視頻播放等等
    2022-10-10

最新評論