在Android開發中ListView是比較經常使用的控件,經常使用於以列表的形式顯示數據集及根據數據的長度自適應顯示。java
ListView一般有兩個主要功能點:android
(1)將數據集填充到佈局中,顯示給用戶數據庫
要實現該功能須要以下三個元素:ubuntu
總結爲:要使用ListView,首先要了解什麼是適配器。適配器是一個鏈接數據和AdapterView的橋樑,經過它能有效地實現數據與AdapterView的分離設置,使AdapterView與數據的綁定更加簡便,修改更加方便數組
(2)處理用戶點擊的item事件緩存
mListView.setOnItemClickListener(new OnItemClickListener() {...});網絡
Adapter種類 | 含義 |
ArrayAdapter<T> | 用來綁定一個數組,支持泛型操做 |
SimpleAdapter | 用來綁定在XML中定義的控件對應的數據 |
SimpleCursorAdatpter | 用來綁定遊標獲得的數據(一般是數據庫的相關操做) |
BaseAdapter | 通用的基礎適配器 |
用ArrayAdapter能夠實現簡單的ListView的數據綁定,默認狀況下,ArrrayAdapter綁定每一個對象的String值到layout中預先定義的textview控件上app
例:ide
佈局文件:activity_main.xml函數
1 <?xml version="1.0" encoding="utf-8"?> 2 <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" 3 xmlns:tools="http://schemas.android.com/tools" 4 android:layout_width="match_parent" 5 android:layout_height="match_parent" 6 android:paddingBottom="@dimen/activity_vertical_margin" 7 android:paddingLeft="@dimen/activity_horizontal_margin" 8 android:paddingRight="@dimen/activity_horizontal_margin" 9 android:paddingTop="@dimen/activity_vertical_margin" 10 tools:context="com.example.ubuntu.listviewtest.MainActivity"> 11 12 <ListView 13 android:id="@+id/lv" 14 android:layout_width="match_parent" 15 android:layout_height="wrap_content" 16 /> 17 </RelativeLayout>
MainActivity.java的初始化
1 package com.example.ubuntu.listviewtest; 2 3 import android.support.v7.app.AppCompatActivity; 4 import android.os.Bundle; 5 import android.widget.ArrayAdapter; 6 import android.widget.ListView; 7 8 public class MainActivity extends AppCompatActivity { 9 10 public ListView mListView;//定義listView對象 11 public String[] strs = {"one","two","three","four","five"};//生成數據集 12 13 @Override 14 protected void onCreate(Bundle savedInstanceState) { 15 super.onCreate(savedInstanceState); 16 setContentView(R.layout.activity_main); 17 18 mListView =(ListView)findViewById(R.id.lv);//初始化listview 19 mListView.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,strs));//適配數據 20 } 21 }
效果以下圖所示:
總結一下使用步驟:
1 lv.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_list_item_checked, strs)); 2 lv.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
1 lv.setAdapter(new ArrayAdapter<String>(this,android.R.layout.simple_list_item_multiple_choice, strs)); 2 lv.setChoiceMode(ListView.CHOICE_MODE_MULTIPLE);
1 lv.setAdapter(newArrayAdapter<String>(this,android.R.layout.simple_list_item_single_choice,strs)); 2 lv.setChoiceMode(ListView.CHOICE_MODE_SINGLE);
1 lv.setOnItemClickListener(new OnItemClickListener() { 2 @Override 3 publicvoid onItemClick(AdapterView<?> parent, View view, int position, long id) { 4 //點擊後在標題上顯示點擊了第幾行 5 setTitle("你點擊了第"+arg2+"行"); 6 } 7 });
1 <?xmlversion="1.0"encoding="utf-8"?> 2 <RelativeLayoutxmlns:android="http://schemas.android.com/apk/res/android" 3 android:layout_height="fill_parent" android:layout_width="fill_parent"> 4 5 <ImageView 6 android:layout_alignParentRight="true" 7 android:layout_width="wrap_content" 8 android:layout_height="wrap_content" 9 android:id="@+id/ItemImage"/> 10 <TextView 11 android:id="@+id/ItemTitle" 12 android:layout_height="wrap_content" 13 android:layout_width="fill_parent" 14 android:textSize="20sp"/> 15 <TextView 16 android:id="@+id/ItemText" 17 android:layout_height="wrap_content" 18 android:layout_width="fill_parent" 19 android:layout_below="@+id/ItemTitle"/> 20 </RelativeLayout>
配置完畢,就能夠在Java代碼中爲ListView綁定數據。
1 public class MyListViewSimple extends Activity { 2 private ListView lv; 3 /** Called when the activity is first created. */ @Override 4 public void onCreate(Bundle savedInstanceState) { 5 super.onCreate(savedInstanceState); 6 setContentView(R.layout.main); 7 lv = (ListView) findViewById(R.id.lv);/*定義一個動態數組*/ 8 ArrayList<HashMap<String, Object>> listItem = new ArrayList<HashMap<String,Object>>();/*在數組中存放數據*/ 9 for(int i=0;i<10;i++){ 10 HashMap<String, Object> map = new HashMap<String, Object>(); 11 map.put("ItemImage", R.drawable.icon);//加入圖片 12 map.put("ItemTitle", "第"+i+"行"); 13 map.put("ItemText", "這是第"+i+"行"); 14 listItem.add(map); 15 } 16 SimpleAdapter mSimpleAdapter = new SimpleAdapter(this,listItem, 17 //須要綁定的數據 18 R.layout.item, 19 //每一行的佈局//動態數組中的數據源的鍵對應到定義佈局的View中 20 new String[] {"ItemImage","ItemTitle", "ItemText"}, 21 new int[] {R.id.ItemImage,R.id.ItemTitle,R.id.ItemText}); 22 lv.setAdapter(mSimpleAdapter);//爲ListView綁定適配器 23 lv.setOnItemClickListener(new 24 OnItemClickListener() { 25 @Override 26 publicvoid onItemClick(AdapterView<?> arg0, View arg1, int arg2, 27 long arg3) { 28 setTitle("你點擊了第"+arg2+"行");//設置標題欄顯示點擊的行 29 } 30 }); 31 } 32 }
1 /* 2 * 新建一個類繼承BaseAdapter,實現視圖與數據的綁定 3 */ 4 private class MyAdapter extends BaseAdapter { 5 private LayoutInflater mInflater;//獲得一個LayoutInfalter對象用來導入佈局 6 7 /*構造函數*/ 8 public MyAdapter(Context context) { 9 this.mInflater = LayoutInflater.from(context); 10 } 11 @Override 12 publicint getCount() { 13 return getDate().size();//返回數組的長度 14 } 15 @Override 16 public Object getItem(int position) { 17 return null; 18 } 19 @Override 20 public long getItemId(int position) { 21 return 0; 22 } 23 /*書中詳細解釋該方法*/ 24 @Override 25 public View getView(finalint position, View convertView, ViewGroup parent) { 26 ViewHolder holder; 27 //觀察convertView隨ListView滾動狀況 28 Log.v("MyListViewBase", "getView " + position + " " + convertView); 29 if (convertView == null) { 30 convertView = mInflater.inflate(R.layout.item,null); 31 holder = new ViewHolder(); 32 /*獲得各個控件的對象*/ 33 holder.title = (TextView) convertView.findViewById(R.id.ItemTitle); 34 holder.text = (TextView) convertView.findViewById(R.id.ItemText); 35 holder.bt = (Button) convertView.findViewById(R.id.ItemButton); 36 convertView.setTag(holder);//綁定ViewHolder對象 37 } 38 else{ 39 holder = (ViewHolder)convertView.getTag();//取出ViewHolder對象 40 /*設置TextView顯示的內容,即咱們存放在動態數組中的數據*/ 41 holder.title.setText(getDate().get(position).get("ItemTitle").toString()); 42 holder.text.setText(getDate().get(position).get("ItemText").toString()); 43 } 44 /*爲Button添加點擊事件*/ 45 holder.bt.setOnClickListener(new OnClickListener() { 46 @Override 47 publicvoid onClick(View v) { 48 Log.v("MyListViewBase", "你點擊了按鈕" + position);//打印Button的點擊信息 49 } 50 }); 51 return convertView; 52 } 53 54 } 55 /*存放控件*/ 56 public final class ViewHolder{ 57 public TextView title; 58 public TextView text; 59 public Button bt; 60 } 61 }
運行效果如圖所示。還須要注意的是,Button會搶奪ListView的焦點,須要將Button設置爲沒有焦點。設置很是簡單,只須要在xml的Button標籤下加入一行:android:focusable=「false」代碼就能夠了。在LogCat觀察點擊後輸出的信息,以下圖所示。
使用ListView主要注意如下四點:
1.佈局文件:將ListView控件加到layout佈局文件中;listView自定義的layout佈局文件
2.數據來源:(網絡端下載的數據;自定義的數據;數據庫讀取的數據)-》數據集相關的數組
3.適配器:ArrayAdapter<T>;SimpleAdapter;SimpleCursorAdatpter;BaseAdapter按需調用,建議複雜的itemView佈局文件須要經過繼承BaseAdapter來擴展
4.性能調優:使用ListView佈局文件時,android:layout_height高度屬性建議設置爲"match_parent",而非"wrap_content".
若設置爲wrap_content時,每次繪製ListView都會從新measure整個listview的高度,致使bindview函數重複調用。
若數據集較大的時候,則整個listview的顯示則會卡頓,用戶體驗很差。後續會專門一篇博客性能調優來講明這點。