Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> Android開發實例 >> android用戶界面-組件Widget-列表視圖ListView

android用戶界面-組件Widget-列表視圖ListView

編輯:Android開發實例

ListView是比較常用的控件,但一直都覺得創建ListView步驟有點繁瑣,故在此總結一下,方便查閱。

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

 

 

 

 

首先在xml裡面定義一個ListView

 

  1. <?xml version="1.0" encoding="utf-8"?>  
  2. <LinearLayout    
  3.     android:id="@+id/LinearLayout01"    
  4.     android:layout_width="fill_parent"    
  5.     android:layout_height="fill_parent"    
  6.     xmlns:android="http://schemas.android.com/apk/res/android">  
  7. <ListView android:layout_width="wrap_content"    
  8.           android:layout_height="wrap_content"    
  9.           android:id="@+id/ListView01"  
  10.           />  
  11. </LinearLayout>  

 

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

 

  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,具體見注釋:

 

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

 

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