ExpandableListView实现展开更多和收起更多
【需求】:
如上面图示
当点开某个一级菜单的时候,其他菜单收起;
子级菜单默认最多5个;
多于5个的显示“展开更多”
点击“展开更多”,展开该级所有子级菜单,同时显示“收起更多”
【代码】:
@Bind(R.id.exp_listview)
ExpandableListView expListview;
adapter = new MyAdapter1(dataBeans);
expListview.setDividerHeight(0);
expListview.setChildDivider(null);
expListview.setGroupIndicator(null);//去掉ExpandableListView 默认的箭头
expListview.setOnGroupClickListener(new ExpandableListView.OnGroupClickListener() {
@Override
public boolean onGroupClick(ExpandableListView parent, View v, int groupPosition, long
id) {
return false;//默认为false,设为true时,点击事件不会展开Group
}
});
expListview.setOnGroupExpandListener(new ExpandableListView.OnGroupExpandListener() {
@Override
public void onGroupExpand(int groupPosition) {
adapter.setMaxIs5(true);
for (int i = 0; i < expListview.getCount(); i++) {
//expListview.expandGroup(i);
if (i != groupPosition) {
expListview.collapseGroup(i);//折叠其他
}
}
adapter.notifyDataSetChanged();
}
});
expListview.setOnGroupCollapseListener(new ExpandableListView.OnGroupCollapseListener() {
@Override
public void onGroupCollapse(int groupPosition) {
adapter.setMaxIs5(true);
}
});
expListview.setOnChildClickListener(new ExpandableListView.OnChildClickListener() {
@Override
public boolean onChildClick(ExpandableListView parent, View v, int groupPosition, int
childPosition, long id) {
return false;
}
});
expListview.setAdapter(adapter);
class MyAdapter1 extends BaseExpandableListAdapter { private List<Category.DataBean> dataBeans;
private boolean maxIs5=true;//子View最多5个
private View expand_more_view;//展开更多
private View collapse_more_view;//收起更多
// private View listviewItem;//
private boolean isExpandMore=false;
private boolean isCollapseMore=false; public void setMaxIs5(boolean maxIs5) {
this.maxIs5 = maxIs5;
} public MyAdapter1(List<Category.DataBean> dataBeans1) {
this.dataBeans = dataBeans1;
expand_more_view=UIUtils.getXmlView(R.layout.category_expand_more);
collapse_more_view=UIUtils.getXmlView(R.layout.category_collapse_more);
// listviewItem=UIUtils.getXmlView(R.layout.item_category_listview_item);
} @Override
public int getGroupCount() {
return dataBeans == null ? 0 : dataBeans.size();
} @Override
public int getChildrenCount(int groupPosition) {
int size = dataBeans.get(groupPosition).getSubs().size();
int size1=Math.min(size,5);
int size2=Math.max(size,size1);
if(maxIs5){
System.out.println("【getChildrenCount】:"+groupPosition+":"+size1);
return size1;
}else{
System.out.println("【getChildrenCount】:"+groupPosition+":"+size2);
return size2;
}
} @Override
public Object getGroup(int groupPosition) {
return dataBeans.get(groupPosition);
} @Override
public Object getChild(int groupPosition, int childPosition) {
System.out.println("【getChild】:groupPosition="+groupPosition+",childPosition="+childPosition);
return dataBeans.get(groupPosition).getSubs().get(childPosition);
} @Override
public long getGroupId(int groupPosition) {
System.out.println("【getGroupId】:"+groupPosition);
return groupPosition;
} @Override
public long getChildId(int groupPosition, int childPosition) {
System.out.println("【getChildId】:groupPosition="+groupPosition+",childPosition="+childPosition);
return childPosition;
} @Override
public boolean hasStableIds() {
//组和子元素是否持有稳定的ID,也就是底层数据的改变不会影响到它们。
return true;
} @Override
public View getGroupView(int groupPosition, boolean isExpanded, View convertView,
ViewGroup parent) {
if (convertView == null) {
convertView = UIUtils.getXmlView(R.layout.expand_header);
}
ImageView iv_category_item = (ImageView) convertView.findViewById(R.id
.iv_category_item);
x.image().bind(iv_category_item, dataBeans.get(groupPosition).getImg());
return convertView;
}
@Override
public View getChildView(int groupPosition, final int childPosition, boolean isLastChild, View
convertView, ViewGroup parent) {
System.out.println("【getChildView】:"+childPosition);
// if (convertView == null) {
// convertView = UIUtils.getXmlView(R.layout.expand_content);
// }
// ListView lv_category_item = (ListView) convertView.findViewById(R.id.lv_category_item);
// MyAdapter2 adapter = new MyAdapter2(dataBeans.get(groupPosition).getSubs());
// lv_category_item.setAdapter(adapter);
// if (convertView == null) {
// convertView = listviewItem;
convertView = UIUtils.getXmlView(R.layout.item_category_listview_item);
// convertView= LayoutInflater.from(getActivity()).inflate(R.layout.item_category_listview_item,parent,false);
// }
TextView tv_catename = (TextView) convertView.findViewById(R.id.tv_catename);
RelativeLayout rl_category= (RelativeLayout) convertView.findViewById(R.id.rl_category);
List<Category.DataBean.SubsBean> list=dataBeans.get(groupPosition).getSubs();
final Category.DataBean.SubsBean subsBean =list.get(childPosition);
tv_catename.setText(subsBean.getCate_name());
rl_category.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
UIUtils.toast("跳转到类别:" + subsBean.getCate_name() + ",【图片url】:" + subsBean
.getImg(), false);
// if (childPosition == 4) {
// maxIs5 = false;
// YouFanApplication.mHandler.post(new Runnable() {
// @Override
// public void run() {
// notifyDataSetChanged();
// }
// });
// }
}
});
//处理“展开更多”和“收起更多”
if(list.size()>5 && isLastChild){
final LinearLayout convertView1= (LinearLayout) convertView;
if(maxIs5){//添加展开更多布局
if(isExpandMore){
//convertView1.removeView(expand_more_view);
}
ViewGroup parent1 = (ViewGroup) expand_more_view.getParent();
if(parent1!=null){
parent1.removeAllViews();
}
convertView1.addView(expand_more_view);
//The specified child already has a parent. You must call removeView() on the child's parent first.
isExpandMore=true;
}else{//添加收起更多布局
if(isCollapseMore){
//convertView1.removeView(collapse_more_view);
}
ViewGroup parent2= (ViewGroup) collapse_more_view.getParent();
if(parent2!=null){
parent2.removeAllViews();
}
convertView1.addView(collapse_more_view);
isCollapseMore=true;
} /*-------------------------------------------------------------*/
expand_more_view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
convertView1.removeView(v);
//isCollapseMore=true;
//isExpandMore=false;
maxIs5 = false;
YouFanApplication.mHandler.post(new Runnable() {
@Override
public void run() {
notifyDataSetChanged();
}
});
}
});
/*-------------------------------------------------------------*/
collapse_more_view.setOnClickListener(new View.OnClickListener() {
@Override
public void onClick(View v) {
convertView1.removeView(v);
//isExpandMore=true;
maxIs5 = true;
YouFanApplication.mHandler.post(new Runnable() {
@Override
public void run() {
notifyDataSetChanged();
}
});
}
});
/*-------------------------------------------------------------*/
return convertView1;
} return convertView;
} @Override
public boolean isChildSelectable(int groupPosition, int childPosition) {
//是否选中指定位置上的子元素
return true;
}
}
ExpandableListView实现展开更多和收起更多的更多相关文章
- javascript 特效实现(1)——展开选项和收起效果
知识点:javascript事件:判断当前展开收起状态:延迟执行setTimeout方法. 1.简单的展开和收起效果: 1.1 静态结构HTML代码分析 body包含最外层的div id=" ...
- android之ExpandableListView 无法展开
1.Button 对,没错,就是这个button组件,不知道出现都少次过问题,很多都是它造成的! 最常见的问题:ExpandableListView无法展开,OnItemClickListener不响 ...
- WPF中TreeView单击展开其子元素以及点击一个元素展开其他元素收起
TreeView单击展开其子元素: 在WPF的TreeView控件中,要想展开它的子元素,我们必须要鼠标左键点两下或者右键点一下,那么我们怎样实现左键点一下就使它展开呢? Xaml: <Grid ...
- avalon.js 文字显示更多与收起
isShowMore: function (content) { if(content && content.length >= 124){ var shortContent = ...
- 点击更多button显示更多数据的功能实现思路代码
此功能是根据自己思路去慢慢做出来的,做的不够专业,希望有懂这个的前辈给自己指点指点. //分界线———————————————————————————————————————————————————— ...
- vue实现点击展开,点击收起
安装vue的步骤在这里就不进行赘述了,下面直接进入正题 首先定义一下data里面的数据: data () { return { toLearnList:[ 'html','css','javascri ...
- expandablelistView 可展开的列表
这个东西用法基本固定,不知道能不能做三级的展开. 界面代码 <?xml version="1.0" encoding="utf-8"?> <L ...
- 微信小程序——收起和查看更多功能
项目中做一些列表的时候,可能会需要做到 查看更多 及 收起功能,如下图所示: 大概的需求就是默认只显示2条,点击[查看更多]显示全部,点击[收起]还原. 实现的方法千万种.我来讲一下我的实现思路: 1 ...
- Android开发之仿微信显示更多文字的View
最近开发需求中要模仿微信朋友圈文章的展开收起功能,网上找了找,发现都有问题,于是乎自己在前辈的基础上进行了一定量的修改,下边将源码贴出来供大家参考:1.主Activity布局文件就不粘贴了,很简单,就 ...
随机推荐
- Pointer's NULL And 0
问题起源 在使用Qt框架的时候, 经常发现一些构造函数 *parent = 0 这样的代码. 时间长了, 就觉的疑惑了. 一个指针不是等于NULL吗? 这样写, 行得通吗? 自己测试一下就可以了. 测 ...
- Fig 应用编排
Fig是Docker的应用编排工具,主要用来跟 Docker 一起来构建基于 Docker 的复杂应用,Fig 通过一个配置文件来管理多个Docker容器,非常适合组合使用多个容器进行开发的场景. 说 ...
- Laravel 5.3 请求处理管道详解
对于一个Web应用来说,在一个请求真正处理前,我们可能会对请求做各种各样的判断,然后才允许后续处理. 我们通常的做法: Script 01.php Script 02.php 优点:直观,容易理解 缺 ...
- OpenCASCADE Camera
OpenCASCADE Camera eryar@163.com Abstract. OpenCASCADE introduce a new class Graphic3d_Camera for th ...
- 前端学PHP之面向对象系列第二篇——魔术方法
× 目录 [1]构造方法 [2]析构方法 [3]不可访问属性[4]对象复制[5]字符串[6]对象不存在[7]自动加载类[8]串行化[9]函数调用 前面的话 php在面向对象部分有很多相关的魔术方法,这 ...
- 创建第一个 local network(II)- 每天5分钟玩转 OpenStack(81)
上一节通过 Web GUI 创建了 “first_local_net”,本节我们需要搞清楚底层网络结构有了哪些变化? 点击 “first_local_net” 链接,显示 network 的 subn ...
- 使用jQuery封装实用函数
一.引言 项目开发中,前端会有一个辅助工具类的js文件,比如cookie的操作,团队成员自己封装的方法.大多数时候,我们开发人员自己都是写一个全局函数,不考虑后期维护人员也会写相同的代码,然后造成代码 ...
- C++中的内存管理
在C++中也是少不了对内存的管理,在C++中只要有new的地方,在写代码的时候都要想着delete. new分配的时堆内存,在函数结束的时候不会自动释放,如果不delete我分配的堆内存,则会造成内存 ...
- linux内核中的每cpu变量
一.linux中的每cpu变量 看linux内核代码的时候,会发现大量的per_cpu(name, cpu),get_cpu_var(name)等出现cpu字眼的语句.从语句的意思可以看出是要使用与当 ...
- 如何用Perl对Excel的数据进行提取并分析
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了一个表的数据量统计日报,主要是针对数据库中使用较频繁,数据量又较大的31张表.该日报有两个sheet组成,第一个sheet是数据填写,第二个sh ...