内容简介:如下图:这个浮窗有两个图形:每个图形绘制的都是该线程最后300帧的数据。
如下图:
这个浮窗有两个图形:
- 上面的是GPU thread 表示在GPU线程上生成每帧需要的时间。
- 下面的UI thread 表示在UI线程上生成每帧需要的时间。
每个图形绘制的都是该线程最后300帧的数据。
为了保证60FPS,每帧耗费的时间应该是小于16ms的,看上图中绿色的粗线条,代表的是当前帧的数据,如果当前帧的数据符合预期(<16ms),那么就是绿色的,如果不符合,就是红色的,如下图:
遇到红色的就需要去具体分析,因为会造成APP卡顿:
-
如果GPU thread是红色的
说明当前场景太复杂了,导致无法快速渲染
-
如果UI thread是红色的
说明肯定是Dart代码里有耗时操作,导致阻塞了UI操作。
-
如果两个都是红色的 建议从UI thread,也就是Dart代码查起。
0x02 如何开启Performance Overlay
开启Performance Overlay的方法有三种:
1、 Flutter Inspector
Flutter Inspector是一个强大的工具,Performance Overlay的功能也集成在Flutter Inspector里。
需要我们运行Flutter APP后才可以使用,
- 在Android Studio里
选择 View > Tool Windows > Flutter Inspector,就可以打开Flutter Inspector,可以看到有很多功能,如下图:
然后选择Performance Overlay。
- 在VS Code里
通过 View > Command Palette 或者 cmd+p 打开命令板,输入“performance” 然后选择 Toggle Performance Overlay 就行。
2. 使用代码设置
将 MaterialApp 或者 WidgetsApp 的showPerformanceOverlay 属性设置为true,如下:
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return MaterialApp(
showPerformanceOverlay: true,
title: 'My Awesome App',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: MyHomePage(title: 'My Awesome App'),
);
}
}
复制代码
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
打造Facebook
王淮、祝文让 / 印刷工业出版社 / 2013-2-1 / 39.80元
《打造Facebook》新书发布会,王淮与读者面对面,活动链接:http://www.douban.com/event/18166913/ 这本书的书名——《打造Facebook:亲历Facebook爆发的5年》很嚣张,谁有资格可以说这句话呢,当然,扎克伯格最有资格,但他不会亲自来告诉你,至少从目前的情况来看,近几年都不大可能。而且,这不是一个人的公司。里面的每一人,尤其是工程师,既是公司文......一起来看看 《打造Facebook》 这本书的介绍吧!