欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  移动技术

Android实现qq列表式的分类悬浮提示

程序员文章站 2024-03-06 20:38:08
效果图: 这种效果的实现这里是采用自定义expandablelistview,给它设置一个指示布局,在滑动过程中监听当前是否应该悬浮显示分类来实现的。今天抽时间,整理...

效果图:

Android实现qq列表式的分类悬浮提示

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

话不多说,我们直接看代码和使用方法。

一 项目结构

Android实现qq列表式的分类悬浮提示

上边儿三个类分别是我们的自定义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实现图中的效果是非常容易的,以上就是这篇文章的全部内容,希望对大家的学习或工作带来一定的帮助,如果有疑问可以留言交流。