Android實現的ListView分組布局改進樣本_Android

來源:互聯網
上載者:User

本文執行個體講述了Android實現的ListView分組布局改進方法。分享給大家供大家參考,具體如下:

由於是在網上轉載的一篇文章,在這裡就不多說廢話了,首先看一下最終的效果圖:

然後是實現該ListView布局的主要代碼:

1、程式主介面 SeparateListView.java

package whu.iss.wuxianglong;import java.util.ArrayList;import java.util.List;import android.app.Activity;import android.content.Context;import android.os.Bundle;import android.view.LayoutInflater;import android.view.View;import android.view.ViewGroup;import android.widget.ArrayAdapter;import android.widget.ListView;import android.widget.TextView;public class SeparateListView extends Activity {  ListView listView;  MyAdapter myAdapter;  public List<String> listTag = new ArrayList<String>();  /** Called when the activity is first created. */  @Override  public void onCreate(Bundle savedInstanceState) {    super.onCreate(savedInstanceState);    setContentView(R.layout.main);    listView = (ListView) findViewById(R.id.list);    myAdapter = new MyAdapter(this,        android.R.layout.simple_expandable_list_item_1, getData());    listView.setAdapter(myAdapter);  }  private List<String> getData() {    List<String> data = new ArrayList<String>();    int i = 0;    data.add("A");    listTag.add("A");    data.add("aa試資料" + (i++));    data.add("a試資料" + (i++));    data.add("aa試資料" + (i++));    listTag.add("B");    data.add("B");    data.add("bb試資料" + (i++));    data.add("b試資料" + (i++));    data.add("b試資料" + (i++));    data.add("b試資料" + (i++));    listTag.add("C");    data.add("C");    data.add("c測試資料" + (i++));    data.add("c測試資料" + (i++));    listTag.add("D");    data.add("D");    data.add("d測試資料" + (i++));    data.add("d測試資料" + (i++));    data.add("d測試資料" + (i++));    listTag.add("E");    data.add("E");    data.add("e測試資料" + (i++));    data.add("e測試資料" + (i++));    data.add("e測試資料" + (i++));    listTag.add("F");    data.add("F" );    data.add("f測試資料" + (i++));    return data;  }  class MyAdapter extends ArrayAdapter<String> {    public MyAdapter(Context context, int textViewResourceId,        List<String> objects) {      super(context, textViewResourceId, objects);    }    @Override    public boolean areAllItemsEnabled() {      return false;    }    @Override    public boolean isEnabled(int position) {      // 如果-開頭,則該項不可選      return !listTag.contains(getItem(position));    }    @Override    public View getView(int position, View convertView, ViewGroup parent) {      View view = convertView;     //根據標籤類型載入不通的布局模板      if(listTag.contains(getItem(position))){        //如果是標籤項        view = LayoutInflater.from(getContext()).inflate(R.layout.group_list_item_tag, null);      }else{        //否則就是資料項目        view = LayoutInflater.from(getContext()).inflate(R.layout.group_list_item, null);      }     //顯示名稱      TextView textView = (TextView) view.findViewById(R.id.group_list_item_text);      textView.setText(getItem(position));     //返回重寫的view      return view;    }  }}

2、程式主介面布局檔案main.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:orientation="vertical"  android:layout_width="fill_parent"  android:layout_height="fill_parent"  >  <ListView    android:id="@+id/list"    android:layout_width="fill_parent"    android:layout_height="wrap_content">  </ListView></LinearLayout>

3、ListView中資料部分樣式布局檔案group_list_item.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:orientation="horizontal"  android:layout_width="fill_parent"  android:layout_height="wrap_content"  android:padding="5dip">  <ImageView    android:src="@drawable/icon"    android:layout_width="50px"    android:layout_height="50px">  </ImageView>  <TextView    android:id="@+id/group_list_item_text"    android:layout_width="wrap_content"    android:layout_height="fill_parent"    android:paddingLeft="5dip"    android:gravity="center_vertical">  </TextView></LinearLayout>

4、ListView中分組標誌行的樣式布局檔案group_list_item_tag.xml

<?xml version="1.0" encoding="utf-8"?><LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"  android:layout_width="fill_parent"  android:layout_height="wrap_content"  android:background="#555555"  android:paddingLeft="10dip">  <TextView    android:id="@+id/group_list_item_text"    android:layout_width="wrap_content"    android:layout_height="20dip"    android:textColor="#ffffff"    android:gravity="center_vertical">  </TextView></LinearLayout>

更多關於Android相關內容感興趣的讀者可查看本站專題:《Android視圖View技巧總結》、《Android編程之activity操作技巧總結》、《Android操作SQLite資料庫技巧總結》、《Android操作json格式資料技巧總結》、《Android資料庫操作技巧總結》、《Android檔案操作技巧匯總》、《Android編程開發之SD卡操作方法匯總》、《Android開發入門與進階教程》、《Android資源操作技巧匯總》及《Android控制項用法總結》

希望本文所述對大家Android程式設計有所協助。

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.