Android教程網
  1. 首頁
  2. Android 技術
  3. Android 手機
  4. Android 系統教程
  5. Android 游戲
 Android教程網 >> Android技術 >> 關於Android編程 >> 實例講解Android app開發中ListView的基本使用及優化

實例講解Android app開發中ListView的基本使用及優化

編輯:關於Android編程

一、直接使用ListView組件創建
1.直接在XML中創建ListView用entries屬性附上一個數組資源
其中divider屬性是設置分割線可以使用顏色和drawable資源分割

 <ListView
    android:id="@+id/listView1"
    android:layout_width="match_parent"
    android:layout_height="wrap_content" 
    android:divider="#33000000"
    android:dividerHeight="0.2dp"
    android:footerDividersEnabled="true"
    android:headerDividersEnabled="true"
    android:entries="@arrary/ctype">
  </ListView>

在values下定義一個數組資源文件arrays.xml

<resources>
<item >情景模式1</item>
<item >情景模式2</item> 
<item >情景模式3</item>
</resources>

2.創建ArrayAdapter指定要顯示的列表項
在oncreat方法中關聯適配器

simple_list_item_1:列表項為普通文本

simple_list_item_2:列表項為普通文本字體略大
simple_list_item_checked:列表項為一個已選中的
simple_list_item_multiple_choice:帶有復選框的列表項
simple_list_item_single_choice:帶有單選按鈕的列表項

listview = (ListView) findViewById(R.id.listView1);
 ArrayAdapter<CharSequence> adapter = ArrayAdapter.createFromResource(this,R.array.ctype, android.R.layout.simple_list_item_checked);
    listview.setAdapter(adapter);

二、讓Activity繼承ListActivity實現

public class ActivityMain extends ListActivity {
  @Override
  protected void onCreate(Bundle savedInstanceState) {

    super.onCreate(savedInstanceState);
    String[] ctype ={"1","2","3"}; 
    ArrayAdapter<String> adapter = new ArrayAdapter<String>(this,android.R.layout.simple_list_item_1,ctype);
    setListAdapter(adapter);

  }

  @Override
  protected void onListItemClick(ListView l, View v, int position, long id) {

    super.onListItemClick(l, v, position, id);
  }


}

三、SimpleAdapter和BaseAapter的使用(重點)
SimpleAdapter的使用

在main.xml中添加ListView組件
編寫用於布局列表項內容的布局文件items.xml
創建一個簡單適配器與ListView關聯

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout
 xmlns:android="http://schemas.android.com/apk/res/android"
 android:orientation="horizontal"
 android:layout_width="match_parent"
 android:layout_height="match_parent">
<ImageView 
  android:id="@+id/image" 
  android:paddingRight="10px"
  android:paddingTop="20px"
  android:paddingBottom="20px"
  android:adjustViewBounds="true"
  android:maxWidth="72px"
  android:maxHeight="72px"
  android:layout_height="wrap_content" 
  android:layout_width="wrap_content"/> 
 <TextView 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:padding="10px"
  android:layout_gravity="center"
  android:id="@+id/title"
  />   
</LinearLayout>
public class MainActivity extends Activity {
  @Override
  public void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.main);
    ListView listview = (ListView) findViewById(R.id.listView1); // 獲取列表視圖
    int[] imageId = new int[] { R.drawable.img01, R.drawable.img02,
        R.drawable.img03, R.drawable.img04, R.drawable.img05,
        R.drawable.img06, R.drawable.img07, R.drawable.img08 }; // 定義並初始化保存圖片id的數組
    String[] title = new String[] { "保密設置", "安全", "系統設置", "上網", "我的文檔",
        "GPS導航", "我的音樂", "E-mail" }; // 定義並初始化保存列表項文字的數組
    List<Map<String, Object>> listItems = new ArrayList<Map<String, Object>>(); // 創建一個list集合
    // 通過for循環將圖片id和列表項文字放到Map中,並添加到list集合中
    for (int i = 0; i < imageId.length; i++) {
      Map<String, Object> map = new HashMap<String, Object>(); // 實例化Map對象
      map.put("image", imageId[i]);
      map.put("title", title[i]);
      listItems.add(map); // 將map對象添加到List集合中
    }

    SimpleAdapter adapter = new SimpleAdapter(this, listItems,
        R.layout.items, new String[] { "title", "image" }, new int[] {
            R.id.title, R.id.image }); // 創建SimpleAdapter
    listview.setAdapter(adapter); // 將適配器與ListView關聯

  }
}

三、BaseAdapter的使用及ListView的優化
使用方法同上主要是BaseAdapter的使用更加靈活也更加強大,可以向其中添加其他控件。

<?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/imageView1"
     android:layout_width="50dip"
    android:layout_height="50dip"
    android:layout_marginLeft="5dip"
    android:layout_marginTop="5dip"
    android:layout_marginBottom="5dip"  
    android:src="@android:drawable/ic_lock_power_off" />

  <TextView
    android:id="@+id/textView1"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_above="@+id/textView2"
    android:layout_toRightOf="@+id/imageView1"
    android:text="name"
    android:textColor="#000000"
    android:textSize="20sp" />

  <TextView
    android:id="@+id/textView2"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:layout_alignBottom="@+id/imageView1"
    android:layout_toRightOf="@+id/imageView1"
    android:text="number"
    android:textColor="#000000"
    android:textSize="20sp" />


</RelativeLayout>

public class MainActivity extends Activity {
  private ListView lv;
  private List<MyInfo> infos;
  private Random random;

  @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_main);
    lv = (ListView) findViewById(R.id.listView1);
    infos = new ArrayList<MyInfo>();
//通過for循環將name和number添加到List集合中
    for (int i = 0; i < 100; i++) {
      MyInfo userInfo = new MyInfo();
      userInfo.setName("name"+i);
      userInfo.setNumber("number"+i);
      infos.add(userInfo);
      System.out.println(userInfo.toString());  
    }

    lv.setAdapter(new MyAdapter());
  }

  private class MyAdapter extends BaseAdapter{

    @Override
    public int getCount() {
      return infos.size();//返回listview的長度
    }
    @Override
    public View getView(int position, View convertView, ViewGroup parent) {
      MyInfo userInfo = infos.get(position);
      View view;
      ViewHolder holder;
      //減少內存中view對象創建的次數
      if (convertView != null && convertView instanceof RelativeLayout) {
        view = convertView;//復用已經回收掉的view對象
        holder = (ViewHolder) view.getTag();//得到他們的引用
      } else {
        view = View.inflate(getApplicationContext(),
            R.layout.item_layout, null);//把布局文件轉化成View對象
        holder = new ViewHolder();
        //把ID存到存到holder對象中
        //注意是在view下findViewById
        holder.iv = (ImageView) view.findViewById(R.id.imageView1);
        holder.tv1 = (TextView) view.findViewById(R.id.textView1);
        holder.tv2 = (TextView) view.findViewById(R.id.textView2);
        view.setTag(holder);//對象創建出來時找到他們的引用存到holder中
      }
      holder.tv1.setText(infos.get(position).getName());
      holder.tv2.setText(infos.get(position).getNumber());
      return view;
    }
    @Override
    public Object getItem(int position) {      
      return null;
    }

    @Override
    public long getItemId(int position) {      
      return 0;
    }    

  }
  /*
   * view對象的容器記錄View對象的內存地址相當於一個記事本
   */
  static class ViewHolder{
    TextView tv1;
    TextView tv2;
    ImageView iv;
  }

}
public class MyInfo {
  private String name; 
  private String number;//也可以添加Bitmap

  @Override
  public String toString() {
    return "MyInfo [name=" + name + ", number=" + number + "]";
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getNumber() {
    return number;
  }
  public void setNumber(String number) {
    this.number = number;
  }


}

注意:(很多人不注意下面的這條語句是在view下findViewById,少了view會造成空指針異常)

holder.iv = (ImageView) view.findViewById(R.id.imageView1);

優化的原理就是動態循環復用已經回收掉的ListView對象(回收後為convertview),保持一個界面下的ListView的條目數的動態平衡。(具體內容參考代碼注釋即可)

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