實現一個ListView,ListView裏面有標題,內容和圖片,並加入點擊和長按響應

ListView是比較經常使用的控件,但一直都以爲建立ListView步驟有點繁瑣,故在此總結一下,方便查閱。java

程序效果是實現一個ListView,ListView裏面有標題,內容和圖片,並加入點擊和長按響應。android

 

 

 

 

首先在xml裏面定義一個ListView數組

 

Xml代碼  收藏代碼app

  1. <?xml version="1.0" encoding="utf-8"?>  ide

  2. <LinearLayout   函數

  3.     android:id="@+id/LinearLayout01"   this

  4.     android:layout_width="fill_parent"   spa

  5.     android:layout_height="fill_parent"   orm

  6.     xmlns:android="http://schemas.android.com/apk/res/android">  xml

  7. <ListView android:layout_width="wrap_content"   

  8.           android:layout_height="wrap_content"   

  9.           android:id="@+id/ListView01"  

  10.           />  

  11. </LinearLayout>  

 

定義ListView每一個條目的Layout,用RelativeLayout實現:

 

Xml代碼  收藏代碼

  1. <?xml version="1.0" encoding="utf-8"?>  

  2. <RelativeLayout   

  3.     android:id="@+id/RelativeLayout01"   

  4.     android:layout_width="fill_parent"   

  5.     xmlns:android="http://schemas.android.com/apk/res/android"   

  6.     android:layout_height="wrap_content"   

  7.     android:paddingBottom="4dip"   

  8.     android:paddingLeft="12dip"  

  9.     android:paddingRight="12dip">  

  10. <ImageView   

  11.     android:paddingTop="12dip"  

  12.     android:layout_alignParentRight="true"  

  13.     android:layout_width="wrap_content"   

  14.     android:layout_height="wrap_content"   

  15.     android:id="@+id/ItemImage"  

  16.     />   

  17. <TextView   

  18.     android:text="TextView01"   

  19.     android:layout_height="wrap_content"   

  20.     android:textSize="20dip"   

  21.     android:layout_width="fill_parent"   

  22.     android:id="@+id/ItemTitle"  

  23.     />  

  24. <TextView   

  25.     android:text="TextView02"   

  26.     android:layout_height="wrap_content"   

  27.     android:layout_width="fill_parent"   

  28.     android:layout_below="@+id/ItemTitle"   

  29.     android:id="@+id/ItemText"  

  30.     />  

  31. </RelativeLayout>  

 

 最後在Activity裏面調用和加入Listener,具體見註釋:

 

Java代碼  收藏代碼

  1. package com.ray.test;  

  2.   

  3. import java.util.ArrayList;  

  4. import java.util.HashMap;  

  5.   

  6. import android.app.Activity;  

  7. import android.os.Bundle;  

  8. import android.view.ContextMenu;  

  9. import android.view.MenuItem;  

  10. import android.view.View;  

  11. import android.view.ContextMenu.ContextMenuInfo;  

  12. import android.view.View.OnCreateContextMenuListener;  

  13. import android.widget.AdapterView;  

  14. import android.widget.ListView;  

  15. import android.widget.SimpleAdapter;  

  16. import android.widget.AdapterView.OnItemClickListener;  

  17.   

  18. public class TestListView extends Activity {  

  19.     @Override  

  20.     public void onCreate(Bundle savedInstanceState) {  

  21.         super.onCreate(savedInstanceState);  

  22.         setContentView(R.layout.main);  

  23.         //綁定Layout裏面的ListView  

  24.         ListView list = (ListView) findViewById(R.id.ListView01);  

  25.           

  26.         //生成動態數組,加入數據  

  27.         ArrayList<HashMap<String, Object>> listItem = new ArrayList<HashMap<String, Object>>();  

  28.         for(int i=0;i<10;i++)  

  29.         {  

  30.             HashMap<String, Object> map = new HashMap<String, Object>();  

  31.             map.put("ItemImage", R.drawable.checked);//圖像資源的ID  

  32.             map.put("ItemTitle""Level "+i);  

  33.             map.put("ItemText""Finished in 1 Min 54 Secs, 70 Moves! ");  

  34.             listItem.add(map);  

  35.         }  

  36.         //生成適配器的Item和動態數組對應的元素  

  37.         SimpleAdapter listItemAdapter = new SimpleAdapter(this,listItem,//數據源   

  38.             R.layout.list_items,//ListItem的XML實現  

  39.             //動態數組與ImageItem對應的子項          

  40.             new String[] {"ItemImage","ItemTitle""ItemText"},   

  41.             //ImageItem的XML文件裏面的一個ImageView,兩個TextView ID  

  42.             new int[] {R.id.ItemImage,R.id.ItemTitle,R.id.ItemText}  

  43.         );  

  44.          

  45.         //添加而且顯示  

  46.         list.setAdapter(listItemAdapter);  

  47.           

  48.         //添加點擊  

  49.         list.setOnItemClickListener(new OnItemClickListener() {  

  50.   

  51.             @Override  

  52.             public void onItemClick(AdapterView<?> arg0, View arg1, int arg2,  

  53.                     long arg3) {  

  54.                 setTitle("點擊第"+arg2+"個項目");  

  55.             }  

  56.         });  

  57.           

  58.       //添加長按點擊  

  59.         list.setOnCreateContextMenuListener(new OnCreateContextMenuListener() {  

  60.               

  61.             @Override  

  62.             public void onCreateContextMenu(ContextMenu menu, View v,ContextMenuInfo menuInfo) {  

  63.                 menu.setHeaderTitle("長按菜單-ContextMenu");     

  64.                 menu.add(000"彈出長按菜單0");  

  65.                 menu.add(010"彈出長按菜單1");     

  66.             }  

  67.         });   

  68.     }  

  69.       

  70.     //長按菜單響應函數  

  71.     @Override  

  72.     public boolean onContextItemSelected(MenuItem item) {  

  73.         setTitle("點擊了長按菜單裏面的第"+item.getItemId()+"個項目");   

  74.         return super.onContextItemSelected(item);  

  75.     }  

  76. }  

相關文章
相關標籤/搜索