吾生也有涯,而知也无涯。这篇文章主要讲述android UI卡顿问题学习相关的知识,希望能为你提供帮助。
【android UI卡顿问题学习】转自https://blog.csdn.net/joye123/article/details/79425398
https://blog.csdn.net/zhenjie_chang/article/details/52584967
卡顿优化卡顿:从用户角度说,App操作起来缓慢,响应不及时,列表滑动一顿一顿的,动画刷新不流畅等等一些直观感受。从系统角度来说,屏幕刷新的帧率不稳定,无法保证每秒绘制60帧,也就是说有掉帧的情况发生。
对于开发过程,出现卡顿的主要原因是主线程做了一些不该做的事,或者主线程做不了事情了。
- 布局渲染(解析、测量、布局、渲染)
- 动画执行
- Binder通信
- 界面响应
文章图片
- 原色:没有过度绘制
- 蓝色:过度绘制1次
- 绿色:过度绘制2次
- 粉色:过度绘制3次
- 红色:过度绘制4次或更多
常见卡顿原因及解决方案
过度绘制
去除不必要的背景色
- 设置窗口背景色为通用背景色,去除根布局背景色。
- 若页面背景色与通用背景色不一致,在页面渲染完成后移除窗口背景色
- 去除和列表背景色相同的Item背景色
- 移除嵌套布局
- 使用merge、include标签
- 使用性能消耗更小布局(TableLayout、ConstraintLayout)
- 通过使用半透明颜色值(#77000000)代替
- 使用ViewStub标签,延迟加载不必要的视图
- 使用AsyncLayoutInflater异步解析视图
主线程耗时操作
- Json数据解析耗时(Cache类)
- 文件操作(获取所属渠道名称)
- Binder通信(获取系统属性(mac地址))
- 正则匹配(Hybird 通信)
- 相机操作:初始化、预览、停止预览、释放(反扫)
- 组件初始化(推送)
- 循环删除、创建View(更多页面)
- WebView首次初始化
布局优化的一些策略1. < include> 标签
2. < viewstub> 标签
3.< merge> 标签
4.去除不必要的嵌套和View节点
5.减少不必要的infalte
6.View局部更新
推荐阅读
- create-react-app react脚手架
- 微信语音转文字的设置办法_微信
- 微博财神卡在啥地方看?微博财神卡怎样看有几张?_新浪微博
- 微信小程序搜索历史小程序的办法_微信
- 我在微博的2016怎样看?我在微博的2016入口_新浪微博
- 微信被封号怎样解封?微信解封步骤_微信
- 亲测有效果 无需手机发短信验证的微信解封办法_微信
- 微信解封软件运用图文详细教程_微信
- 手机QQ勋章如何点亮?手机QQ勋章点亮图文详细教程