林炳文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" ><ExpandableListViewandroid:id="@id/android:list"android:layout_width="fill_parent"android:layout_height="fill_parent" /></LinearLayout>

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

<LinearLayoutxmlns:android="http://schemas.android.com/apk/res/android"android:orientation="vertical"android:layout_width="fill_parent"android:layout_height="fill_parent"
><TextViewandroid: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

<LinearLayoutxmlns: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" ><ExpandableListViewandroid: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); // 设置指示图标的位置

效果:

源码免费下载:

Android列表收缩与展开仿QQ好友列表(非常详细,附源码)相关推荐

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

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

  2. iOS之仿QQ好友列表展开收缩效果的实现

    使用UICollectionView实现 思路 很明显整体它是一个列表,它的分组是一个列表,它里面的好友列表也是一个列表,所以就可以使用组头来设置分组列表,使用cell设置好友列表: 当点击组头的时候 ...

  3. html仿qq最小化怎么实现,JS仿QQ好友列表展开、收缩功能(第一篇)

    JS仿QQ好友列表展开.收缩功能(第一篇) 发布时间:2020-10-17 14:20:03 来源:脚本之家 阅读:96 作者:erdouzhang 效果图如下所示: html: 我的好友 张三 李四 ...

  4. qq列表展开多个html代码,JS仿QQ好友列表展开、收缩功能(第二篇)

    在上篇的基础上继续完善,点击一个li元素,其他li元素上的类名清除掉. 效果图如下所示: js: window.onload = function(){ var list = document.get ...

  5. android 仿qq好友动态,Android UI仿QQ好友列表分组悬浮效果

    本文实例为大家分享了Android UI仿QQ好友列表分组悬浮效果的具体代码,供大家参考,具体内容如下 楼主是在平板上測试的.图片略微有点大,大家看看效果就好 接下来贴源代码: PinnedHeade ...

  6. android 仿qq好友列表分组效果及联系人分组效果

     历史记录仿QQ好友列表的动态效果 以及联系人的分组效果 QQ朋友分组的功能做的不错,大家都很认可,那么到底他的分组并且滑动的时候,标题能停留在顶部是如何实现的呢?今天从网上搜索了一下资料,自己运行了 ...

  7. 仿QQ好友列表,QListWidget!

    仿QQ好友列表, 设计逻辑: 设计qqItem类,再添加到widget中: 设计时布局等可以直接在ui中设计:内容设计通过代码实现: qqItem.cpp #include "qqitem. ...

  8. android+仿iphone,Android编程实现仿iphone抖动效果的方法(附源码)

    Android编程实现仿iphone抖动效果的方法(附源码) 时间:2021-05-20 本文实例讲述了Android编程实现仿iphone抖动效果的方法.分享给大家供大家参考,具体如下: 布局文件: ...

  9. PHP仿QQ实时在线聊天1.0源码

    源码说明 1.实现实时在线聊天 2.自适应手机PC端 演示图 使用方式 1.上传源码后解压 2.将 data.sql 数据文件导入数据库 3.修改根目录下 data.php 文件里的数据库连接信息 下 ...

最新文章

  1. 三十六亿的《哪吒》历时五年,如何用AI解决动画创作难题?
  2. Kafka 客户端实现逻辑分析
  3. windows phone 8 的新特性
  4. 怎么把数据文件上传云服务器,怎么把数据上传导云服务器
  5. 【POJ - 1486】Sorting Slides(思维建图,二分图求必须边,关建边,图论)
  6. python改变turtle画笔方向的函数_哪个选项不能改变turtle画笔的运行方向?
  7. windows datacenter 2012 R2 密钥
  8. 风尚云网学习-h5的input:type属性的image属性
  9. 阿里云域名购买和域名解析教程
  10. C语言学习中遇到的问题和解决方法
  11. Red Giant Universe 3中文版
  12. 机器学习笔试题精选(六)
  13. FPGA 基础知识(亚稳态、流水线、时序约束、信号同步、时钟等)
  14. Problem A: 零起点学算法93——矩阵转置
  15. codeforces 1238
  16. 在服务器系统Windows 2003安装Avira AntiVir小红伞免费中文版
  17. 机械臂速成小指南(九):正运动学分析
  18. 手动拆解一个block
  19. UDP IPv4广播地址计算(附Node.js示例代码)
  20. 球状空心介孔硫化铋/二氧化硅纳米微球/全无机铯铅卤化物钙钛矿纳米晶修饰二氧化硅微球相关制备

热门文章

  1. 精品微信小程序二手汽车拍卖系统+后台管理系统|前后分离VUE
  2. 以太坊创始人V神:放弃对币价的关注,应专注于技术
  3. 东北大学OJ-1533: 实验2-8:程序改错
  4. tim trgo 的使用方法
  5. 加速清洁能源时代到来,芯讯通助力智能电网建设
  6. 小学科学新课标中的创客实践教育
  7. MES系统看板管理,助力企业实现车间可视化!
  8. 浅谈Bootstrap
  9. 药物磷钼钨杂多酸修饰MOF-5|Bio-MOF-11装载MTX甲氨蝶呤|COF-105装载姜黄素
  10. 因程序员开发速度太慢,公司索赔90万败诉后不服申请再审,法院判了