屏蔽RecyclerView单边滑动到头阴影(fadingEdge) 屏蔽RecyclerView单边滑动到头阴影(fadingEdge)的方法
tongcpp 人气:0想了解屏蔽RecyclerView单边滑动到头阴影(fadingEdge)的方法的相关内容吗,tongcpp在本文为您仔细讲解屏蔽RecyclerView单边滑动到头阴影(fadingEdge)的相关知识和一些Code实例,欢迎阅读和指正,我们先划重点:recyclerview滑动阴影,recyclerview,阴影,recyclerview边缘阴影,下面大家一起来学习吧。
前言
RecyclerView 是一个增强版的ListView,不仅可以实现和ListView同样的效果,还优化了ListView中存在的各种不足之处
ResyslerView 能够实现横向滚动,这是ListView所不能实现的
目前官方更加推荐使用RecyclerView.
场景:
由于在某些产品需求下,希望RecyclerView滑动到底部时显示到头阴影,但由于顶部是下拉刷新控件而不希望显示顶部的fadingEdge。
做法:
通过阅读RecyclerView的源码实现,我们发现没有暴露的方法可被调用或重载,故采用反射的方式实现。
代码如下:
mRecyclerView.setOnScrollListener(new RecyclerView.OnScrollListener() { @Override public void onScrolled(RecyclerView recyclerView, int dx, int dy) { super.onScrolled(recyclerView, dx, dy); EdgeEffectCompat mTopGlow = null; try { Field topGlow = mRecyclerView.getClass().getDeclaredField("mTopGlow"); if (topGlow != null) { topGlow.setAccessible(true); mTopGlow = (EdgeEffectCompat) topGlow.get(mRecyclerView); } } catch (Exception e) { e.printStackTrace(); } if (mTopGlow != null) { mTopGlow.setSize(0, 0); mTopGlow.finish(); } } });
如有其他更优方案,欢迎讨论。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。
加载全部内容