Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >APP&游戏需要关注Jank卡顿吗?

APP&游戏需要关注Jank卡顿吗?

原创
作者头像
WeTest质量开放平台团队
修改于 2020-04-07 09:44:09
修改于 2020-04-07 09:44:09
1.6K0
举报

导语:

    本次技术干货分享主要是讲解PerfDog卡顿Jank定义、原理及影响。内容将分为五部分:FrameTime、FPS、流畅度、Jank、影响。从深层次分析在性能测试工作中这五部分起到的重要意义。

第一部分:FrameTime

FrameTime 的定义:两帧画面间隔耗时(也可简单认为单帧渲染耗时)。

对于FrameTime和卡顿是否有关联?请看下图的案例图示:

    从图中可看出画面中B帧在GPU渲染耗时(帧生成时间)大于显示器刷新间隔,占用两次显示器刷新耗时。也就是说有一次画面没刷新。当出现多次没有画面刷新(也就是说画面没变化),则可能是一次卡顿。

从这里就得出结论:玩家用户真正看到的是屏幕新画面刷新间隔时间,而不是eglSwapbuffers-GPU渲染完成(并未有提交屏幕显示)间隔时间。所以后面所提到Frametime统统指的是屏幕Display-Frametime。

PerfDog工具优点:PerfDog统计的FPS和Frametime都是用户看到的屏幕Display新画面真实刷新FPS和帧耗时。所以大家可以直接通过Frametime来判断测试过程中是否出现卡顿。

第二部分:FPS

FPS的定义:帧率(1秒内平均画面刷新次数)。

平均帧率:传统常说的FPS,1秒内平均画面刷新次数。

瞬时帧率:单帧耗时FrameTime算出来实时FPS,每一帧画面刷新耗时换算出的实时帧率。

画面渲染流程图如下,每一帧FrameTime。

PerfDog统计帧率及FrameTime如下图:

FPS帧率与卡顿是否有关系?我们分为Andriod和ios两个场景去进一步了解:

iOS端

    苹果WDDC18年开发者大会

①     FramePacing

比如下面两个游戏画面,左边的试图以60帧运行,但实际只能达到40帧;右边的则持续稳定在30帧运行:

    上图左边帧率高,反而看起来有一卡一顿的现象,这就是Micro Stuttering(微型口吃)导致的,左边FrameTime如下图:

    通过FrameTime可以看出,左边高帧率FPS=40帧率中出现一次FrameTim>=117ms,理论平均FrameTime=25ms。所以非均匀渲染,虽然帧率高达40,但依然觉得非常卡。

右边低帧率30帧运行FrameTime如下图:

从上面FrameTime可以看出,帧率FPS=30,FrameTime均匀为33ms,画面会非常平滑。

总结:帧率高,未必流畅。

Android

    测试系统版本:Android4.4

①     流畅度机制-黄油计划(Jank)

Google Jank 计算思路:考虑视觉惯性,以硬件vsync时间间隔,连续1次vsync没有新画面刷新,则认为是一次卡顿,也就是说下一次vsync时间点没有新画面刷新,则认为是一次Jank。

第三部分:流畅度

流畅度与卡顿的关联可以用以下的流程图来大致展示:

    流畅度影响卡顿。这个可以简单的理解为视觉惯性和电影帧这两个方面:

1、视觉惯性

    视觉预期帧率,用户潜意识里认为下帧也应该是当前帧率刷新比如一直60帧,用户潜意识里认为下帧也应该是60帧率。刷新一直是25帧,用户潜意识里认为下帧也应该是25帧率。但是刷新如果是60帧一下跳变为25帧,扰乱用户视觉惯性。这个时候就会出现用户体验的卡顿感。

2、电影帧

    电影帧率(18-24),一般是24帧。电影帧单帧耗时:1000ms/24=40ms。电影帧率是一个临界点。低于这个帧率,人眼基本能感觉画面不连续性,也就是感觉到了卡顿。

第四部分:PerfDog-Jank

    PerfDog Jank 计算思路:考虑视觉惯性,假设以前三帧的平均帧耗时为参考,作为vsync时间间隔,连续两次vsync没有新渲染画面刷新,则认为是一次潜在卡顿,也就是说下一帧耗时大于前三帧平均帧耗时2倍,则认为一次潜在卡顿。同时单帧耗时满足大于两倍电影帧耗时1000ms/24*2 (由于人眼低于24帧才能辨别画面不连续性),则认为是一次真正卡顿。同时若单帧耗时大于3倍电影帧耗时,则认为是一次严重卡顿。

注解:为什么是两次vsync?GPU一般是3重缓冲buffer,当前帧已占用一个buffer,即剩余2缓冲buffer,人眼一般可容忍2帧延迟。

    为什么是两帧电影帧耗时?低于24帧画面,人眼就能感知到画面不连续性,电影一般都是24帧。即电影帧耗时1000ms/24=41.67ms,两帧电影帧耗时也就是41.67ms*2,三帧电影帧耗时是41.67ms*3。

PerfDog Jank计算方法:

同时满足两条件,则认为是一次卡顿Jank.

①Display FrameTime>前三帧平均耗时2倍。

②Display FrameTime>两帧电影帧耗时 (1000ms/24*2=84ms)。

同时满足两条件,则认为是一次严重卡顿BigJank.

①Display FrameTime >前三帧平均耗时2倍。

②Display FrameTime >三帧电影帧耗时(1000ms/24*3=125ms)。

Google-Jank如图:

PerfDog-Jank如图:

真实测试FrameTime计算Jank,如下图:

PerfDog-Jank如图:

备注:帧率低,并不是顿卡,如帧率都是只有几帧了,还有什么顿卡而言?

目前主流游戏对比Jank如下:

PerfDog-web平台

第五部分:影响

    从前面的知识了解到FrameTime、FPS、流畅度和Jank之间的紧密联系后,就可以顺其自然得出我们的结论:APP和游戏到底需不需要关注Jank卡顿呢?答案是需要的,并且还是重点关注!理由如下:

游戏方面

游戏流畅度是最影响用户体验的,所以需要重点关注FPS和Jank。

备注:比如游戏中已预知的卡顿,如新UI弹出等造成卡顿,可认为是干扰,需要剔除,不应算在Jank,可通过web云上,框选右键删除干扰数据。

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卡顿对于APP&游戏的重要,以及其关注的侧重点,PerfDog正是是致力于为游戏&应用提升品质。

PerfDog是由WeTest腾讯质量开放平台发行的移动全平台iOS\Android性能测试工具,能快速定位分析性能问题,提升APP应用及游戏性能和品质,手机无需ROOT/越狱,手机硬件、游戏及应用无需做任何更改,极简化即插即用。

扫码即刻加群 与2000+测试同行深度交流

点击阅读原文直达官网!

PerfDog官网:perfdog.qq.com

腾讯WeTest官网:wetest.qq.com

PerfDog交流群:602206842

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。

如有侵权,请联系 cloudcommunity@tencent.com 删除。

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
【PerfDog专家课堂】APP&游戏需要关注Jank卡顿吗?
导语   本次技术干货分享主要是讲解PerfDog卡顿Jank定义、原理及影响。内容将分为五部分:FrameTime、FPS、流畅度、Jank、影响。从深层次分析在性能测试工作中这五部分起到的重要意义。 第一部分:FrameTime FrameTime 的定义:两帧画面间隔耗时(也可简单认为单帧渲染耗时)。 对于FrameTime和卡顿是否有关联?请看下图的案例图示:   从图中可看出画面中B帧在GPU渲染耗时(帧生成时间)大于显示器刷新间隔,占用两次显示器刷新耗时。也就是说有一次画面没刷新。当出现多
WeTest质量开放平台团队
2019/12/24
3.9K0
【PerfDog专家课堂】APP&游戏需要关注Jank卡顿吗?
性能优化测试中的相关名词
当一个APP或游戏各种功能越来越多时,性能优化的重要性就不言而喻了,况且现在APP或游戏的功能逐渐趋同,提升用户体验已从产品设计本身转到了APP或游戏的流畅性上,这也让越来越多的开发者更加关注性能优化与测试。前段时间PerfDog研发团队曾带来《腾讯游戏性能实战案例分享之帧率陡变1.0》和《APP&游戏需要关注Jank卡顿吗?》两篇关于帧率与Jank的专业分析文章,本次我们就来看看在性能优化测试中会遇到的哪些名词。
WeTest质量开放平台团队
2020/04/27
3.1K0
性能优化测试中的相关名词
移动端性能测试必备工具PerfDog性能狗
在项目研发支持过程中,经历如上障碍和痛苦。我们决定做一个完全独立、简单易用,与APP版本、系统版本、系统平台无任何关系的性能平台。
WeTest质量开放平台团队
2020/09/01
2.8K0
Android深入卡顿分析与实践
1、视觉惯性 视觉预期帧率,用户潜意识里认为下帧也应该是当前帧率刷新比如一直60帧,用户潜意识里认为下帧也应该是60帧率。刷新一直是25帧,用户潜意识里认为下帧也应该是25帧率。但是刷新如果是60帧一下跳变为25帧,扰乱用户视觉惯性。这个时候就会出现用户体验的卡顿感。
QQ音乐技术团队
2023/12/20
1.9K0
Android深入卡顿分析与实践
WeTest明星工具-移动端性能测试PerfDog初探
在十一月初,腾讯就官宣了一则消息,腾讯WeTest明星工具-PerfDog面向全球发布。官宣介绍如下:https://wetest.qq.com/lab/view/475.html。我在看到该新闻时,有种大开眼界的感觉,移动端的性能测试原来可以这么简单。今天闲暇之余,来了一波初探,简单体验了一番。
WeTest质量开放平台团队
2020/09/08
1.3K0
初识PerfDog
小编最近刚接触了一款性价比较高的性能评测工具-PerfDog,这是腾讯旗下的一款移动全平台iOS/Android性能测试及指标分析工具平台,简而言之就是测试采集手机在运行App时的性能指标数据:FPS、Jank、FTime、CPU、GPU、Memory、Battery 、Network、CTemp等性能参数,从而快速定位分析App的性能问题,小编在这里主要介绍下相关名词含义、使用技巧及案例分析。
用户5521279
2020/12/11
3.1K0
初识PerfDog
APP性能测试—PerfDog
PerfDog是一个移动全平台Android/iOS性能测试、分析工具。可以快速定位分析性能问题。手机无需ROOT/越狱,手机硬件、游戏及应用APP也无需做任何修改,极简化即插即用。
清风穆云
2021/08/09
4.3K0
APP性能测试—PerfDog
PerfDog 下性能测试分析记录(Android)
最近做的项目需要和Unity做交互, Unity作为一款游戏引擎, 还是很耗性能的, 所以找了找性能测试的工具, 发现了腾讯的PerfDog, 记录一下使用心得。
WeTest质量开放平台团队
2020/11/24
1.5K0
PerfDog 下性能测试分析记录(Android)
PerfDog使用说明书
English User's Guide:https://bbs.perfdog.qq.com/article-detail.htmlid=7
WeTest质量开放平台团队
2020/12/08
2.7K0
【Android 性能优化】布局渲染优化 ( CPU 与 GPU 架构分析 | 安卓布局显示流程 | 视觉与帧率分析 | 渲染超时卡顿分析 | 渲染过程与优化 )
① 承担工作多 : GPU 没有出现之前 , CPU 要承担很多工作 , 如逻辑运算 , 内存管理 , 显示控制 , 界面渲染 等操作 ;
韩曙亮
2023/03/27
4.2K0
【Android 性能优化】布局渲染优化 ( CPU 与 GPU 架构分析 | 安卓布局显示流程 | 视觉与帧率分析 | 渲染超时卡顿分析 | 渲染过程与优化 )
直播回顾 | 移动产品质量管理如何实践?听听行业大咖怎么说(附直播回放)
6月24日,腾讯WeTest质量云首场专题直播《十年磨一剑,匠心铸造PerfDog》圆满收官。 本次直播,WeTest邀请MTSC中国互联网测试开发大会主席、腾讯资深测试技术总监、明星性能工具PerfDog创始人曹文升(Awen)老师,为大家揭秘和全面解读了明星产品背后的起源、诞生、成长故事,PerfDog创新指标的涵义与作用,并与线上观众共同探讨了移动产品质量管理的的前沿技术与应用实践。 下面让我们一起来回顾,Awen老师在直播过程中的精彩演讲吧。 01 厚积薄发 十年匠心打磨 PerfDog团队从20
WeTest质量开放平台团队
2022/07/12
7550
直播回顾 | 移动产品质量管理如何实践?听听行业大咖怎么说(附直播回放)
Android系统16ms之内能做些什么
如果你觉得你的应用界面出现卡顿不流畅的情况,不用怀疑,这很大原因是你没有在16ms完成你的工作。没错,16ms要完成你的工作,再慢点,用户一定会吐槽,然后狠心把你辛辛苦苦开发出来的应用给卸载掉,你也不想想,人生有几个16ms可以浪费啊!
open
2020/03/19
1.2K0
Android系统16ms之内能做些什么
测试 App 流畅度
FPS 和丢帧率可以在一定程度上作为 APP 流畅度的一项衡量标准,本文介绍利用 adb shell dumpsys gfxinfo 命令获取软件渲染加载过程的数据,进行计算从而获取测试结果。
霍格沃兹测试开发Muller老师
2022/12/01
6300
APP性能测评分析
1.1流畅度相关概念 刷新率 vs 帧率 刷新率:美妙屏幕刷新次数,手机品目的刷新率是60HZ 帧率:GPU在一秒内绘制的帧率
用户10443079
2023/03/21
1.9K0
APP性能测评分析
专项测试实战 | 如何测试 App 流畅度(基于 FPS 和丢帧率)?
FPS 和丢帧率可以在一定程度上作为 APP 流畅度的一项衡量标准,本文介绍利用 adb shell dumpsys gfxinfo 命令获取软件渲染加载过程的数据,进行计算从而获取测试结果。
霍格沃兹测试开发
2022/05/23
1.7K0
Matrix TraceCanary -- 初恋·卡顿
Baby 不要再哭泣,这一幕多么熟悉~ 在使用 App 时,有些人遇上这弹框应该会是一本正经,而有些人看到了估计一脸懵逼(黑人❓)。当然,这里我们要讨论的不是什么初恋,而是对大多数开发者来说,戏虐你千百遍,回头对它如初恋的卡顿。 曾经有篇杂志说“使用一款应用,犹如谈一场恋爱”,当时我觉得这是一本正经地在胡说八道,你手机装了上百款应用,能说这像谈恋爱?但现在想想,其实并非没有道理,当你喜欢上一款应用,往往是因为它的功能足够吸引你,就像你喜欢他的外表,再然后你体验了一段时间(交往),发现这款确实是你喜欢的
微信终端开发团队
2019/01/11
4.4K0
Matrix TraceCanary -- 初恋·卡顿
PerfDog测试腾讯视频、优酷、爱奇艺视频类小程序性能
自从经朋友介绍PerfDog这款移动端测试神器后就一直在使用它测试大型游戏的流程度,前两天使用腾讯视频追剧分享到微信时发现发现的链接直接进入腾讯视频的小程序中,试了多个视频软件皆是如此,于是想要试试用PerfDog测试一下各家视频小程序实际使用的性能到底如何。
WeTest质量开放平台团队
2020/05/18
1.3K0
PerfDog测试腾讯视频、优酷、爱奇艺视频类小程序性能
iOS的三重缓冲和微型口吃(micro stuttering)
iOS 中采用双重缓冲和三重缓冲一起使用,从 display 中就可以看出来。即:双缓冲不够用了就采用三缓冲。
全栈程序员站长
2022/08/26
5860
iOS的三重缓冲和微型口吃(micro stuttering)
专项测试实战 | 如何测试 App 流畅度(基于 FPS 和丢帧率)
FPS 和丢帧率可以在一定程度上作为 APP 流畅度的一项衡量标准,本文介绍利用 adb shell dumpsys gfxinfo 命令获取软件渲染加载过程的数据,进行计算从而获取测试结果。
霍格沃兹测试开发
2020/09/03
1.6K0
专项测试实战 | 如何测试 App 流畅度(基于 FPS 和丢帧率)
又卡了~从王者荣耀看Android屏幕刷新机制
这下大家应该知道了,帧就是一个静止画面,很多个帧一起就组成了视频、电影、游戏画面。
码上积木
2021/04/30
1K0
推荐阅读
相关推荐
【PerfDog专家课堂】APP&游戏需要关注Jank卡顿吗?
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档