Android實現(xiàn)的ListView分組布局改進示例
本文實例講述了Android實現(xiàn)的ListView分組布局改進方法。分享給大家供大家參考,具體如下:
由于是在網(wǎng)上轉(zhuǎn)載的一篇文章,在這里就不多說廢話了,首先看一下最終的效果圖:

然后是實現(xiàn)該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試數(shù)據(jù)" + (i++));
data.add("a試數(shù)據(jù)" + (i++));
data.add("aa試數(shù)據(jù)" + (i++));
listTag.add("B");
data.add("B");
data.add("bb試數(shù)據(jù)" + (i++));
data.add("b試數(shù)據(jù)" + (i++));
data.add("b試數(shù)據(jù)" + (i++));
data.add("b試數(shù)據(jù)" + (i++));
listTag.add("C");
data.add("C");
data.add("c測試數(shù)據(jù)" + (i++));
data.add("c測試數(shù)據(jù)" + (i++));
listTag.add("D");
data.add("D");
data.add("d測試數(shù)據(jù)" + (i++));
data.add("d測試數(shù)據(jù)" + (i++));
data.add("d測試數(shù)據(jù)" + (i++));
listTag.add("E");
data.add("E");
data.add("e測試數(shù)據(jù)" + (i++));
data.add("e測試數(shù)據(jù)" + (i++));
data.add("e測試數(shù)據(jù)" + (i++));
listTag.add("F");
data.add("F" );
data.add("f測試數(shù)據(jù)" + (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;
//根據(jù)標簽類型加載不通的布局模板
if(listTag.contains(getItem(position))){
//如果是標簽項
view = LayoutInflater.from(getContext()).inflate(R.layout.group_list_item_tag, null);
}else{
//否則就是數(shù)據(jù)項
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中數(shù)據(jù)部分樣式布局文件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相關內(nèi)容感興趣的讀者可查看本站專題:《Android視圖View技巧總結》、《Android編程之a(chǎn)ctivity操作技巧總結》、《Android操作SQLite數(shù)據(jù)庫技巧總結》、《Android操作json格式數(shù)據(jù)技巧總結》、《Android數(shù)據(jù)庫操作技巧總結》、《Android文件操作技巧匯總》、《Android編程開發(fā)之SD卡操作方法匯總》、《Android開發(fā)入門與進階教程》、《Android資源操作技巧匯總》及《Android控件用法總結》
希望本文所述對大家Android程序設計有所幫助。
- android 通過向viewpage中添加listview來完成滑動效果(類似于qq滑動界面)
- android Listview模擬聊天界面
- Android 新聞界面模擬ListView和ViewPager的應用
- Android ListView自定義Adapter實現(xiàn)仿QQ界面
- Android App界面的ListView布局實戰(zhàn)演練
- Android中使用Expandablelistview實現(xiàn)微信通訊錄界面
- android動態(tài)布局之動態(tài)加入TextView和ListView的方法
- Android ListView添加頭布局和腳布局實例詳解
- 神奇的listView實現(xiàn)自動顯示隱藏布局Android代碼
- Android開發(fā)之ListView的簡單用法及定制ListView界面操作示例
相關文章
Android 解決build path errors的問題
這篇文章主要介紹了Android 解決build path errors的問題的相關資料,需要的朋友可以參考下2016-09-09
Android使用SlidingPaneLayout 實現(xiàn)仿微信的滑動返回
這篇文章主要介紹了Android使用SlidingPaneLayout 實現(xiàn)仿微信的滑動返回,需要的朋友可以參考下2018-04-04
React Native中Android物理back鍵按兩次返回鍵即退出應用
這篇文章主要給大家介紹了關于React Native中Android物理back鍵按兩次返回鍵即退出應用的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧。2017-10-10
SurfaceView開發(fā)[捉小豬]手機游戲 (一)
這篇文章主要介紹了用SurfaceView開發(fā)[捉小豬]手機游戲 (一)本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-08-08

