模拟QQ分组(具有伸缩功能) (添加开源框架的光闪烁效果)SimpleExpandableListAdapter 适配器的用法,并且可添加组及其组内数据。
package com.lixu.qqfenzu; import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map; import com.facebook.shimmer.ShimmerFrameLayout;
import com.romainpiel.shimmer.Shimmer;
import com.romainpiel.shimmer.ShimmerTextView; import android.app.Activity;
import android.content.Context;
import android.graphics.Color;
import android.os.Bundle;
import android.view.LayoutInflater;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.Button;
import android.widget.EditText;
import android.widget.ExpandableListView;
import android.widget.ExpandableListView.OnGroupClickListener;
import android.widget.SimpleExpandableListAdapter;
import android.widget.TextView;
import android.widget.Toast; public class MainActivity extends Activity {
private ArrayList<HashMap<String, Object>> date;
private final String GROUP = "group";
private final String CHILD = "child";
EditText et;
MyExpandableListAdapter mExpandableListAdapter = null; @Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main); Button btn1 = (Button) findViewById(R.id.btn);
Button btn2 = (Button) findViewById(R.id.btn1);
et = (EditText) findViewById(R.id.et); ExpandableListView elv = (ExpandableListView) findViewById(R.id.elv); btn1.setOnClickListener(new OnClickListener() { @Override
public void onClick(View v) {
addGroup(2);
Toast.makeText(getApplicationContext(), "添加成功!", 0).show();
}
});
btn2.setOnClickListener(new OnClickListener() { @Override
public void onClick(View v) {
addChild(1);
Toast.makeText(getApplicationContext(), "添加成功!", 0).show();
}
}); String[] group = { "家人", "朋友", "同事", "同学" };
String[] name = { "张三", "李四", "王五", "狗儿" }; date = new ArrayList<HashMap<String, Object>>(); for (String n : group) {
HashMap<String, Object> map = new HashMap<String, Object>(); map.put(GROUP, n); ArrayList<String> child = new ArrayList<String>();
for (String n1 : name) {
child.add(n1);
} map.put(CHILD, child);
date.add(map); } mExpandableListAdapter = new MyExpandableListAdapter(this, null, 0, 0, null, null, null, 0, 0, null, null);
elv.setAdapter(mExpandableListAdapter);
// 去掉下拉小箭头
elv.setGroupIndicator(null); // 展开0组
// elv.expandGroup(0);
// 收起1组
// elv.collapseGroup(1);
// 展开2组
// elv.expandGroup(2); elv.setOnGroupClickListener(new OnGroupClickListener() { @Override
public boolean onGroupClick(ExpandableListView arg0, View arg1, int arg2, long arg3) {
return false;
}
});
} // 增加组
public void addGroup(int pos) {
String str = et.getText().toString(); HashMap<String, Object> map = new HashMap<String, Object>(); map.put(GROUP, str); ArrayList<String> child = new ArrayList<String>(); map.put(CHILD, child);
date.add(pos, map); mExpandableListAdapter.notifyDataSetChanged();
et.setText(""); } // 增加特定组内数据
public void addChild(int pos) {
String str = et.getText().toString();
// 往第2组内添加数据
HashMap<String, Object> map = date.get(1);
ArrayList<String> list = (ArrayList<String>) map.get(CHILD);
list.add(pos, str); mExpandableListAdapter.notifyDataSetChanged();
et.setText(""); } private class MyExpandableListAdapter extends SimpleExpandableListAdapter {
private LayoutInflater flater = null; public MyExpandableListAdapter(Context context, List<? extends Map<String, ?>> groupData,
int expandedGroupLayout, int collapsedGroupLayout, String[] groupFrom, int[] groupTo,
List<? extends List<? extends Map<String, ?>>> childData, int childLayout, int lastChildLayout,
String[] childFrom, int[] childTo) {
super(context, groupData, expandedGroupLayout, collapsedGroupLayout, groupFrom, groupTo, childData,
childLayout, lastChildLayout, childFrom, childTo);
flater = LayoutInflater.from(context);
} @Override
public View getChildView(int groupPosition, int childPosition, boolean isLastChild, View convertView,
ViewGroup parent) {
if (convertView == null)
convertView = flater.inflate(R.layout.list, null); ShimmerFrameLayout sfl = (ShimmerFrameLayout) convertView.findViewById(R.id.sfl); sfl.setDuration(2000);
sfl.startShimmerAnimation();
TextView tv = (TextView) convertView.findViewById(R.id.tv);
tv.setText(getChild(groupPosition, childPosition) + "");
tv.setTextSize(20); return convertView;
} @Override
public int getChildrenCount(int groupPosition) { ArrayList<String> items = (ArrayList<String>) date.get(groupPosition).get(CHILD);
return items.size();
} @Override
public int getGroupCount() {
return date.size();
} @Override
public Object getChild(int groupPosition, int childPosition) {
ArrayList<String> items = (ArrayList<String>) date.get(groupPosition).get(CHILD);
return items.get(childPosition);
} @Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView, ViewGroup parent) {
if (convertView == null)
convertView = flater.inflate(R.layout.list2, null); ShimmerTextView stv = (ShimmerTextView) convertView.findViewById(R.id.stv1);
stv.setText(getGroup(groupPosition).toString());
stv.setTextColor(Color.BLUE);
stv.setTextSize(30);
stv.setBackgroundColor(Color.YELLOW);
Shimmer shimmer = new Shimmer();
shimmer.setDuration(2500);
shimmer.start(stv); return convertView; } @Override
public Object getGroup(int groupPosition) {
HashMap<String, Object> items = date.get(groupPosition);
return items.get(GROUP) + "";
} } }
xml文件:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/LinearLayout1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
tools:context="com.lixu.qqfenzu.MainActivity" > <ExpandableListView
android:id="@+id/elv"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:layout_weight="2" /> <LinearLayout
android:id="@+id/linearLayout1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" > <EditText
android:id="@+id/et"
android:layout_width="100dp"
android:layout_height="wrap_content" >
</EditText> <Button
android:id="@+id/btn1"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignParentRight="true"
android:layout_alignTop="@+id/linearLayout1"
android:text="添加内容" /> <Button
android:id="@+id/btn"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_alignBaseline="@+id/btn1"
android:layout_alignBottom="@+id/btn1"
android:layout_toLeftOf="@+id/btn1"
android:text="添加组" />
</LinearLayout> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <com.facebook.shimmer.ShimmerFrameLayout
android:id="@+id/sfl"
android:layout_width="wrap_content"
android:layout_height="wrap_content" > <TextView
android:id="@+id/tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content" />
</com.facebook.shimmer.ShimmerFrameLayout> </LinearLayout>
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical" > <com.romainpiel.shimmer.ShimmerTextView
android:id="@+id/stv1"
android:layout_width="wrap_content"
android:layout_height="wrap_content" >
</com.romainpiel.shimmer.ShimmerTextView> </LinearLayout>
运行效果:

模拟QQ分组(具有伸缩功能) (添加开源框架的光闪烁效果)SimpleExpandableListAdapter 适配器的用法,并且可添加组及其组内数据。的更多相关文章
- 模拟QQ系统设置面板实现功能
业务需求: 基于网盘客户端的实现,原有网盘的设置面板无论从界面显示还是从业务需求都不能满足我们的正常需求.当前的要求是,模拟QQ系统设置的面板实现当前我们网盘中的基本配置功能.在完成这篇文章时已将基本 ...
- 模拟QQ分组
package com.lixu.fenzu; import java.util.ArrayList; import java.util.HashMap; import android.app.Lis ...
- Farseer.net轻量级开源框架 入门篇:添加数据详解
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 分类逻辑层 下一篇:Farseer.net轻量级开源框架 入门篇: 修改数据详解 ...
- Farseer.net轻量级ORM开源框架说明及链接索引
项目简介 基于.net framework 4 开发. 基于Lambda表达式快速上手的ORM框架. 参考Entity Framework的调用方式. 基于Database First模式. POCO ...
- Farseer.net轻量级开源框架 入门篇:分类逻辑层
导航 目 录:Farseer.net轻量级开源框架 目录 上一篇:Farseer.net轻量级开源框架 入门篇: 缓存逻辑层 下一篇:Farseer.net轻量级开源框架 入门篇: 添加数据详解 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射 下一篇:Farseer.net轻量级ORM开源 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:存储过程实体类映射 下一篇:Farseer.net轻量级ORM ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:视图实体类映射
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作 下一篇:Farseer.net轻量级ORM开源框 ...
- Farseer.net轻量级ORM开源框架 V1.x 入门篇:表的数据操作
导航 目 录:Farseer.net轻量级ORM开源框架 目录 上一篇:Farseer.net轻量级ORM开源框架 V1.x 入门篇:表实体类映射 下一篇:Farseer.net轻量级ORM开源框 ...
随机推荐
- 常用模块之hashlib,subprocess,logging,re,collections
hashlib 什么是hashlib 什么叫hash:hash是一种算法(3.x里代替了md5模块和sha模块,主要提供 SHA1, SHA224, SHA256, SHA384, SHA512 ,M ...
- E: could not get lock /var/lib/dpkg/lock-frontend - open (11: Resource temporary unavailable) E: Unable to acquire the dpkg frontend lock (/var/lib/dpkg/lock-frontend), is an other process using it
1. 问题详细提示如下: E: Could not get lock /var/lib/dpkg/lock-frontend - open (11: Resource temporarly unava ...
- 51nod 1082 与7无关的数
暴力 打表过的 注意爆int 还有 7的倍数 和 数字中有7的 #include<bits/stdc++.h> using namespace std; typedef long long ...
- 总结java中的super和this关键字
知识点: 在java类中使用super引用父类的成分,用this引用当前对象 this可以修饰属性.构造器.方法 super可以修饰属性.构造器.方法 关于子类实例化过程中的内存分配,在下一篇博客中说 ...
- 论文笔记之:Human-level control through deep reinforcement learning
Human-level control through deep reinforcement learning Nature 2015 Google DeepMind Abstract RL 理论 在 ...
- VS2010下创建WEBSERVICE,第二天 ----你会在C#的类库中添加web service引用吗?
本文并不是什么高深的文章,只是VS2008应用中的一小部分,但小部分你不一定会,要不你试试: 本人对于分布式开发应用的并不多,这次正好有一个项目要应用web service,我的开发环境是vs2008 ...
- 前端验证用户登陆状态(vue.js)
首先用户需要进行登陆(请求登陆接口),接口请求成功之后后台会返回对应的用户信息(可以把用户信息存放在浏览器缓存中),并且后台会设置浏览器的cookie值(可以在network->header-& ...
- vscode中使用EF脚手架生成数据库上下文(scaffold-dbcontext)
目前在vscode上用netcore + ef core,在用dbfirst的方式生成模型和context上下文一直没有找到方法,之前在vs2017中,的nuget管理控制台输入命令: Scaffol ...
- WPF基础学习笔记整理 (五) DependencyObject & DependencyProperty
参考资料: 1.http://www.cnblogs.com/Zhouyongh/archive/2009/10/20/1586278.html 基础知识: DependencyObject & ...
- Jquery实现光棒效果
<script type="text/javascript"> $(function () { var $bac; $("#d1 tr").hove ...