林炳文Evankaka原创作品。转载请注明出处http://blog.csdn.net/evankaka

ExpandableListView是一个垂直滚动显示两级列表项的视图,与ListView不同的是,它可以有两层:每一层都能够被独立的展开并显示其子项。

好友QQ列表,可以展开,可以收起,在android中,以往用的比较多的是listview,虽然可以实现列表的展示,但在某些情况下,我们还是希望用到可以分组并实现收缩的列表,那就要用到android的ExpandableListView,今天研究了一下这个的用法,也参考了很多资料动手写了一个小demo,实现了基本的功能,下面直接上效果图以及源代码~!

本文效果:

效果一源码下载

效果二源码下载



目录:

一、实现原理

二、布局与代码

三、自定义图标

四、图标放置右边

一、实现原理

1,首先必须在布局文件中定义一个ExpandableListView

2,其次创建一级条目对应的布局文件group

3,创建二级条目对应的布局文件child

4,加载ExpandableListView组件的Activity必须继承自ExpandableListActivity

二、布局与代码

1、首先在主布局中activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="vertical" >    <ExpandableListView        android:id="@id/android:list"        android:layout_width="fill_parent"        android:layout_height="fill_parent" /></LinearLayout>

2、其次在drawable文件夹定义布局一级列表groups.xml

<LinearLayout    xmlns:android="http://schemas.android.com/apk/res/android"    android:orientation="vertical"    android:layout_width="fill_parent"    android:layout_height="fill_parent">    <TextView        android:id="@+id/textGroup"        android:layout_width="fill_parent"        android:layout_height="fill_parent"        android:paddingLeft="40px"        android:paddingTop="6px"        android:paddingBottom="6px"        android:textSize="25sp"        android:text="No data"    /></LinearLayout>

3、接着在drawable文件夹定义布局二级列表childs.xml

<LinearLayout    xmlns:android="http://schemas.android.com/apk/res/android"  android:orientation="vertical"    android:layout_width="fill_parent"    android:layout_height="fill_parent">    <TextView         android:id="@+id/textChild"   android:layout_width="fill_parent"        android:layout_height="fill_parent"        android:paddingLeft="60px"        android:paddingTop="10px"        android:paddingBottom="10px"        android:textSize="20sp"   android:text="No Data"/></LinearLayout>

4、然后就是初始化和使用了

package com.example.expandablelistview;import java.util.ArrayList;import java.util.HashMap;import java.util.List;import java.util.Map;import android.os.Bundle;import android.app.ExpandableListActivity;import android.util.DisplayMetrics;import android.view.View;import android.widget.ExpandableListView;import android.widget.SimpleExpandableListAdapter;import android.widget.Toast;public class MainActivity extends ExpandableListActivity {/** * 创建一级条目容器 */List<Map<String, String>> gruops = new ArrayList<Map<String, String>>();/** * 存放内容, 以便显示在列表中 */List<List<Map<String, String>>> childs = new ArrayList<List<Map<String, String>>>();@Overridepublic void onCreate(Bundle savedInstanceState) {super.onCreate(savedInstanceState);setContentView(R.layout.activity_main);setListData();}/** * 设置列表内容 */public void setListData() {// 创建二个一级条目标题Map<String, String> title_1 = new HashMap<String, String>();Map<String, String> title_2 = new HashMap<String, String>();Map<String, String> title_3 = new HashMap<String, String>();title_1.put("group", "林炳文");title_2.put("group", "文炳林");gruops.add(title_1);gruops.add(title_2);// 创建二级条目内容// 内容一Map<String, String> title_1_content_1 = new HashMap<String, String>();Map<String, String> title_1_content_2 = new HashMap<String, String>();Map<String, String> title_1_content_3 = new HashMap<String, String>();title_1_content_1.put("child", "工人");title_1_content_2.put("child", "学生");title_1_content_3.put("child", "农民");List<Map<String, String>> childs_1 = new ArrayList<Map<String, String>>();childs_1.add(title_1_content_1);childs_1.add(title_1_content_2);childs_1.add(title_1_content_3);// 内容二Map<String, String> title_2_content_1 = new HashMap<String, String>();Map<String, String> title_2_content_2 = new HashMap<String, String>();Map<String, String> title_2_content_3 = new HashMap<String, String>();title_2_content_1.put("child", "猩猩");title_2_content_2.put("child", "老虎");title_2_content_3.put("child", "狮子");List<Map<String, String>> childs_2 = new ArrayList<Map<String, String>>();childs_2.add(title_2_content_1);childs_2.add(title_2_content_2);childs_2.add(title_2_content_3);childs.add(childs_1);childs.add(childs_2);/** * 创建ExpandableList的Adapter容器 参数: 1.上下文 2.一级集合 3.一级样式文件 4. 一级条目键值 * 5.一级显示控件名 6. 二级集合 7. 二级样式 8.二级条目键值 9.二级显示控件名 *  */SimpleExpandableListAdapter sela = new SimpleExpandableListAdapter(this, gruops, R.drawable.groups, new String[] { "group" },new int[] { R.id.textGroup }, childs, R.drawable.childs,new String[] { "child" }, new int[] { R.id.textChild });// 加入列表setListAdapter(sela);}/** * 列表内容按下 */@Overridepublic boolean onChildClick(ExpandableListView parent, View v,int groupPosition, int childPosition, long id) {Toast.makeText(MainActivity.this,"您选择了"+ gruops.get(groupPosition).toString()+ "子编号"+ childs.get(groupPosition).get(childPosition).toString(), Toast.LENGTH_SHORT).show();return super.onChildClick(parent, v, groupPosition, childPosition, id);}/** * 二级标题按下 */@Overridepublic boolean setSelectedChild(int groupPosition, int childPosition,boolean shouldExpandGroup) {return super.setSelectedChild(groupPosition, childPosition,shouldExpandGroup);}/** * 一级标题按下 */@Overridepublic void setSelectedGroup(int groupPosition) {super.setSelectedGroup(groupPosition);}}

5、效果

这是我手机上的效果,点击工人。学生等二级列表时,我手机上会有提示框出现的,但是不知为什么录制下来就是没有。

源码免费下载

三、自定义列表图标

上面的图标是系统自己生成的,下面我们要改成自己的

1、更改自定义图标

在drawable文件夹下新建expandablelistview_change.xml

<?xml version = "1.0"   encoding = "utf-8"?><selector   xmlns:android = "http://schemas.android.com/apk/res/android" >           <item android:state_expanded = "true"   android:drawable = "@drawable/w2"/>           <item android:drawable = "@drawable/w1"/>      </selector > 


2、修改上面布局Activity.main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"    android:layout_width="fill_parent"    android:layout_height="fill_parent"    android:orientation="vertical" >    <ExpandableListView        android:id="@id/android:list"        android:layout_width="fill_parent"        android:layout_height="fill_parent"        android:background="#f5f5f5"        android:cacheColorHint="#f5f5f5"        android:groupIndicator="@drawable/expandablelistview_change" /></LinearLayout>

其实就是加了一句

android:groupIndicator="@drawable/expandablelistview_change"

下面我们再来看看效果:


源码免费下载

四、图标放置右边

在上面MainActivity.java的函数setListData()加中:

// 得到屏幕的大小DisplayMetrics dm = new DisplayMetrics();getWindowManager().getDefaultDisplay().getMetrics(dm);//图标设置在右边getExpandableListView().setIndicatorBounds(dm.widthPixels-60, dm.widthPixels); // 设置指示图标的位置

效果:


源码免费下载:


更多相关文章

  1. 自定义 Android(安卓)对话框 (AlertDialog) 的样式
  2. Android(安卓)5.0 Activity切换动画
  3. Android布局文件xml
  4. Android(安卓)最佳实践
  5. android listview 详解 开发指南
  6. Android输入框布局如何随键盘变化
  7. [置顶] Android性能优化-布局优化
  8. Android界面开发之盘点所有Dialog对话框大合集(一)
  9. Android(安卓)ApiDemos示例解析(2): SimpleAdapter,ListActivity

随机推荐

  1. 安卓巴士Android开发神贴整理
  2. android traceview and dmtracedump使用
  3. Android(安卓)布局
  4. Android(安卓)UI大杂烩
  5. Android(安卓)TextView背景色、圆角、内
  6. Android(安卓)获取地理位置的经度和纬度
  7. 设置行距
  8. Dealing with dependencies in Android(
  9. android 动作处理之手势捕捉
  10. Android(安卓)JNI环境搭建及开发入门