亲宝软件园·资讯

展开

屏蔽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();
    }
   }
  });

如有其他更优方案,欢迎讨论。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对的支持。

加载全部内容

相关教程
猜你喜欢
用户评论