重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
android项目中如何实现给RecyclerView加上折叠效果?很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。
成都网络公司-成都网站建设公司成都创新互联公司十多年经验成就非凡,专业从事成都做网站、网站建设,成都网页设计,成都网页制作,软文发布平台,1元广告等。十多年来已成功提供全面的成都网站建设方案,打造行业特色的成都网站建设案例,建站热线:028-86922220,我们期待您的来电!
效果
总结一下这个列表的特点,就是以下三点:
1. 重叠效果;
2. 层次感;
3. 首项的差动效果。
下面我们来一个个解决。
我们新建一个ParallaxRecyclerView,让它继承RecyclerView,并使用LinearLayoutManager作为布局管理器。
重叠效果
其实就是每一项都搭一部分在它前面那项而已。我们知道,RecyclerView可以通过设置ItemDecoration来实现列表的间隔效果,有没有想过要是把间隔设为负数会怎么样?比如:
addItemDecoration(new ItemDecoration() { @Override public void getItemOffsets(Rect outRect, View view, RecyclerView parent, State state) { super.getItemOffsets(outRect, view, parent, state); outRect.bottom = -dp2px(context, 10); } });
没错,这就实现了我们的重叠效果。
层次感
在Material Design里是有Z轴这个概念的,我们可以给控件设置垂直于屏幕的高度,让不在同一高度的控件看起来有层次感。当然,我们要用Material Design的控件才有这个属性,这里我用的是CardView。
我们给ParallaxRecyclerView增加一个滑动监听,在onScrolled方法里面做如下设置:
LinearLayoutManager layoutManager = (LinearLayoutManager) recyclerView.getLayoutManager(); int firstPosition = layoutManager.findFirstVisibleItemPosition(); int lastPosition = layoutManager.findLastVisibleItemPosition(); int visibleCount = lastPosition - firstPosition; //重置控件的高度 int elevation = 1; for (int i = firstPosition - 1; i <= (firstPosition + visibleCount) + 1; i++) { View view = layoutManager.findViewByPosition(i); if (view != null) { if (view instanceof CardView) { ((CardView) view).setCardElevation(dp2px(context, elevation)); elevation += 5; } } }
其中,setCardElevation方法就是用来给CardView设置高度的,这里让每一项的高度比它的上一项高5dp。
首项的差动
最后,我们想给第一项增加一个差动效果,这个同样在onScrolled方法里面做处理就好了:
View firstView = layoutManager.findViewByPosition(firstPosition); float firstViewTop = firstView.getTop(); firstView.setTranslationY(-firstViewTop / 2.0f);
这样相当于第一项的滑动速度变成原来的一半。但这也会导致一个问题, 由于改变了控件的位置,当这个控件被复用时,会出现位置不正确的情况。所以我们在设置高度的时候,可以顺便把控件的位置复原了:
float translationY = view.getTranslationY(); if (i > firstPosition && translationY != 0) { view.setTranslationY(0); }
看完上述内容是否对您有帮助呢?如果还想对相关知识有进一步的了解或阅读更多相关文章,请关注创新互联行业资讯频道,感谢您对创新互联的支持。