一、几个概念
1.FrameTime:单帧渲染耗时
2.FPS:帧率
- 平均帧率:1s平均画面刷新次数
- 瞬时帧率:单帧渲染耗时换算出来的实时帧率
3.Jank:卡顿
同时满足以下两条件,则认为是一次卡顿Jank.
a)当前帧耗时>前三帧平均耗时2倍;
b)当前帧耗时>两帧电影帧耗时(1000ms/24*2=84ms)
4.BigJank:严重卡顿
同时满足以下两条件,则认为是一次严重卡顿BigJank.
a)当前帧耗时>前三帧平均耗时2倍。
b)当前帧耗时>三帧电影帧耗时(1000ms/24*3=125ms)
5.PerfDog Stutter:卡顿率
定义:测试过程中,卡顿时长的占比。即Stutter(卡顿率)=卡顿时长/总时长
计算思路:基于PerfDog Jank的基础上,一次Jank卡顿,会有一次卡顿时间Jank time。测试过程中可能有多次Jank卡顿,即有多次卡顿时间Jank time。测试总时长为Time。
Stutter(卡顿率)=∑Jank time / Time
说明:Jank为卡顿次数,Stutter为卡顿率,Jank和Stutter趋势有一致性,但并非完全线性,因为每次Jank卡顿严重性是不一样的。同时也说明了,没有Jank卡顿出现,自然也就卡顿率是0了。
二、导致不流畅的原因
1.帧率过低:
电影帧率(18-24),一般是24帧。电影帧单帧耗时:1000ms/24≈41.67ms。电影帧率是一个临界点。低于这个帧率,人眼基本能感觉画面不连续性
2.跳帧:
视觉预期帧率,用户潜意识里认为下帧也应该是当前帧率刷新比如一直60帧,用户潜意识里认为下帧也应该是60帧率刷新一直25帧,用户潜意识里认为下帧也应该是25帧率刷新如果是60帧一下跳变为25帧,扰乱用户视觉惯性。
三、衡量流畅度的指标
1.FPS:不应该低于24帧
2.Jank:不应该大于0
3.BigJank:不应该大于0
4.Stutter:不应该大于0%
四、App怎么测试流畅度
APP也需要关注FPS、Jank及卡顿率。只是需要区分使用场景,如:
1.静态页面窗口:
只需关注FPS,理论FPS应该为0,否则,说明有冗余刷新,容易引起手机发热及耗电。
2.有滚动动画页面窗口:
只需关注FPS,FPS处于合适值即可,无需高频刷新。
3.快速滑动页面窗口:
需要关注FPS、Jank及卡顿率。手机交互灵敏度就是来源于此,Android系统才出黄油计划Jank。一般滑动状态下,帧率越高越好,Jank越小越好。
4.播放视频页面窗口:
需要关注FPS、 Jank及卡顿率,视频卡顿直接影响用户。视频一般帧率18-24帧,Jank=0。比如微信播放视频、视频播放器等。
五、注意
本文中的Jank、BigJank、Stutter的概念都是基于PerfDog工具的概念。