美文网首页
一个页面两个或者多个listview(ExpandableLis

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

作者: 母老虎饲养员 | 来源:发表于2017-07-18 15:23 被阅读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);

    }

    }

    }

    });

    }

    相关文章

      网友评论

          本文标题:一个页面两个或者多个listview(ExpandableLis

          本文链接:https://www.haomeiwen.com/subject/zobcyttx.html