开启硬件加速导致动画掉帧分析

背景

最近碰到一个动画卡顿的问题,花了比较多的精力进行解决,并从中总结出来一些分析的套路,特此进行分享。
卡顿掉帧的现象:


gte96-fhw59.gif

正常的现象:


94njj-wcbhv.gif

从现象可以看出,应用信息展开的时候,有一定的卡顿。

绘制原理

image.png

要在屏幕上显示,其实要经过一系列的过程,Android 应用程序把经过测量、布局、绘制后的 surface 缓存数据,通过进程通信的方式,把数据给到SurfaceFlinger ,SurfaceFlinger这把这些图层的数据根据surface的排序进行混合,最后把混合之后的数据渲染到显示屏幕上, 通过 Android 的刷新机制来刷新数据。也就是说应用层负责绘制,系统层负责渲染,通过进程间通信把应用层需要绘制的数据传递到系统层服务,系统层服务通过刷新机制把数据更新到屏幕上。


image.png

surfaceflinger在初始化时设置VnSync信号周期,一般为16ms,之后监听Vnsync信号,在收到信号之后,重新走混合渲染流程。
开发app的性能目标就是保持60fps,这意味着每一帧你只有16ms≈1000/60的时间来处理所有的任务。Android系统每隔16ms发出VSYNC信号,触发对UI进行渲染,如果每次渲染都成功,这样就能够达到流畅的画面所需要的60fps。


image.png

如果你的某个操作花费时间是24ms,系统在得到VSYNC信号的时候就无法进行正常渲染,这样就发生了丢帧现象。那么用户在32ms内看到的会是同一帧画面。
image.png

丢帧情况 卡顿情况
0-10帧 流畅
10-20帧 较卡
20-40帧 很卡
40-60帧 卡死了

卡顿分析

通过systrace抓取launcher应用卡顿时候的信息,获取的traceview,掉帧的的部分如下:


捕获1.PNG

线程在traceview中的信息包括两部分,线程运行状态,和线程运行方法栈。
通过颜色判断线程运行状态,各个颜色的含义为:
灰色:sleeping,线程休眠状态
蓝色:runnable,线程就绪状态
绿色:running,线程运行状态
从掉帧的的线程的运行状态判断,在掉帧的时候,UI线程状态色颜色为长时间灰色,处于sleeping状态。直接原因找到了,找到导致卡顿的元凶近了一步。
导致UI线程挂起的线程,一般也是将UI线程唤醒的线程。
在traceview中双击UI线程结束休眠后,变成就绪的第一个状态,也就是从灰色变成蓝色的第一个状态,可以发现,导致挂起的线程的线程号为27005。


捕获2.PNG

在traceview中搜索27005,可以知道此线程名为RenderThread,也就是硬件加速专门用来渲染的线程。


捕获3.PNG

并且从图中可看出在UI线程被唤醒前,RenderThread线程刚刚执行完syncFrameState方法。


捕获4.PNG

RenderThread的工作流程

RenderThread的工作流程可以参考 https://www.jianshu.com/p/bc1c1d2fadd1
简单的来说RenderThread的工作流程为:
1.将Main Thread维护的Display List同步到Render Thread维护的Display List去。这个同步过程由Render Thread执行,但是Main Thread会被阻塞住。
2.如果能够完全地将Main Thread维护的Display List同步到Render Thread维护的Display List去,那么Main Thread就会被唤醒,此后Main Thread和Render Thread就互不干扰,各自操作各自内部维护的Display List;否则的话,Main Thread就会继续阻塞,直到Render Thread完成应用程序窗口当前帧的渲染为止。
3.Render Thread在渲染应用程序窗口的Root Render Node的Display List之前,首先将那些设置了Layer的子Render Node的Display List渲染在各自的一个FBO上,接下来再一起将这些FBO以及那些没有设置Layer的子Render Node的Display List一起渲染在Frame Buffer之上,也就是渲染在从Surface Flinger请求回来的一个图形缓冲区上。这个图形缓冲区最终会被提交给Surface Flinger合并以及显示在屏幕上。

注意第二步:“如果能够完全地将Main Thread维护的Display List同步到Render Thread维护的Display List去,那么Main Thread就会被唤醒”,这个就验证了我们从traceview中看到的在RenderThread完成syncFrameState之后,UI线程被唤醒。

综述

掉帧的根本原因是RenderThread的绘制时间过长。UI线程在Draw方法中,完成将数据放入displaylist之后会挂起,等待Render Thread将displaylist的数据同步,也就是完成syncFrameState方法。如果RenderThread一直在绘制,那么UI线程挂起的时间就会很长,整个绘制市场就会超过16ms,最终导致掉帧。

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

推荐阅读更多精彩内容

  • 转载:http://tech.meituan.com/hardware-accelerate.html 在手机客户...
    kkgo阅读 664评论 0 1
  • 1 CALayer IOS SDK详解之CALayer(一) http://doc.okbase.net/Hell...
    Kevin_Junbaozi阅读 5,088评论 3 23
  • 页面渲染背景知识: 页面渲染时,被绘制的元素最终转换为矩阵像素点(多维数组的形式),才能被显示器显示 页面由各种基...
    三十二蝉阅读 1,676评论 0 3
  • 今晚的作业,因为三次谎话而屡遭停滞,娃上床已经快11点了,我这会儿还在洗衣服, 允许事情在变好之前出现糟糕的状况,...
    冰糖诚阅读 135评论 0 0
  • 活着浪费空气,死了浪费土地,半死不活浪费人民币。 猛的一看你不怎么样,仔细一看还不如猛的一看。 ...
    禁锢流星雨阅读 687评论 2 0