Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电

Android耗电优化实践 (二)

检测错误的UI绘制刷新导致的耗电

首先打开开发者选项,打开GPU视图更新的开关,然后看看应用内部有哪些不必要的UI刷新,

场景一(自定义TextView)

Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电

首页快速组队页面,列表中查看更多在一直刷新,直接看代码,
Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电

这里有一个自定义View,继续看TextViewWideContent的代码
Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电
分析代码发现在onDraw()里面调用了setPadding(),继续看setPadding()的源码,
Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电
可以看到这里面调用了页面invalidate(),这就导致了onDraw()方法的循环调用,所以页面会持续刷新。结论就是在自定义View的onDraw()方法里面,调用setPadding(),会导致页面重复绘制
解决办法也很简单把setPadding放到onLayout()里面去。

场景二(CoordinatorLayout+AppBarLayout错误的依赖关系)

Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电
错误代码如下:

Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电在CoordinatorLayout+AppBarLayout页面结构中,错误的将底部依赖于头部控件,导致底部一直在刷新,去掉 app:layout_anchor="@id/user_appbar_layout" 就好了。

场景三(游戏专区页面视频播放导致整体页面刷新)

Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电
具体原因还在排查,可能是第三方库导致的,要更换只能换库。

场景四(麦位刷新)

Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电
Android耗电优化实践 (二)- 检测错误的UI绘制刷新导致的耗电
聊天室麦位刷新导致的的页面重绘,这边似乎是需求如此,需要定期刷新。可能有更好的实现方式,先记录一下。

总结一下:

  • 首先自定义View的onDraw()方法里面,不要调onPadding(),如果一定要调用,请放在onLayout()里面设置。
  • CoordinatorLayout+AppBarLayout 结构中,错误的使用app:layout_anchor="@id/user_appbar_layout" 导致整个底部刷新。

相关建议