QQ分组显示列表ExpandableListView组件应用源码
ExpandableListView又称为可扩展的ListView组件,他和ListView组件很相似
不过每行的显示有两个xml文件,一个xml文件用于定义分组列表的显示风格,
还有一个xml文件用于定义分组下面的列表显示风格。如要显示如下图所示的风格

可以用如下代码实现:
public class Friend_manage extends Activity {
private static final String GROUP_TEXT = "group_text";// 大组成员Map的key
private Relationshipdao instanceRelationshipdao;//该对象用于获取数据源(由于该类涉及到数据库的操作,故没有给出源代码)
private List<Map<String, String>> groupData = new ArrayList<Map<String, String>>();// 大组成员
private List<List<User>> childDatalist = new ArrayList<List<User>>();// 小组成员
ExAdapter adapter;//将数据绑定到ExpandableListView组件上
ExpandableListView exList;// 可扩展的ListView
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.friend_manage);
instanceRelationshipdao = DaoFactory
.getinstanceRelationshipdao(Friend_manage.this);
List<User> childrenlist = new ArrayList<User>();
List<Relationship> rel_user_id = null;
for (int j = 0; j < 4; j++) {
rel_user_id = instanceRelationshipdao.getrelationship(
Login.user.getId(), j);
childrenlist = getUserbyRelationship(rel_user_id);
childDatalist.add(childrenlist);
}
// 为大小组中添加数据
Map<String, String> curGroupMap1 = new HashMap<String, String>();
Map<String, String> curGroupMap2 = new HashMap<String, String>();
Map<String, String> curGroupMap3 = new HashMap<String, String>();
Map<String, String> curGroupMap4 = new HashMap<String, String>();
curGroupMap1.put(GROUP_TEXT, "朋友(" + childDatalist.get(0).size() + ")");
groupData.add(curGroupMap1);
curGroupMap2.put(GROUP_TEXT, "亲人(" + childDatalist.get(1).size() + ")");
groupData.add(curGroupMap2);
curGroupMap3.put(GROUP_TEXT, "同学(" + childDatalist.get(2).size() + ")");
groupData.add(curGroupMap3);
curGroupMap4
.put(GROUP_TEXT, "陌生人(" + childDatalist.get(3).size() + ")");
groupData.add(curGroupMap4);
adapter = new ExAdapter(Friend_manage.this, childDatalist, groupData);
exList = (ExpandableListView) findViewById(R.id.list);
exList.setAdapter(adapter);
exList.setOnChildClickListener(new ExpandableListView.OnChildClickListener() {
@Override
public boolean onChildClick(ExpandableListView parent, View v,
int groupPosition, int childPosition, long id) {
// TODO Auto-generated method stub
Bundle bundle=new Bundle();
bundle.putSerializable("user1", childDatalist.get(groupPosition).get(childPosition));
Intent intent=new Intent(Friend_manage.this, Friend_type_show.class);
intent.putExtras(bundle);
Friend_manage.this.startActivity(intent);
return false;
}
});
exList.setOnLongClickListener(new View.OnLongClickListener() {
@Override
public boolean onLongClick(View v) {
// TODO Auto-generated method stub
return false;
}
});
exList.setGroupIndicator(null);// 不设置大组指示器图标,因为我们自定义设置了
exList.setDivider(null);// 设置图片可拉伸的
}
// 根据List<Relationship>获取User表中的字段
public List<User> getUserbyRelationship(List<Relationship> rel_list) {
List<User> list = new ArrayList<User>();
Userdao instanceUserdao = DaoFactory
.getinstanceUserdao(Friend_manage.this);
if(rel_list!=null){
for (int i = 0; i < rel_list.size(); i++) {
list.add(instanceUserdao.getUserByid(rel_list.get(i).getUser_id()));
}
}
return list;
}
// 关键代码是这个可扩展的listView适配器
class ExAdapter extends BaseExpandableListAdapter {
private Context context;//该数据成员必不可少
//大小组的数据源可以自定义其数据类型,并不一定就是我这样
private List<List<User>> childdatalist;//小组列表的数据源
private List<Map<String, String>> groupData;//大组列表的数据源
public ExAdapter(Context context, List<List<User>> childdatalist,
List<Map<String, String>> groupData) {
super();
this.context = context;
this.childdatalist = childdatalist;
this.groupData = groupData;
}
// 得到大组成员的view
public View getGroupView(int groupPosition, boolean isExpanded,
View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
LayoutInflater inflater = (LayoutInflater) getSystemService(Context.LAYOUT_INFLATER_SERVICE);
view = inflater.inflate(R.layout.member_listview, null);//member_listview.xml文件用于定义GroupView的显示
}
TextView title = (TextView) view.findViewById(R.id.content_001);
title.setText(getGroup(groupPosition).toString());// 设置大组成员名称
ImageView image = (ImageView) view.findViewById(R.id.ImageView01);// 是否展开大组的箭头图标
if (isExpanded)// 大组展开时
image.setBackgroundResource(R.drawable.uyun_next_n);
else
// 大组合并时
image.setBackgroundResource(R.drawable.uyun_next_no);
return view;
}
// 得到大组成员的id
public long getGroupId(int groupPosition) {
return groupPosition;
}
// 得到大组成员名称
public Object getGroup(int groupPosition) {
return groupData.get(groupPosition).get(GROUP_TEXT).toString();
}
// 得到大组成员总数
public int getGroupCount() {
return groupData.size();
}
// 得到小组成员的view
public View getChildView(int groupPosition, int childPosition,
boolean isLastChild, View convertView, ViewGroup parent) {
View view = convertView;
if (view == null) {
LayoutInflater inflater = LayoutInflater.from(context);
view = inflater.inflate(R.layout.member_childitem, null);//member_childitem.xml文件定义小组列表的显示风格
}
final TextView title = (TextView) view
.findViewById(R.id.child_text);
title.setText(childdatalist.get(groupPosition).get(childPosition)
.getName());// 大标题
final TextView title2 = (TextView) view
.findViewById(R.id.child_text2);
title2.setText(childdatalist.get(groupPosition).get(childPosition)
.getInfo());// 小标题
final ImageView seximage=(ImageView)view.findViewById(R.id.child_image);
if("男".equals(childdatalist.get(groupPosition).get(childPosition).getSex())){
seximage.setBackgroundResource(R.drawable.friends_man);
}else{
seximage.setBackgroundResource(R.drawable.friends_woman);
}
return view;
}
// 得到小组成员id
public long getChildId(int groupPosition, int childPosition) {
return childPosition;
}
// 得到小组成员的名称
public Object getChild(int groupPosition, int childPosition) {
return childdatalist.get(groupPosition).get(childPosition);
}
// 得到小组成员的数量
public int getChildrenCount(int groupPosition) {
return childdatalist.get(groupPosition).size();
}
public boolean hasStableIds() {
return true;
}
// 得到小组成员是否被选择
public boolean isChildSelectable(int groupPosition, int childPosition) {
return true;
}
}
}
member_listview.xml文件用于定义GroupView的显示,代码如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_gravity="center_horizontal"
android:orientation="horizontal">
<ImageView
android:id="@+id/ImageView01"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:gravity="center_vertical"
android:paddingTop="10dp">
</ImageView>
<TextView
android:id="@+id/content_001"
android:layout_width="wrap_content"
android:layout_height="fill_parent"
android:layout_gravity="center_vertical"
android:gravity="center_vertical"
android:paddingLeft="10dp"
android:textColor="#ff0000"
android:textSize="30sp" >
</TextView>
</LinearLayout>
member_childitem.xml文件定义小组列表的显示风格,代码如下:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/childlayout"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="horizontal" > <ImageView
android:id="@+id/child_image"
android:layout_width="50dip"
android:layout_height="60dip"
android:layout_marginLeft="40dp"
android:background="@drawable/friends_man"
android:paddingTop="10dp" >
</ImageView> <LinearLayout
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:orientation="vertical" > <TextView
android:id="@+id/child_text"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:gravity="center_vertical"
android:text=""
android:textColor="#000000"
android:textSize="25sp" >
</TextView> <TextView
android:id="@+id/child_text2"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center_vertical"
android:gravity="center_vertical"
android:text=""
android:textColor="#000000"
android:textSize="20sp" >
</TextView>
</LinearLayout> </LinearLayout>
QQ分组显示列表ExpandableListView组件应用源码的更多相关文章
- 如何在Eclipse中查看Android源码或者第三方组件包源码
文章出处:http://blog.csdn.net/cjjky/article/details/6535426 在学习过程中如果经常阅读源码,理解程度会比较深,学习效率也会比较高,那么如何方便快捷的阅 ...
- Django 之 admin组件使用&源码解析
admin组件使用 Django 提供了基于 web 的管理工具. Django 自动管理工具是 django.contrib 的一部分.可以在项目的 settings.py 中的 INSTALLED ...
- .Net Core 认证组件之Cookie认证组件解析源码
接着上文.Net Core 认证系统源码解析,Cookie认证算是常用的认证模式,但是目前主流都是前后端分离,有点鸡肋但是,不考虑移动端的站点或者纯管理后台网站可以使用这种认证方式.注意:基于浏览器且 ...
- 基于微软企业库的AOP组件(含源码)
软件开发,离不开对日志的操作.日志可以帮助我们查找和检测问题,比较传统的日志是在方法执行前或后,手动调用日志代码保存.但自从AOP出现后,我们就可以避免这种繁琐但又必须要实现的方式.本文是在微软企业库 ...
- Spring源码系列(二)--bean组件的源码分析
简介 spring-bean 组件是 Spring IoC 的核心,我们可以使用它的 beanFactory 来获取所需的对象,对象的实例化.属性装配和初始化等都可以交给 spring 来管理. 本文 ...
- .Net Core缓存组件(Redis)源码解析
上一篇文章已经介绍了MemoryCache,MemoryCache存储的数据类型是Object,也说了Redis支持五中数据类型的存储,但是微软的Redis缓存组件只实现了Hash类型的存储.在分析源 ...
- .Net Core缓存组件(MemoryCache)源码解析
一.介绍 由于CPU从内存中读取数据的速度比从磁盘读取快几个数量级,并且存在内存中,减小了数据库访问的压力,所以缓存几乎每个项目都会用到.一般常用的有MemoryCache.Redis.MemoryC ...
- QQ群免IDKEY加群PHP源码
加群链接需要idkey的,该源码自动解析idkey,实现免idkey加群. 该源码来自彩虹秒赞系统. 例如:api.yum6.cn/qqun.php?qun=463631294 <?php /* ...
- iOS 未读消息角标 仿QQ拖拽 简单灵活 支持xib(源码)
一.效果 二.简单用法 超级简单,2行代码集成:xib可0代码集成,只需拖一个view关联LFBadge类即可 //一般view上加角标 _badge1 = [[LFBadge alloc] init ...
随机推荐
- spring缓存
Spring Cache使用详解 复制过来时的地址:http://blog.csdn.net/xiaoyu411502/article/details/48901555 标签: spring-bo ...
- 遇到IIS7配置PHP出现403和404错误的解决办法
服务器要配置PHP,总是出现403错误.服务器是新装的,操作系统是windows server 2008 R2,装的IIS7. IIS里PHP和本地服务器对比了好几遍,都没到出错的原因,后来通过cmd ...
- PHP正则表达式 /i, /is, /s, /isU等
PHP正则表达式 /i, /is, /s, /isU等 都是些什么东西呢? i 匹配大小写 s 模式中的圆点元字符(.)匹配所有的字符,包括换行符 x 模式中的空白字符除了被转义的或在字符类中的以外完 ...
- axure设置变量值
以登录框为例设置axure变量值 1.打开axure,打开新页面命名为login,拖入一个矩形背景,命名:登录背景图 2.拖入标签控件和输入框控件分别命名为用户名:.userName.密码:.pass ...
- 从多列的DataTable里取需要的几列(转)
方法一: 也是广为人知的一种: YourDataTable.Columns.Remove("列名"); 但是这种情况只适合于去掉很少列的情况. 如果有很多列我却只要一两列呢,那就得 ...
- Numpy 学习之路(1)——数组的创建
数组是Numpy操作的主要对象,也是python数据分析的主要对象,本系列文章是本人在学习Numpy中的笔记. 文章中以下都基于以下方式的numpy导入: import numpy as np fro ...
- Windows Desktop 调用 WinRT api
<Reference Include="Windows"> <HintPath>..\..\..\..\..\..\Program Files (x86)\ ...
- kiosk-mode,免密码登陆, sideload Windows Store apps 等
MVVM带来的性能问题及其解决方案 MVVM 和语言性能提示:https://msdn.microsoft.com/zh-cn/library/windows/apps/xaml/mt628050. ...
- json数据测试接口
json数据测试接口:http://www.xiaoqiang.org/tools/JsonView/?1348068433
- BZOJ2933: [Poi1999]地图
Description 一个人口统计办公室要绘制一张地图.由于技术的原因只能使用少量的颜色.两个有相同或相近人口的区域在地图应用相同的颜色.例如一种颜色k,则A(k) 是相应的数,则有: 在用颜色 ...