流畅度测试

本文章转载于搜狗测试

对于任何产品来说,流畅度的重要性都不言而喻,流畅度的好坏,对一个产品的体验和口碑有着极大的影响。今天,小编就和大家一起学习下流畅度评测的相关内容~

什么是流畅度

我们都知道动画片其实是由一张张画出来的图片连贯执行产生的效果,当一张张独立的图片切换速度足够快的时候,会欺骗我们的眼睛,以为这是连续的动作。反之,当图片切换不够快时就会被人眼看穿,反馈给用户的就是卡顿现象。

Android绘制机制及卡顿原因

上图是在VSync机制下的绘制过程。VSync是Vertical Synchronization(垂直同步)的缩写,可以简单地把它认为是一种定时中断,Android规定,1秒钟有60个Vsync间隔,每个间隔时间为16.67ms,从图中看CPU 和GPU处理时间都很快,都少于一个VSync的间隔。

当CPU和GPU处理时间都很慢或者因为在主线程中干活太多,就会出现上图的现象。从上图可以看到CPU和GPU处理时间比较慢,都大于一个VSync的间隔,第二个VSync还在处理A区域的绘制。

现在的App每秒中最多能绘制60帧,1000ms/60帧=16.67ms/帧,也就是说对图像绘制的要求是平均每帧的绘制时间为16.67ms,超过了这个时间就可能造成不流畅的现象。

FPS测试流畅度的不足

FPS(Frames Per Secend)即一秒内绘制的帧数。FPS值越高画面越流畅。

举例:在测试输入法按键响应时,当我们按下按键到候选绘制完成的时间用了50ms,这个过程只用3帧就完成了,那么FPS就是3帧/秒,可见FPS值非常低,但是我们在测试过程中却没有发现卡顿的现象,这是为什么呢?

原因:输入法在1s内只有3帧的显示需求,50ms就画完了,那么FPS最高也只有3帧/秒。我们在使用输入法时,并没有每时每刻都在打字、滑动屏幕,很多时候输入法是处于静止的状态,这个时候输入法界面并不会进行图像绘制,那FPS就为1,但这个数并不能代表当前App在UI上界面不流畅。

结论:由此可见,FPS来衡量相对静止App的流畅度并不准确。

SM测试流畅度

VSync机制客户通过其Loop来了解当前App最高绘制能力,其机制如下:

1)固定每隔16.6ms执行一次;

2)如果没有绘制事件的时候也会运行这样一个Loop;

3)Loop在1s之内运行了多少次,即可以表示当前App绘制的最高能力,也就是App卡顿的程度。

if(存在帧的绘制):

Loop = 1 帧绘制完成所占用的Vsync间隔

else:

Loop = 1个Vsync间隔

所以SM计算方法为Loop在1s内运行了多少次(Loops per seconds)。Android机制中有一个Choreographer对象,当收到Vsync信号时,通过postCallback设置的回调函数调用使用者,在每一个Loop运行前通知我们,我们只需要数一下一秒内通知我们的次数就可以了。

使用腾讯提供的测试工具GT对流畅度进行测试,主界面如下图所示:

使用步骤为:

1)设计流畅度评测的动作;

2)打开“流畅度调试”;

3)点击“检测”,如果结果不“OK”,点击“更改”,然后再点击“重启”;如果结果为“OK”,选中被调试的进程后点击开始;

4)进入“参数”界面,点击“编辑”,拖动“SM”至“悬浮窗展示的参数”,可以实时看到SM的变化,然后点击“出参列表”右侧的红色按钮开始;

5)操作被测App,完成后点击“SM”可以看到评测的相关数据,包括:次数、平均值、最小值等;

6)点击“出参列表”右侧的红色按钮结束,结束后点击“保存”可以将评测的数据保存在相应的目录下。

流畅度优化

一开始发现App有卡顿的情况后,首先去查看我们的App是不是存在过度绘制的问题。过度绘制是指屏幕上的某个像素在同一帧的时间内被绘制了多次,在多层次的UI结构里面,如果不可见的UI也在做绘制的操作,这就会导致某些像素区域被绘制了多次。这就浪费大量的CPU以及GPU资源。过度绘制显示的四种颜色如下图所示,关于过度绘制详细问题可参考《Android GPU之过度绘制与图形渲染优化》

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 141,022评论 1 296
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 60,531评论 1 254
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 92,811评论 0 210
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 40,662评论 0 171
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 48,341评论 1 250
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 38,549评论 1 169
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 30,248评论 2 266
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 29,023评论 0 161
  • 想象着我的养父在大火中拼命挣扎,窒息,最后皮肤化为焦炭。我心中就已经是抑制不住地欢快,这就叫做以其人之道,还治其人...
    爱写小说的胖达阅读 28,764评论 6 225
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 32,375评论 0 211
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 29,146评论 2 212
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 30,454评论 1 222
  • 白月光回国,霸总把我这个替身辞退。还一脸阴沉的警告我。[不要出现在思思面前, 不然我有一百种方法让你生不如死。]我...
    爱写小说的胖达阅读 24,146评论 0 31
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 26,992评论 2 210
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 31,364评论 3 201
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 25,575评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 25,918评论 0 163
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 33,329评论 2 227
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 33,447评论 2 229

推荐阅读更多精彩内容