android ExpandableListView简单例子

   android中常常要用到ListView,有时也要用到ExpandableListView,如在手机设置中,对于分类有很好的效果,会用ListView的人一定会用ExpandableListView,因为
 ExpandableListView extends ListView的,下面来看个简单的例子
 
 运行效果图:
 




<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity" >

    <ExpandableListView
        android:id="@+id/expendlist"
        android:layout_width="match_parent"
        android:layout_height="wrap_content" >
    </ExpandableListView>

 </RelativeLayout>

//扩展ListView的头List布局文件
 <?xml version="1.0" encoding="utf-8"?>
 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="wrap_content"
  android:orientation="horizontal" >

  <TextView
   android:id="@+id/txt"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content" />

  <ImageView
   android:id="@+id/img"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content" />
 </LinearLayout>

//扩展ListView的子List布局文件
 <?xml version="1.0" encoding="utf-8"?>
 <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  android:layout_width="match_parent"
  android:layout_height="match_parent"
  android:orientation="horizontal"
  android:padding="10.0dp" >

  <ImageView
   android:id="@+id/img"
   android:layout_width="20.0dp"
   android:layout_height="20.0dp" />

  <TextView
   android:id="@+id/txt"
   android:layout_width="wrap_content"
   android:layout_height="wrap_content" />

 </LinearLayout>

package com.example.test;

 import java.util.ArrayList;
 import java.util.List;

 import android.app.Activity;
 import android.content.Context;
 import android.os.Bundle;
 import android.view.View;
 import android.view.ViewGroup;
 import android.widget.BaseExpandableListAdapter;
 import android.widget.ExpandableListView;
 import android.widget.ImageView;
 import android.widget.TextView;

 public class MainActivity extends Activity {

 private ExpandableListView expandableListView;
 private List<String> group_list;
 private List<List<String>> item_list;
 private List<List<Integer>> item_list2;

 @Override
 protected void onCreate(Bundle savedInstanceState) {
  super.onCreate(savedInstanceState);
  setContentView(R.layout.activity_main);

  //随便一堆测试数据
  group_list = new ArrayList<String>();
  group_list.add("A");
  group_list.add("B");
  group_list.add("C");

  item_list = new ArrayList<List<String>>();
  item_list.add(group_list);
  item_list.add(group_list);
  item_list.add(group_list);

  List<Integer> tmp_list = new ArrayList<Integer>();
  tmp_list.add(R.drawable.ic_launcher);
  tmp_list.add(R.drawable.ic_launcher);
  tmp_list.add(R.drawable.ic_launcher);

  item_list2 = new ArrayList<List<Integer>>();
  item_list2.add(tmp_list);
  item_list2.add(tmp_list);
  item_list2.add(tmp_list);

  expandableListView = (ExpandableListView) findViewById(R.id.expendlist);
  expandableListView.setAdapter(new MyExpandableListViewAdapter(this));
 }

 //用过ListView的人一定很熟悉,只不过这里是BaseExpandableListAdapter
 class MyExpandableListViewAdapter extends BaseExpandableListAdapter {

  private Context context;

  public MyExpandableListViewAdapter(Context context) {
   this.context = context;
  }

  @Override
  public int getGroupCount() {
   return group_list.size();
  }

  @Override
  public int getChildrenCount(int groupPosition) {
   return item_list.get(groupPosition).size();
  }

  @Override
  public Object getGroup(int groupPosition) {
   return group_list.get(groupPosition);
  }

  @Override
  public Object getChild(int groupPosition, int childPosition) {
   return item_list.get(groupPosition).get(childPosition);
  }

  @Override
  public long getGroupId(int groupPosition) {
   return groupPosition;
  }

  @Override
  public long getChildId(int groupPosition, int childPosition) {
   return childPosition;
  }

  @Override
  public boolean hasStableIds() {
   return true;
  }

  @Override
  public View getGroupView(int groupPosition, boolean isExpanded,
    View convertView, ViewGroup parent) {
   GroupHolder groupHolder = null;
   if (convertView == null) {
    convertView = (View) getLayoutInflater().from(context).inflate(
      R.layout.expendlist_group, null);
    groupHolder = new GroupHolder();
    groupHolder.txt = (TextView) convertView.findViewById(R.id.txt);
    // groupHolder.img = (ImageView) convertView
    // .findViewById(R.id.img);
    convertView.setTag(groupHolder);
   } else {
    groupHolder = (GroupHolder) convertView.getTag();
   }
   groupHolder.txt.setText(group_list.get(groupPosition));
   return convertView;
  }

  @Override
  public View getChildView(int groupPosition, int childPosition,
    boolean isLastChild, View convertView, ViewGroup parent) {
   ItemHolder itemHolder = null;
   if (convertView == null) {
    convertView = (View) getLayoutInflater().from(context).inflate(
      R.layout.expendlist_item, null);
    itemHolder = new ItemHolder();
    itemHolder.txt = (TextView) convertView.findViewById(R.id.txt);
    itemHolder.img = (ImageView) convertView.findViewById(R.id.img);
    convertView.setTag(itemHolder);
   } else {
    itemHolder = (ItemHolder) convertView.getTag();
   }
   itemHolder.txt.setText(item_list.get(groupPosition).get(
     childPosition));
   itemHolder.img.setBackgroundResource(item_list2.get(groupPosition).get(
     childPosition));
   return convertView;
  }

  @Override
  public boolean isChildSelectable(int groupPosition, int childPosition) {
   return true;
  }

 }

 class GroupHolder {
  public TextView txt;
  public ImageView img;
 }

 class ItemHolder {
  public ImageView img;
  public TextView txt;
 }
}

  我的博客的其他文章列表
  http://my.oschina.net/helu

转载于:https://my.oschina.net/helu/blog/141739

ExpandableListView实例(一)_数据库增删改查处理和listitem点击长按处理 本例说明: 1.实例中表现层与数据处理层分开,代码可复用性强,如果能看懂代码对算法会有提高. 2.组和子条目上"点击"事件处理,能够区分操作的是组还是子条目,并且得到组和子条目的内容. 3.组和子条目上"长按"事件处理,能够区分组和子条目,并且得到组和子条目的内容. 4.自定义条目样式,灵活与数据库中字段绑定. 5.实现对DB的增删改查,并且操作后自动刷新. 6.使用数据库处理框架AHibernate灵活操作sqlite数据库,详见: http://blog.csdn.net/lk_blog/article/details/7455992 ExpandableListView实例(二)_两种方式实现QQ中组后面显示子条目数量效果 本例说明: QQ,飞信等聊天工具中组后面后会显示有多少个子条目,这个是如何实现的呢?查阅了网上还没有相关的介绍,现在本文介绍两种方式实现此功能. 第一种方式:自定义Adapter,重写getGroupView方法. 第二种方式:自定义group.xml中的控件,加一个textview用于显示子条目个数. 注:本文数据库处理使用框架AHibernate,可以灵活操作sqlite数据库, 详见: http://blog.csdn.net/lk_blog/article/details/7455992 ExpandableListView实例(三)_实现QQ中"未分组"效果和"未分组"不可编辑删除功能 本例说明: 实现QQ中"未分组"效果和"未分组"不可编辑删除功能. 注:本文数据库处理使用框架AHibernate,可以灵活操作sqlite数据库, 详见: http://blog.csdn.net/lk_blog/article/details/7455992
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值