1、刷新率介绍
我们先来理一下基本的概念:
1、60 fps 的意思是说,画面每秒更新 60 次
2、这 60 次更新,是要均匀更新的,不是说一会快,一会慢,那样视觉上也会觉得不流畅
3、每秒 60 次,也就是 1/60 ~= 16.67 ms 要更新一次
4、一般来说屏幕的刷新率是硬件概念,意思是1秒显示60张图片。如果屏幕分辨率为60HZ,应用程序设置的刷新率要小于或等于60HZ。
data:image/s3,"s3://crabby-images/70cc1/70cc166c13a9fafa4c7d3cf49de0cbdb671e398d" alt=""
data:image/s3,"s3://crabby-images/63f96/63f9618b426ed85b470471b43248c8e24e4e1a3e" alt=""
2、图层介绍
2.1、绘制介绍
在Android渲染系统中,⽣产者是应⽤进程,消费者是SurfaceFlinger进程,两个不同的进程数据的交换就涉及跨 进程通信,⽽服务它们跨进程通信的组件是BufferQueue。BufferQueue就像是⼀个桥梁,让原本孤⽴的应⽤进程 和SurfaceFlinger进程联系在⼀起,有了BufferQueue这个桥梁,图形显示系统基本架构可变成如下:
data:image/s3,"s3://crabby-images/ab1af/ab1af9bc3cbcc06be71af42e29fe8baec1bed62e" alt=""
data:image/s3,"s3://crabby-images/09188/0918837c0709b7c701bf02b411079c99ee10373d" alt=""
data:image/s3,"s3://crabby-images/da243/da243862ac757a9c74ba11ff86f130c7f2449b64" alt=""
Perfetto中SurfaceFlinger图层数据显示如下
data:image/s3,"s3://crabby-images/f4721/f4721571963b32b9fed6555b118342bcc6b8c591" alt=""
代码环节中,ViewRootImpl.java中的drawSoftware
函数中,使用mSurface.lockCanvas(dirty)来获取SurfaceFlinger缓冲区
data:image/s3,"s3://crabby-images/0ea92/0ea920beeeac51f285ba57576ec97d674f083dfe" alt=""
在surface.unlockCanvasAndPost(canvas);来释放缓冲区
data:image/s3,"s3://crabby-images/8fd31/8fd311b999f0ae0105b5fc169341491e58437bc6" alt=""
2.2、卡顿是如何生成的呢?
既然出现了生产者和消费者,那么不是16.7ms类相关流程没有完成,是否就会感受到卡顿?
参考https://perfetto.dev/docs/data-sources/frametimeline
data:image/s3,"s3://crabby-images/554e8/554e8cfce6ea9ac0811d2ddc6ec0025e998ec572" alt=""
查看Perfetto log时,绿色表示正常绘制,其他颜色表示没按时绘制。
data:image/s3,"s3://crabby-images/e19f8/e19f871868c92dc6128448eaa46eb82cbb9e163c" alt=""
当APP绘制时长超过30帧后,对应在Log中有如下打印。
data:image/s3,"s3://crabby-images/90ba1/90ba1c75e9dfc3c9dce15e38565569664554e6ea" alt=""
当APP Choreographer中来不及绘制时,是否就出现了卡顿呢?
答案是不一定,这个涉及到Buffer缓冲区设计
2.3、 Triple Buffer
Buffer缓冲区设计具体得参考
https://blog.csdn.net/flc2762/article/details/122881577