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>>>();  @Override
  public 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);
  }  /**
   * 列表内容按下
   */
  @Override
  public 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);
  }  /**
   * 二级标题按下
   */
  @Override
  public boolean setSelectedChild(int groupPosition, int childPosition,
      boolean shouldExpandGroup) {
    return super.setSelectedChild(groupPosition, childPosition,
        shouldExpandGroup);
  }  /**
   * 一级标题按下
   */
  @Override
  public 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); // 设置指示图标的位置

效果:

源码免费下载:

Listview列表收缩与展开——ExpandableListView相关推荐

  1. android仿qq折叠,android列表收缩与展开仿QQ好友列表(非常详细,附源码)

    好友QQ列表,可以展开,可以收起,在android中,以往用的比较多的是listview,虽然可以实现列表的展示,但在某些情况下,我们还是希望用到可以分组并实现收缩的列表,那就要用到android的E ...

  2. Android列表收缩与展开仿QQ好友列表(非常详细,附源码)

    林炳文Evankaka原创作品.转载请注明出处http://blog.csdn.net/evankaka ExpandableListView是一个垂直滚动显示两级列表项的视图,与ListView不同 ...

  3. php 列表收缩展示插件,可展开和收缩的jquery FAQ问答列表特效

    这是一款简单的jquery FAQ问答列表特效.该FAQ问答列表可以通过点击问题的标题来展开或收缩列表,它使用简单,方便实用. 使用方法 在页面中引入jquery. HTML结构 该FAQ问答列表采用 ...

  4. JS下拉列表动态收缩与展开

    提示:经过测试用起来效果非常好,只要你灵活地去修改以适用于自己的菜单列表,结果绝对满意,在没有自己写之前我也在网上查过许多,但是都是要么无法满足自动收缩和展开,要么就是定义复杂无法通过连接数据库批量定 ...

  5. 京东css3动画全屏海报_CSS3+HTML5+JS 实现一个块的收缩与展开动画效果

    最近在做项目时,发现CSS3中关于动画的技术,自己很少运用在项目中,平时一些列表块的收缩和展开动画效果,几乎都是使用 display 的 none 和 block,或者 visibility 的 hi ...

  6. WPF 项目开发入门(五)ListView列表组件 与 Expander组件

    WPF 项目开发入门(一) 安装运行 WPF 项目开发入门(二) WPF 页面布局 WPF 项目开发入门(三)WPF 窗体与页面 WPF 项目开发入门(四) MVVM 模式 与 TreeView树组件 ...

  7. Android精通:View与ViewGroup,LinearLayout线性布局,RelativeLayout相对布局,ListView列表组件...

    UI的描述 对于Android应用程序中,所有用户界面元素都是由View和ViewGroup对象构建的.View是绘制在屏幕上能与用户进行交互的一个对象.而对于ViewGroup来说,则是一个用于存放 ...

  8. 【Flutter】ListView 列表高级功能 ( ScrollController 上拉加载更多 )

    文章目录 一.ScrollController 上拉加载更多 二.ScrollController 使用流程 三.ScrollController 判定滑动到底部 四.完整代码示例 五.相关资源 一. ...

  9. php展开收缩bom表_WordPress实现文章内容收缩和展开功能

    我们经常在浏览有些网站的时候看到内容只展示部分内容,如果需要阅读全文的话需要点击内容按钮才可以展现全部内容.这样的好处就是不至于一次将文字页面全部打开,使得页面不至于一次加载太长.这个功能到底如何实现 ...

最新文章

  1. oracle exp导出分区表,【实验】【PARTITION】exp导出分区表数据
  2. 开课吧python小课值得么-领导想提拔你,从来看的不止努力!
  3. 树与二叉树的深度优先与广度优先算法(递归与非递归)
  4. HDU3415 Max Sum of Max-K-sub-sequence
  5. 从Exchange 通往Office 365系列(十二)发布Outlook Anywhere
  6. 阿里中间件——消息中间件Notify和MetaQ
  7. python中的isinstance()使用方法[探索2]
  8. 谈谈linux内核原理,谈谈Linux内核驱动的coding style
  9. android 内存泄漏分析工具,Android内存泄漏终极解决篇(上)
  10. javascript学习一、js的初步了解
  11. 删除60天之前的elasticsearch索引
  12. MAVEN处理本地jar包 ojdbc7 的spingboot配置
  13. 五笔拼音反查精灵 v6.69 绿色版
  14. Python初学者:输入若干个正整数,升序后输出
  15. Baker Tilly与RGL Forensics宣布合并
  16. CGMB 奔驰钥匙积分 以及 奔驰怪兽详细功能介绍 奔驰调表 奔驰擦空变数箱电脑等等
  17. 海康威视 0day_清华紫光原厂3D TLC颗粒初体验,海康威视C2000 PRO 2TB版体验
  18. kotlin-协程-lzf
  19. 将一个整数分解为质数的乘积
  20. adb命令查看应用权限赋予情况

热门文章

  1. STM32 GD32 影响ZI-DATA大小的选项use MicroLib
  2. 【文献调研】高性能脑电放大器(电极方向)
  3. Hdu 1533(KM算法)
  4. 9 概率图模型(三):推断
  5. vue 项目适配PC和移动端配置 (两套代码)
  6. 电源中W(瓦)和VA(伏安)的区别
  7. 光通信器件与系统(西交大朱京平笔记) -5-7 EDFA的主要参数
  8. 计算机三级数据库备考,2017年计算机三级数据库技术备考习题及答案
  9. 为什么dns解析失败?如何用花生壳修复dns解析失败?
  10. el-table 抖动问题(已解决)