一个页面两个或者多个listview(ExpandableLis

2017-07-18  本文已影响0人  母老虎饲养员

首先改变一下自己一成不变的android思想,所谓条条大路通罗马,在确定需求的前提下,我们需要考虑好自己的最优布局,怎样实现最简单,UI渲染的效率最高,那我们就确定怎样的布局;

下图这个布局要求名称这一竖列在左右滑动的时候固定,从“最新”开始可以往左滑动,并且沪铝1,2,3....是沪铝连续的子view;

我最开始考虑的布局是使用一个ExpandableListView,同时标题(名称,最新。。)为一个自定义的HorizontalScrollView,滑动的时候可以和ExpandableListView联动,效果是实现了,但是由于ExpandableListView的每一个item都是一个自定义的HorizontalScrollView布局,每次滑动便是屏幕上所显示的所有item,也就是一屏幕的HorizontalScrollView在滑动,这样就导致在左右滑动的时候特别卡顿,最终不得不放弃。。。。返工;


-----------------------------------------------重点--------------------------------------------------------

经过再三考虑,决定布局大换血

布局A我采用一个ExpandableListView,同样,布局C也采用一个ExpandableListView(设置宽度为标题栏的总宽度),标题栏包括布局C用一个自定义的HorizontalScrollView包裹,可以滑动的宽度就是标题栏的总宽度;

Question1.

那么如此的话我要解决的第一个问题便是 如何滑动右侧ExpandableListView的时候同时带动左侧的联动,并且是相同距离的联动,右侧也一样需要联动,下面贴出代码,互相学习指正;

Question2.


联动实现之后遇到了第二个问题,由于外面的父布局是一个viewPager嵌套多个fragment滑动,所以当我左右滑动listview的时候导致viewpager并不能灵活切换,显然这个是事件的分发和消费机制问题,隧道式向下分发,冒泡式向上处理,想起了当年老师总结的规律,于是在右侧listview外层的自定义HorizontalScrollView中重写了dispatchTouchEvent方法


requestDisallowInterceptTouchEvent 是ViewGroup类的一个方法,它的参数是boolean值,由字面意思可知,它的作用是要求不允许拦截触摸事件,要求谁呢?当时是父容器,通过getParent()方法获取父容器的实例,然后调用requestDisallowInterceptTouchEvent()阻止父容器拦截点击事件


这样通过改变后的大换血布局,整个页面没有再出现卡顿的现象,viewPager之间的切换也很流畅


下面这段代码是左右两侧的listView同时展开 ,同时闭合,且只展开一列的联动代码

private void  setBothExpandListView() {

mLeftListView.setOnGroupClickListener(newExpandableListView.OnGroupClickListener() {

@Override

public boolean onGroupClick(ExpandableListView parent,View v, intgroupPosition, longid) {

if(mLeftListView.isGroupExpanded(groupPosition)) {

mRightListView.collapseGroup(groupPosition);

}else{

mRightListView.expandGroup(groupPosition);

}

return false;

}

});

mRightListView.setOnGroupClickListener(newExpandableListView.OnGroupClickListener() {

@Override

public boolean onGroupClick(ExpandableListView parent,View v, intgroupPosition, longid) {

if(mRightListView.isGroupExpanded(groupPosition)) {

mLeftListView.collapseGroup(groupPosition);

}else{

mLeftListView.expandGroup(groupPosition);

}

return false;

}

});

mLeftListView.setOnGroupExpandListener(newExpandableListView.OnGroupExpandListener() {

@Override

public void onGroupExpand(intgroupPosition) {

for(inti =0;i

if(i != groupPosition &&mLeftListView.isGroupExpanded(i)) {

mLeftListView.collapseGroup(i);

}

}

}

});

mRightListView.setOnGroupExpandListener(newExpandableListView.OnGroupExpandListener() {

@Override

public void onGroupExpand(intgroupPosition) {

for(inti =0;i

if(i != groupPosition &&mRightListView.isGroupExpanded(i)) {

mRightListView.collapseGroup(i);

}

}

}

});

}

上一篇下一篇

猜你喜欢

热点阅读