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

 更新时间:2016年09月08日 11:02:56   作者:甄某某某某  
工作中遇到了一个需求,让应用中的一个列表按照分类显示,并且能提示当前是在哪个分类,度娘了一番,参考了前辈们的博客后实现了,现在分享给大家,有需要的可以参考借鉴。

效果图:

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

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

一 项目结构


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

相关文章

  • Android自定义指示器时间轴效果实例代码详解

    Android自定义指示器时间轴效果实例代码详解

    指示器时间轴在外卖、购物类的APP里会经常用到,效果大家都知道的差不多吧,下面小编通过实例代码给大家分享Android自定义指示器时间轴效果,需要的朋友参考下吧
    2017-12-12
  • Android仿微信录制小视频

    Android仿微信录制小视频

    这篇文章主要为大家详细介绍了Android仿微信录制小视频,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-05-05
  • 简单仿写Android控件SlidingMenu的实例代码

    简单仿写Android控件SlidingMenu的实例代码

    下面小编就为大家分享一篇简单仿写Android控件SlidingMenu的实例代码,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Android 详解Studio引用Library与导入jar

    Android 详解Studio引用Library与导入jar

    这篇文章主要介绍了Android Studio引用Library与导入jar的相关资料,需要的朋友可以参考下
    2017-01-01
  • Android仿微信和QQ多图合并框架(类似群头像)的实现方法

    Android仿微信和QQ多图合并框架(类似群头像)的实现方法

    这篇文章主要给大家介绍了关于Android仿微信和QQ多图合并框架的相关资料,其实就是我们平时所见的群聊头像,文中通过示例代码介绍的非常详细,对各位Android开发者们具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧。
    2017-12-12
  • Android使用LinearLayout设置边框

    Android使用LinearLayout设置边框

    这篇文章主要介绍了Android如何使用LinearLayout设置边框,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-09-09
  • Android自定义View的实现方法实例详解

    Android自定义View的实现方法实例详解

    本文通过实例代码给大家详细介绍了Android自定义View的实现方法,需要的朋友可以参考下
    2017-09-09
  • Android View移动的3种方式总结

    Android View移动的3种方式总结

    这篇文章主要给大家介绍了Android View移动的三种方式,在介绍这三种方式之前先介绍了Android坐标系的定义规则以及View的一些位置参数。有需要的朋友们可以参考借鉴。
    2016-09-09
  • android监听返回按钮事件的方法

    android监听返回按钮事件的方法

    这篇文章主要介绍了android监听返回按钮事件的方法,涉及Android事件监听的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-10-10
  • Android Studio使用教程(二):基本设置与运行

    Android Studio使用教程(二):基本设置与运行

    这篇文章主要介绍了Android Studio使用教程(二):基本设置与运行,本文讲解了项目结构、偏好设置、常用功能介绍、创建模拟器等内容,需要的朋友可以参考下
    2015-05-05

最新评论