序言

有些bug,来无影,去无踪。你不知道它怎么产生的。比如下面这个,描述一下症状,每次Fragment切换的时候,页面都会自己滚动一点好像要把自己对齐。

布局如下

XML实现如下:

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"xmlns:app="http://schemas.android.com/apk/res-auto"android:layout_width="match_parent"android:layout_height="match_parent"android:orientation="vertical"><RelativeLayoutandroid:id="@+id/top_bar"android:layout_width="match_parent"android:layout_height="@dimen/TopBarHeight"android:background="@color/colorPrimary"><ImageViewandroid:layout_width="wrap_content"android:layout_height="wrap_content"android:layout_centerInParent="true"android:src="@drawable/ic_logo" /></RelativeLayout><com.trs.library.widget.statusviewlayout.StatusViewLayoutandroid:id="@+id/status_layout"android:layout_width="match_parent"android:layout_height="match_parent"><com.scwang.smartrefresh.layout.SmartRefreshLayoutandroid:id="@+id/ptr"android:layout_width="match_parent"android:layout_height="match_parent"app:srlEnableHeaderTranslationContent="true"app:srlEnableLoadmore="true"><com.scwang.smartrefresh.layout.header.ClassicsHeaderandroid:layout_width="match_parent"android:layout_height="wrap_content"app:srlClassicsSpinnerStyle="FixedBehind" /><android.support.v7.widget.RecyclerViewandroid:id="@+id/recyclerView"android:layout_width="match_parent"android:layout_height="match_parent"android:background="@android:color/white" /><com.scwang.smartrefresh.layout.footer.ClassicsFooterandroid:layout_width="match_parent"android:layout_height="wrap_content" /></com.scwang.smartrefresh.layout.SmartRefreshLayout></com.trs.library.widget.statusviewlayout.StatusViewLayout>
</LinearLayout>

用的是最近比较火的SmartRefreshLayout。

分析

一开始我看到的是这样的

1.自定义Layout出问题

每一次切换回来最顶部的自定义Layout都显示不全,也就是下面这个,实现可以看我的上一篇博客三角形兼梯形布局

于是把这个控件替换成RelativeLayout高度固定,但是bug依然存在。因此排除此项。

2.SmartRefreshLayout的问题

这个页面使用的了SmartRefreshLayout,详情见这里Android智能下拉刷新框架-SmartRefreshLayout
虽然是比较有名的第三方库,但是bug也是可能有的。所以开始阅读他的源码,但是在阅读了他的源码以后,发现没什么问题。通过打断点发现,在页面发生滚动的时候它的方法根本就没有调用。

3.手机的bug

我怀疑是不是开启了类属于三星的眼动功能,于是用了同事的小米进行测试,排除。

4.RecyclerView的问题

既然排除了所以可能性,那么最不可能的答案也是答案了。在RecyclerView中负责滚动的是LayoutManger,于是我自定义了LayoutManger,发现确实有Log输出
测试代码如下:

 @Overrideprotected RecyclerView.LayoutManager getLayoutManager() {return new MyLayoutManger(getActivity());}private class MyLayoutManger extends LinearLayoutManager {public MyLayoutManger(Context context) {super(context);}@Overridepublic int scrollVerticallyBy(int dy, RecyclerView.Recycler recycler, RecyclerView.State state) {Log.i("zzz", "MyLayoutManger scrollHorizontallyBy dy=" + dy);return super.scrollVerticallyBy(dy, recycler, state);}}

每一次切换回来的Log输出

10-13 16:29:53.968 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=53
10-13 16:29:53.988 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=63
10-13 16:29:53.998 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=53
10-13 16:29:54.018 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=39
10-13 16:29:54.038 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=36
10-13 16:29:54.048 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=26
10-13 16:29:54.068 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=21
10-13 16:29:54.088 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=16
10-13 16:29:54.108 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=12
10-13 16:29:54.118 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=8
10-13 16:29:54.138 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=7
10-13 16:29:54.158 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=5
10-13 16:29:54.168 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=3
10-13 16:29:54.188 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=1
10-13 16:29:54.208 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=2
10-13 16:29:54.238 6990-6990/com.trs.cqjb.gov I/zzz: MyLayoutManger scrollHorizontallyBy dy=1

调用链如下

可以看出来都是Framework层的调用,没有我们自己的代码。也没有SmartRefreshLayout的代码。既然找到问题了,就去Google。果然这是RecyclerView嵌套的bug。

总结

在遇到bug的时候,一定要耐心仔细,从最容易出错的地方找起,可以先从自己找齐,但是如果自身没有问题,也不能放过第三方库,认为第三方库就完美无缺。当遇到第三方库有问题的时候首先可以去翻阅Github中的issues这样会更快捷,但是如果还没有人阅读这类问题,那么我还得去read the funk source code (我曾经就通过跟踪断点,找出张鸿洋一个库里面代码的逻辑问题,然后去提了issues。)因此当我们遇到bug时不要怕,要平心静气,理性分析,合理假设,逐一排除。

神之bug 嵌套RecyclerView谜之滚动相关推荐

  1. NestedScrollView/ScrollView嵌套Recyclerview,导致Recyclerview抢占焦点,置顶了, 修改好后,引起Edittext又不能点击问题处理

    NestedScrollView/ScrollView嵌套Recyclerview,导致Recyclerview抢占焦点,置顶了, 修改好后,引起Edittext又不能点击问题处理 NestedScr ...

  2. recyclerview 软键盘_android-打开键盘时,Recyclerview不会滚动到结尾

    android-打开键盘时,Recyclerview不会滚动到结尾 我在应用程序中使用recylerview,并且每当将新元素添加到recyclerview时,它都会通过使用滚动到最后一个元素 rec ...

  3. Android中RecyclerView嵌套RecyclerView或嵌套ListView

    Android中RecyclerView嵌套RecyclerView或嵌套ListView

  4. ListView嵌套RecyclerView遇到的一些坑以及解决办法

    首先看下需求 要实现这个页面首先 我想到的是ListView嵌套RecyclerView,那么开动

  5. Android SrcollView嵌套recyclerView的使用

    今天,简单讲讲Android里使用SrcollView嵌套recyclerView需要注意的地方. 不废话了直接上代码,在使用时加上下面的代码就可以 recyclerView.setLayoutMan ...

  6. Android Scrollview嵌套RecyclerView导致滑动卡顿问题解决(屡试不爽)

    今天开发的一个项目首页,布局还是比较复杂的,各种滑动冲突,(Banner+横向RecyclerView+纵向RecyclerView(item又是横向的RecyclerView)),  最外面的框架用 ...

  7. Android之解决NestedScrollView嵌套RecyclerView部分手机返回到这个页面Recyclerview顶部,而不是页面NestedScrollView顶部

    1.问题 NestedScrollView嵌套Recyclerview部分手机返回到这个页面Recyclerview顶部,而不是页面NestedScrollView顶部 部分布局大致如下 <an ...

  8. Android之解决CoordinatorLayout+AppBarLayout+CollapsingToolbarLayout+RecyclerView里面再嵌套RecyclerView滑动颤抖问题

    1 问题 主页面用的是这种结构 CoordinatorLayout+AppBarLayout+CollapsingToolbarLayout+RecyclerView(里面再嵌套RecyclerVie ...

  9. 解决ScrollView嵌套RecyclerView出现item显示不全的问题

    解决ScrollView嵌套RecyclerView出现item显示不全的问题 参考文章: (1)解决ScrollView嵌套RecyclerView出现item显示不全的问题 (2)https:// ...

  10. Android图片控件,跟随列表(recyclerView)的上下滚动而同步平移。

    一个用于放置在RecycleView中的图片控件,其主要功能是跟随列表的上下滚动而上下平移,使得呈现出一种图像相对列表静止的感觉. Overview ScrollingImageView 提供以下特性 ...

最新文章

  1. zen3架构_AMD Zen3架构处理器的L3缓存或将翻倍到64MB
  2. 分布式事务的实现原理
  3. 放弃手工标记数据吧!斯坦福大学开源弱监督框架
  4. 一些蛮好的题目,学习
  5. css左右布局代码_如何使用CSS位置来布局网站(带有示例代码)
  6. Fiddler设置断点(一)
  7. 不得不看!降低Transformer复杂度的方法
  8. MySQL视图,触发器,事务,存储过程,函数
  9. Docker教程精要版
  10. CATIA怎么约束快捷键_Catia快捷键怎么设置?CATIA小技巧-设置快捷键方法
  11. chrome 内核的浏览器pdf 字体显示问题
  12. UE4 UI界面的层级切换
  13. 弘辽科技:电商新业态的扶贫,远不止卖货那么简单
  14. 马斯克让位?特斯拉中国一把手被曝将接任全球CEO,内部回应:您觉得是真的吗?...
  15. Solved Issues
  16. 亚马逊如何创业?身为小白的我适合创业亚马逊吗
  17. (免费分享)基于jsp,javaweb银行柜员业务绩效考核系统(带论文)
  18. js如何保留对象中指定字段(太刁了)
  19. 至每一位在努力奋斗的人-----复旦女生的高三生活
  20. 【聯強EMBA】「本能叛逆」與「理性叛逆」

热门文章

  1. Android-安卓Canvas画小黄人
  2. 动态规划——Weighted Interval Scheduling
  3. LOJ#2863. 「IOI2018」组合动作 交互
  4. wamp中为何php文件需要下载,配置WAMP后,浏览器输入默认的php文件名都直接下载该文档...
  5. android inflate 参数,Android inflate方法总结
  6. ERROR ITMS-90096
  7. Idea中如何查看pom中dependency Analyzer的快捷键
  8. 干货!JNPF快速开发平台功能一览
  9. Win10系统文件名太长导致无法删除
  10. 泰拉瑞亚 阿里云服务器搭建记录