在上一篇Android ExpandableListView使用小结(一)的介绍中,我们学习了 ExpandableListView 的使用方法,学习了自定义适配器,为列表选项设置监听事件。想必大家都能熟练使用了,今天我要分享的是 ExpandableListView 的 Indicator(指示器)的使用。

在我们看来,Indicator 就是分组项前面的小箭头,回顾一下我们之前做的 Demo,并没有显式指定 Indicator 啊,怎么还会出现呢?原来系统自动为分组的左边加上了 Indicator,不用我们做任何操作。

系统默认的Indicator

有人可能觉得系统提供的 Indicator 难看,想换成自己喜欢的,这可怎么办?当然有办法啦,开源代码总是具有良好的扩展性,这里给出几种办法:

在 Drawable 中利用 XML 定义 Indicator 的状态选择器,然后设置 ExpandableListView 的 groupIndicator 属性,引用我们自定义的 Drawable。先看看我们的状态选择器部分,根据不同的状态分别定义分组展开和闭合的图标就 OK 了。

为 ExpandableListView 设置 Indicator,indicatorLeft 和 indicatorRight 是分别用来指定 Indicator 的左右边界的,这里我们把它放在分组项的左边。

android:id="@+id/expand_list"

android:layout_width="match_parent"

android:layout_height="match_parent"

android:groupIndicator="@drawable/group_indicator"

android:indicatorLeft="0dp"

android:indicatorRight="40dp"

/>

看一下运行效果,除了丑陋没有其他可说的T_T...

通过XML配置Indicator

通过 Java 代码获取自定义的 Drawable 对象,设置 ExpandableListView 的 Indicator,以及显示的位置,来看一下关键代码。

Display display = getWindowManager().getDefaultDisplay();

DisplayMetrics displayMetrics = new DisplayMetrics();

display.getMetrics(displayMetrics);

int widthPixels = displayMetrics.widthPixels;

Drawable drawable = getResources().getDrawable(R.drawable.group_indicator);

expandableListView.setGroupIndicator(drawable);

expandableListView.setIndicatorBounds(widthPixelsdrawable.getMinimumWidth() - 40, widthPixels - 40);

运行一下是这个样子的,它竟然跑到右边去了~~

通过Java代码设置Indicator

有人说了你这 Indicator 的图标长宽比例怎么这么丑呢?哎!谁让咱不是美工呢?美工的妹子在哪里? I need U~~咳咳...言归正传。看过源码才知道,官方是用状态数组记录了 Group 的状态,包括是否展开状态、是否为空以及两者的组合,每次绘制子布局的时候改变状态值。当然还有其他办法,我是这样做的:不管你怎么实现,我就要自己定义 Indicator,自己控制状态的转换。

首先,在分组项的 Item 布局里面加入 Indicator 的图标,就用一个简单的 ImageView 展示吧。

android:layout_width="match_parent"

android:layout_height="wrap_content"

android:background="@android:color/holo_blue_light"

android:orientation="horizontal"

android:padding="8dp">

android:id="@+id/label_expand_group"

android:layout_width="0dp"

android:layout_height="wrap_content"

android:layout_gravity="center_vertical"

android:layout_weight="1"

android:paddingLeft="20dp"

android:textColor="@android:color/white"

android:textSize="20sp"/>

android:id="@+id/iv_indicator"

android:layout_width="wrap_content"

android:layout_height="wrap_content"

android:layout_gravity="center_vertical"

android:src="@mipmap/ic_collapse"/>

然后呢,就是在我们自定义的 Adapter 里面操控了。定义一个 Map 集合存放 Indicator 的位置和图标,根据 Group 的状态动态改变 Indicator。

// 用于存放Indicator的集合

private SparseArray mIndicators;

// 根据分组的展开闭合状态设置指示器

public void setIndicatorState(int groupPosition, boolean isExpanded) {

if (isExpanded) {

mIndicators.get(groupPosition).setImageReource(R.mipmap.ic_expand);

} else {

mIndicators.get(groupPosition).setImageReource(R.mipmap.ic_collapse);

}

// 获取显示指定分组的视图

@Override

public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {

GroupViewHolder groupViewHolder;

if (convertView == null) {

convertView = LayoutInflater.from(MainActivity.this).inflate(R.layout.item_expand_group, false);

groupViewHolder = new GroupViewHolder();

groupViewHolder.ivIndicator = (ImagView)convertView.findViewById(R.id.iv_indicator);

groupViewHolder.tvTitle = (TextView)convertView.findViewByIdR.id.label_expand_group);

convertView.setTag(groupViewHolder);

} else {

groupViewHolder = (GroupViewHolder) convertView.getTag();

}

groupViewHolder.tvTitle.setText(groupStrings[groupPosition]);

// 把位置和图标添加到Map

mIndicators.put(groupPosition, groupViewHolder.ivIndicator);

// 根据分组状态设置Indicator

setIndicatorState(groupPosition, isExpanded);

return convertView;

}

最后,为 ExpandableListView 添加 Group 点击事件,当点击分组项的时候,改变 Indicator 的状态,就能实现我们想要的功能了。

// 设置分组单击监听事件

expandableListView.setOnGroupClickListener(new ExpandableListView.OnGroupClickListener() {

@Override

public boolean onGroupClick(ExpandableListView parent, View v, int groupPosition, long id) {

boolean groupExpanded = parent.isGroupExpanded(groupPosition);

if (groupExpanded) {

parent.collapseGroup(groupPosition);

} else {

parent.expandGroup(groupPosition, true);

}

adapter.setIndicatorState(groupPosition, groupExpanded);

return true;

}

});

我们看看效果怎么样,不用美工我也能做得好看一点了,聊表安慰 (^_^)v

我的Indicator我做主

好了,啰啰嗦嗦这么多,总算把效果做出来了,聊表欣慰。如果各位有什么问题,请评论留言就好,(~ o ~)~zZ

android expandablelistview横向,Android ExpandableListView使用小结(二)相关推荐

  1. android expandablelistview横向,Android ExpandableListView使用小结(一)

    ExpandableListView 是什么? 官方给出的解释是: A view that shows items in a vertically scrolling two-level list. ...

  2. android list 分组,Android 中使用ExpandableListView 实现分组的实例

    Android 中使用ExpandableListView 实现分组 一个视图显示垂直滚动两级列表中的条目.这不同于列表视图,允许两个层次,类似于QQ的好友分组.要实现这个效果的整体思路为: 1.要给 ...

  3. android 开发 电台,Android 开发自己的网络收音机3——电台分类(ExpandableListView)

    上一篇文章说了使用SlidingMenu开源项目实现侧滑栏,今天主要是讲解多级列表ExpandableListView的使用,以及如何使用它实现电台分类管理.ExpandableListView是An ...

  4. android二级列表展开,ExpandableListView控件实现二级列表

    效果图如下: 二级列表附有点击事件. 1.布局文件: 此处加了一个自定义的导航RelativeLayout,记得注activity的时候添加 android:theme="@style/Th ...

  5. Android UI控件----ExpandableListView的基本用法

    ExpandableListView介绍 ExpandableListView的引入 ExpandableListView可以显示一个视图垂直滚动显示两级列表中的条目,这不同于列表视图(ListVie ...

  6. CTS(14)---Android O CTS 测试之Media相关测试小结(二)

    Android O CTS 测试之Media相关测试小结(二) CtsMediaTestCases android.media.cts.VideoDecoderPerfTest failed fail ...

  7. android iphone treeview,Android之IphoneTreeView带组指示器的ExpandableListView效果

    之前实现过一次这种效果的ExpandableListView:https://www.jb51.net/article/38482.htm,带效果比较挫,最近,在参考联系人源码PinnedHeader ...

  8. android list 分组,安卓ExpandableListView实现多组列表,类似于QQ分组

    先直接上图, 1:.展开的效果图: 2:后面的是点击收缩的效果图. 3:下面就是代码部分: 我们要定义2个集合用来存储数据,一个是groupItem的数据,一个是childItem的数据 privat ...

  9. android listview 横向滚动,Android支持水平滚动的ListView控件

    前言 ListView是一个纵向滚动的列表视图,也有朋友嵌套HorizontalScrollView来实现,比如这里,但在ListView的API中明确指明了两者不可同时使用.本文分享一种办法,以方便 ...

最新文章

  1. 12306”的架构到底有多牛逼?
  2. 准程序员必看!该怎么规划自己的职业人生,看看前辈们给的建议!
  3. leetcode437. 路径总和 III
  4. Bailian2735 八进制到十进制【入门】(POJ NOI0113-46)
  5. sb3转换exe_SB转exe或swf(sb3toSB2.rar
  6. 苹果手机iOS系统如何降级 数据备份?
  7. msdia*.dll unregistered
  8. 布尔逻辑代数化简公式
  9. Python faker函数
  10. stm32寄存器版学习笔记06 输入捕获(ETR脉冲计数)
  11. 柯尼卡美能达C364e安装步骤(全)-柯美复印机如何装机-柯美C364e驱动安装-柯美复印机安装扫描
  12. Excel合并单元格排序
  13. 安装卸载Xftp时,遇到的1605和1628问题
  14. java初始化含十个数的数组_java初始化数组的方法
  15. R语言数据可视化 画并列条形图和堆叠条形图
  16. 前端基础 Web网页标准
  17. matlab绘制蜗牛圈圈图,Illustrator软件绘制七彩卡通蜗牛图片
  18. Irrlicht学习备忘录——5 UserInterface
  19. 算法的时间复杂度分析之O(logn)、O(nlogn)
  20. 用于射频功率放大器线性化的多查找表数字预失真

热门文章

  1. 无熟人难办事?—迪米特法则
  2. hdu 3635 Dragon Balls 并查集应用记录每个点的转移次数
  3. Selenium自动化测试IE
  4. [Asp.net]Uploadify上传大文件,Http error 500 解决方案
  5. 更换mysql-connector-java-6.0.5jar包后程序出现的两个异常及解决方法
  6. 【解决方案】SpringCloud项目优雅发版、部署
  7. 蚂蚁金服数据分析平台演进及数据分析方法应用.pdf(附PPT下载链接)
  8. NoSQL技术入门简介
  9. KBQA相关论文分类整理
  10. vuex commit 模块_分享一个Vuex的使用的新姿势