SwipeRefreshLayout+RecyclerView滑

作者: Jlanglang | 来源:发表于2018-09-14 19:37 被阅读38次

偶然间发现的bug

场景如下:
recyclerView使用了头部view的逻辑。具体adapter就不介绍了,具体可以去看我的TreeRecycleView库。大致就是添加了一个头部view

ImageView  imageView = new ImageView(getContext());
 imageView.setLayoutParams(new ViewGroup.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT));
headerAndFootWrapper.addHeaderView(imageView);

我的需求,根据服务器返回的数据。动态设置头部显示隐藏

public void setBanner(String url) {
        if (TextUtils.isEmpty(url)) {
            imageView.setVisibility(View.GONE);
        } else {
            imageView.setVisibility(View.VISIBLE);
            ImageLoaderUtil.getInstance().loadImage(url, imageView);
        }
    }

这时问题出现了:

如果头部imageView隐藏了。那么就无法下拉刷新
如果头部显示了,就可以下拉刷新

那么问题来了,什么鬼呢?

研究了一会。

总结如下:

RecycleView的第一个条目的所有View,如果没有高度(比如用了WRAP_CONTENT)并且使用了View.Gone

那么SwipeRefreshLayout的下拉刷新就不会触发。因为RecyclerView.childAt(0).getTop()不会返回正常结果。

解决也简单。

1.添加了头部View的话。在设置View.GONE的时候记得 notifyDataSetChanged() 刷新一下

相关文章

  • SwipeRefreshLayout+RecyclerView滑

    偶然间发现的bug 场景如下:recyclerView使用了头部view的逻辑。具体adapter就不介绍了,具体...

  • RecyclerView之EmptyView展示

    SwipeRefreshLayout+RecyclerView之EmptyView展示 创建EmptyView的布...

  • SwipeRefreshLayout+Recyclerview

    上拉加载更多实现方式: 参考文章:https://www.jianshu.com/p/96f14f6a5bb4 参...

  • Android 用SwipeRefreshLayout+Recy

    开篇   工作闲暇之余,用SwipeRefreshLayout+RecyclerView倾心打造了一个下拉刷新控件...

  • SwipeRefreshLayout+Recyclerview实

    前提: 现在市面上的Android的App只要涉及到网络交互的,几乎都有着上拉刷新的功能。无论是新闻资讯类的简书掘...

  • SwipeRefreshLayout+RecyclerView冲

    场景1 一种是SwipeRefreshLayout+RecyclerView在同一个界面的,可以通过重写swipe...

  • SwipeRefreshLayout+RecyclerView实

    一、介简 上一节写自定义RecyclerView实现了一个简单的下拉刷新与加载更多,这一节主要写外包Recycle...

  • 滑滑滑

    滑滑滑,滑板,轮滑,滑起来

  • 滑滑鞋

    哎吆哎,是谁在叫,原来是院子里的小朋友滑滑鞋摔倒了,我也迫不及待的拿出滑鞋出去滑。 开始,我还不会滑,奶奶扶着我,...

  • 滑滑虫

    最近我交了个朋友,它说它是滑滑虫,但在我看来,简直和鼻涕虫长得一模一样。我给它取名叫丑丑,因为它岂止是丑,简直是丑...

网友评论

  • 阿西吧喽:这种诡异的bug也有,试过把依赖的版本号提高吗?高版本的可能就修复了

本文标题:SwipeRefreshLayout+RecyclerView滑

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