TabLayout滑动下划线动画卡顿优化行动

界面

界面非常简单,如下图

界面非常简单,但因为一些效果显示的问题,套了六层的布局(老项目接手,这是一个坑,听说上一个Android开发是后端转过来的)。

效果,当屏幕向上滚动时,tab最后要悬停在顶部,不用关注的地方的布局比较复杂,单纯的LinearLayout不能满足需求,再加上可能不会使用ConstraintLayout,所以嵌套了六层布局,使用起来不会感觉卡顿,所以在接手时没想着优化。

场景复现

当data数据量比较大的时候,点击tab更新recyclerview的数据的时候,发现tab的下划线的动画出现0.1秒的卡顿现象。

如下图所示

在第三个第四个标签之间切换的时候,因为第四个标签下的数据量非常大,会导致下划线动画出现卡顿现象。

下图是开启GPU渲染模式时切换两个标签

可以看到在切换两个标签的时候,柱状图陡然拔高。现在,就需要优化这个问题。

处理BUG

其实也不算是BUG,只是一个影响体验的优化。

这里首先要确认到底是哪个地方这么占资源,什么地方这么的绘制需要这么多帧。

从代码的逻辑可以看到,点击tab后,tab的字体加粗,同时网络请求接口获取recyclerview的数据,释放tab后字体变回普通。

我用本办法,把网络请求的部分注释了,不卡顿了。//因为从代码逻辑上大概能猜出来是哪个地方比较耗费资源。

那么,大概就应该知道了,是recycleview加载数据和tab动画同时在占用资源导致卡顿的原因。

优化Item的布局

item的布局是RelativeLayout嵌套两个LinearLayout实现的,两个LinearLayout一个横向一个纵向。这个简单,把最外层换成ConstraintLayout就可以了。

重新运行,发现切换的时候仍然会卡顿一下。

缓存网络数据

点击tab调用网络请求接口,然后根据接口获得的数据刷新列表,那么,将接口数据缓存下来,减少网络请求的消耗。

不过这个直接被产品pass了,因为列表的数据需要实时。

延缓网络请求的时间

既然是因为tab动画和网络请求+recyclerview数据刷新同时占用资源,那么,把网络请求延后100ms,这样同样能解决卡顿问题。

scss 复制代码
CoroutineScope(Dispatchers.IO).launch {
    delay(100)
    mPresenter.getData(position)
}

实测过来发现,tab动画不会卡顿,同时列表加载数据也是正常的。这么完美的方案,产品不同意。

取消tab的动画效果

产品提出,取消tab的动画效果,这样也能处理卡顿效果。

但是,网上的文章都是tablayout+viewpager结合的例子,取消动画用的也是viewpager.setCurrentItem(position, false)这个方法。

这就又引出另一个问题了--为什么都用到tablayout了,为什么不跟着用上viewpager+fragment+recyclerview,而是仅仅只使用了一个recyclerview呢?

前因

这里还有一段故事,具体不细说,大概就是,二级页面触发进程回收,回到一级页面后发现ViewPager显示空白,无法创建Fragment。没有具体的细节了,因为当时忘了记录下来。

虽然没有tab的取消动画效果的方法,不过,可以取巧设置tab的动画时间为0,app:tabIndicatorAnimationDuration="0",同样也能实现取消tab动画效果的结果(我真是机智).

DiffUtil

recyclerview还有一个DiffUtil,不过因为紧急上线的缘故没有用。同样的,也可以对网络请求的数据进行分页处理。

相关推荐
雨白14 小时前
Jetpack Compose Navigation 2.x 详解
android·android jetpack
Android系统攻城狮17 小时前
Android内核进阶之获取DMA地址snd_pcm_sgbuf_get_addr:用法实例(九十一)
android·pcm·android内核·音频进阶·pcm硬件参数
清空mega17 小时前
Android Studio移动应用基础教程(前言)
android·ide·android studio
2501_9371454117 小时前
2025IPTV 源码优化版实测:双架构兼容 + 可视化运维
android·源码·源代码管理·机顶盒
zhoutanooi19 小时前
安卓bp文件编译学习
android·学习
aramae20 小时前
MySQL数据库入门指南
android·数据库·经验分享·笔记·mysql
百锦再21 小时前
选择Rust的理由:从内存管理到抛弃抽象
android·java·开发语言·后端·python·rust·go
whatever who cares21 小时前
在Java/Android中,List的属性和方法
android·java
油炸小波1 天前
09-微服务原理篇(XXLJOB-幂等-MySQL)
android·mysql·微服务
果子没有六分钟1 天前
setprop debug.hwui.profile visual_bars有什么作用
android