干货,仿qq列表,手把手实现分类悬浮提示

新来的产品提了一个需求,让应用中的一个列表按照分类显示,并且能提示当前是在哪个分类,度娘了一番,参考了前辈们的博客,实现了如下图的效果:

效果图.gif

这种效果的实现这里是采用自定义ExpandableListView,给它设置一个指示布局,在滑动过程中监听当前是否应该悬浮显示分类来实现的。今天抽时间,整理了下代码,记录一下使用过程,以便有类似的需求的时候可以快速搞定。 废话不多说,我们直接看代码和使用方法。

一 项目结构

项目结构.PNG

上边儿三个类分别是我们的自定义ExpandableListView,主界面,以及ExpandableListView使用的Adapter。下边儿几个xml文件分别是主界面布局,指示器布局,ExpandableListView子项布局,ExpandableListView组布局。

二 实现代码

1.在xml中声明自定义ExpandableListView

<test.com.expandablelistviewdemo.CustomExpandListview    //这里不唯一,看你具体把CustomExpandListview放在哪里
android:id="@+id/listView"    
android:layout_width="match_parent"    
android:layout_height="match_parent"></test.com.expandablelistviewdemo.CustomExpandListview>

2.声明数据源相关(这里为了演示,数据全是String类型,看具体需求可改变)

private String[] parentSource = {"分类1", "分类2", "分类3", "分类4", "分类5"};
private ArrayList<String> parent = new ArrayList<>();
private Map<String, ArrayList<String>> datas = new HashMap<>();

3.初始化演示数据

//种类
for (int i = 0; i < parentSource.length; i++) {    
parent.add(parentSource[i]);
}
//给每个种类添加模拟数据
for (int i = 0; i < parent.size(); i++) {    
String str = parent.get(i);    
ArrayList<String> temp = new ArrayList<>();    
for (int j = 0; j < 20; j++) {        
temp.add("" + j);    
}    
datas.put(str, temp);
}

4.初始化Adapter以及使用

myAdapter = new MyAdapter(this, parent, datas, listview);
listview.setAdapter(myAdapter);

在初始化adapter的时候,可以看到我们在构造方法中传入了上下文对象,种类,数据,以及我们的CustomExpandListview对象,所以在CustomExpandListview 中我们要添加相应的构造方法。

5.设置悬浮提示布局

listview.setHeaderView(getLayoutInflater().inflate(R.layout.indictor_layout, listview, false));

6.其他

默认全部展开

for (int i = 0; i < parent.size(); i++) {    
listview.expandGroup(i);
}

item点击事件

listview.setOnChildClickListener(new ExpandableListView.OnChildClickListener() {    
@Override    
public boolean onChildClick(ExpandableListView expandableListView, View view, int i, int i1, long l) {        
   Toast.makeText(MainActivity.this, "点击了第" + (i + 1) + " 类的第" + i1 + "项",    Toast.LENGTH_SHORT).show();        
   return true;    
   }
}
);

三 总结

从上边儿的步骤可以看出,使用CustomExpandListview实现图中的效果是非常容易的,这个demo的全部代码在https://github.com/SolveBugs/ExpandableListviewDemo , 欢迎下载,主要的实现在MyAdapter和CustomExpandListview中,都有非常清楚的注释。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Python数据科学

快速入门Matplotlib教程

Matplotlib 可能是 Python 2D-绘图领域使用最广泛的套件。它能让使用者很轻松地将数据图形化,并且提供多样化的输出格式。这里将会探索 matpl...

571
来自专栏游戏开发那些事

【Unity游戏开发】UGUI不规则区域点击的实现

  马三从上一家公司离职了,最近一直在出去面试,忙得很,所以这一篇博客拖到现在才写出来。马三在上家公司工作的时候,曾处理了一个UGUI不规则区域点击的问题,制作...

1203
来自专栏HTML5学堂

一步步教你弹性框架-中篇

HTML5学堂:本文继续为大家讲解弹性框架,在前一篇文章当中,我们实现了最基本的来回运动,在本文当中我们将基于前者,继续书写我们的代码。主要包括缓冲效果、有摩擦...

3364
来自专栏我和未来有约会

[Silverlight动画]转向行为 - 机车

机车类是转向角色的基类,但它不提供任何转向行为,只处理与运动相关的基本内容,如位置,速度,质量以 及角色接触场景边缘后的反应(反弹还是穿越出现在另一边)。转向机...

2016
来自专栏落影的专栏

Metal入门教程(五)视频渲染

Metal入门教程(一)图片绘制 Metal入门教程(二)三维变换 Metal入门教程(三)摄像头采集渲染 Metal入门教程(四)灰度计算

3174
来自专栏進无尽的文章

绘图-类似百度外卖波浪效果的实现与关键点解析

这是一个网上出过文章的例子,很多人都写过,但是大都是拷贝一个人作者的原文,这篇文章主要的目的是为了细致解析效果实现的关键点,以及提供有详细注释的Dome。给有需...

663
来自专栏UAI人工智能

RLLAB 入门

2053
来自专栏数据小魔方

创意雷达图(Round Rador Chart)

今天给大家分享的图表是创意雷达图! ▽▼▽ 既然是创意雷达图,肯定是有难度的啦,单纯的雷达图太没有挑战了! 首先看成品,怎么样,还不错吧,想不想自己也做一个,如...

4105
来自专栏图形学与OpenGL

实验1 OpenGL初识

Windows下的OpenGL编程步骤简单介绍详见课程实验教学博客-实验准备安装GLUT包与创建工程:

713
来自专栏我的博客

关于制作手机网页笔记

1、px和rem换算 em 的计算是基于父级元素的,在实际使用中给我们的计算带来了很大的不便 rem 的出现就可以避免这类计算的问题,再也不用担心父级元素的...

3418

扫码关注云+社区