Flutter性能监控工具(2)--- Performance Overlay

栏目: IOS · Android · 发布时间: 6年前

内容简介:如下图:这个浮窗有两个图形:每个图形绘制的都是该线程最后300帧的数据。

如下图:

Flutter性能监控工具(2)--- Performance Overlay

这个浮窗有两个图形:

  1. 上面的是GPU thread 表示在GPU线程上生成每帧需要的时间。
  2. 下面的UI thread 表示在UI线程上生成每帧需要的时间。

每个图形绘制的都是该线程最后300帧的数据。

为了保证60FPS,每帧耗费的时间应该是小于16ms的,看上图中绿色的粗线条,代表的是当前帧的数据,如果当前帧的数据符合预期(<16ms),那么就是绿色的,如果不符合,就是红色的,如下图:

Flutter性能监控工具(2)--- Performance Overlay

遇到红色的就需要去具体分析,因为会造成APP卡顿:

  1. 如果GPU thread是红色的

    说明当前场景太复杂了,导致无法快速渲染

  2. 如果UI thread是红色的

    说明肯定是Dart代码里有耗时操作,导致阻塞了UI操作。

  3. 如果两个都是红色的 建议从UI thread,也就是Dart代码查起。

0x02 如何开启Performance Overlay

开启Performance Overlay的方法有三种:

1、 Flutter Inspector

Flutter Inspector是一个强大的工具,Performance Overlay的功能也集成在Flutter Inspector里。

需要我们运行Flutter APP后才可以使用,

  1. 在Android Studio里

选择 View > Tool Windows > Flutter Inspector,就可以打开Flutter Inspector,可以看到有很多功能,如下图:

Flutter性能监控工具(2)--- Performance Overlay

然后选择Performance Overlay。

  1. 在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'),
    );
  }
}
复制代码

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

无处安放的互联网隐私

无处安放的互联网隐私

【美】茱莉亚·霍维兹 【美】杰拉米·斯科 / 中国人民大学出版社有限公司 / 2017-7-1 / CNY 55.00

在当今互联网时代,我们的隐私权已经受到了威胁,政府或企业可以追踪我们的电话,搜索引擎可以记录我们的在线浏览记录以及恒温器的设置以及更多信息。在当代,保卫隐私权不只是简单地描述出存在的问题或者警告人们隐私权已经丧失,隐私权的护卫者们提出了解决策略。他们密切关注商业实践、公共政策和技术设计以及人物,应该继续下去吗?条件就是:有问题,让我们找到解决之道。一起来看看 《无处安放的互联网隐私》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码

html转js在线工具
html转js在线工具

html转js在线工具