神之bug 嵌套RecyclerView谜之滚动
序言
有些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谜之滚动相关推荐
- NestedScrollView/ScrollView嵌套Recyclerview,导致Recyclerview抢占焦点,置顶了, 修改好后,引起Edittext又不能点击问题处理
NestedScrollView/ScrollView嵌套Recyclerview,导致Recyclerview抢占焦点,置顶了, 修改好后,引起Edittext又不能点击问题处理 NestedScr ...
- recyclerview 软键盘_android-打开键盘时,Recyclerview不会滚动到结尾
android-打开键盘时,Recyclerview不会滚动到结尾 我在应用程序中使用recylerview,并且每当将新元素添加到recyclerview时,它都会通过使用滚动到最后一个元素 rec ...
- Android中RecyclerView嵌套RecyclerView或嵌套ListView
Android中RecyclerView嵌套RecyclerView或嵌套ListView
- ListView嵌套RecyclerView遇到的一些坑以及解决办法
首先看下需求 要实现这个页面首先 我想到的是ListView嵌套RecyclerView,那么开动
- Android SrcollView嵌套recyclerView的使用
今天,简单讲讲Android里使用SrcollView嵌套recyclerView需要注意的地方. 不废话了直接上代码,在使用时加上下面的代码就可以 recyclerView.setLayoutMan ...
- Android Scrollview嵌套RecyclerView导致滑动卡顿问题解决(屡试不爽)
今天开发的一个项目首页,布局还是比较复杂的,各种滑动冲突,(Banner+横向RecyclerView+纵向RecyclerView(item又是横向的RecyclerView)), 最外面的框架用 ...
- Android之解决NestedScrollView嵌套RecyclerView部分手机返回到这个页面Recyclerview顶部,而不是页面NestedScrollView顶部
1.问题 NestedScrollView嵌套Recyclerview部分手机返回到这个页面Recyclerview顶部,而不是页面NestedScrollView顶部 部分布局大致如下 <an ...
- Android之解决CoordinatorLayout+AppBarLayout+CollapsingToolbarLayout+RecyclerView里面再嵌套RecyclerView滑动颤抖问题
1 问题 主页面用的是这种结构 CoordinatorLayout+AppBarLayout+CollapsingToolbarLayout+RecyclerView(里面再嵌套RecyclerVie ...
- 解决ScrollView嵌套RecyclerView出现item显示不全的问题
解决ScrollView嵌套RecyclerView出现item显示不全的问题 参考文章: (1)解决ScrollView嵌套RecyclerView出现item显示不全的问题 (2)https:// ...
- Android图片控件,跟随列表(recyclerView)的上下滚动而同步平移。
一个用于放置在RecycleView中的图片控件,其主要功能是跟随列表的上下滚动而上下平移,使得呈现出一种图像相对列表静止的感觉. Overview ScrollingImageView 提供以下特性 ...
最新文章
- zen3架构_AMD Zen3架构处理器的L3缓存或将翻倍到64MB
- 分布式事务的实现原理
- 放弃手工标记数据吧!斯坦福大学开源弱监督框架
- 一些蛮好的题目,学习
- css左右布局代码_如何使用CSS位置来布局网站(带有示例代码)
- Fiddler设置断点(一)
- 不得不看!降低Transformer复杂度的方法
- MySQL视图,触发器,事务,存储过程,函数
- Docker教程精要版
- CATIA怎么约束快捷键_Catia快捷键怎么设置?CATIA小技巧-设置快捷键方法
- chrome 内核的浏览器pdf 字体显示问题
- UE4 UI界面的层级切换
- 弘辽科技:电商新业态的扶贫,远不止卖货那么简单
- 马斯克让位?特斯拉中国一把手被曝将接任全球CEO,内部回应:您觉得是真的吗?...
- Solved Issues
- 亚马逊如何创业?身为小白的我适合创业亚马逊吗
- (免费分享)基于jsp,javaweb银行柜员业务绩效考核系统(带论文)
- js如何保留对象中指定字段(太刁了)
- 至每一位在努力奋斗的人-----复旦女生的高三生活
- 【聯強EMBA】「本能叛逆」與「理性叛逆」
热门文章
- Android-安卓Canvas画小黄人
- 动态规划——Weighted Interval Scheduling
- LOJ#2863. 「IOI2018」组合动作 交互
- wamp中为何php文件需要下载,配置WAMP后,浏览器输入默认的php文件名都直接下载该文档...
- android inflate 参数,Android inflate方法总结
- ERROR ITMS-90096
- Idea中如何查看pom中dependency Analyzer的快捷键
- 干货!JNPF快速开发平台功能一览
- Win10系统文件名太长导致无法删除
- 泰拉瑞亚 阿里云服务器搭建记录