FSA全栈行动 FSA全栈行动
首页
  • 移动端文章

    • Android
    • iOS
    • Flutter
  • 学习笔记

    • 《Kotlin快速入门进阶》笔记
    • 《Flutter从入门到实战》笔记
    • 《Flutter复习》笔记
前端
后端
  • 学习笔记

    • 《深入浅出设计模式Java版》笔记
  • 逆向
  • 分类
  • 标签
  • 归档
  • LinXunFeng
  • GitLqr

公众号:FSA全栈行动

记录学习过程中的知识
首页
  • 移动端文章

    • Android
    • iOS
    • Flutter
  • 学习笔记

    • 《Kotlin快速入门进阶》笔记
    • 《Flutter从入门到实战》笔记
    • 《Flutter复习》笔记
前端
后端
  • 学习笔记

    • 《深入浅出设计模式Java版》笔记
  • 逆向
  • 分类
  • 标签
  • 归档
  • LinXunFeng
  • GitLqr
  • AndroidUI

  • Android第三方SDK

  • Android混淆

  • Android仓库

  • Android新闻

  • Android系统开发

  • Android源码

  • Android注解AOP

  • Android脚本

  • AndroidTv开发

  • AndroidNDK

  • Android音视频

  • Android热修复

  • Android性能优化

  • Android云游戏

  • Android插件化

  • iOSUI

  • iOS工具

  • iOS底层原理与应用

  • iOS组件化

  • iOS音视频

  • iOS疑难杂症

  • iOS之Swift

  • iOS之RxSwift

  • iOS开源项目

  • iOS逆向

  • Flutter开发

    • Dart - 抽象类的实例化
    • Flutter - 打印好用的Debug日志
    • Flutter - 混合开发
    • Flutter - 解决混合开发iOS脚本打包遇到的问题
    • Flutter - 低版本在iOS14上遇到的问题与解决方案
    • Flutter - 解决原生弹窗的触摸事件被Flutter响应的问题
    • Flutter - 实现列表上下拉切换header
    • Flutter - 获取ListView当前正在显示的Widget信息
    • Flutter - 列表滚动定位超强辅助库,墙裂推荐!🔥
    • Flutter - 快速实现聊天会话列表的效果,完美💯
    • Flutter - 聊天输入框更新文本时的必备优化点🔖
    • Flutter - 我给官方提PR,解决run命令卡住问题 😃
    • Flutter - 探索run命令到底做了什么 🤔
    • Flutter - 引擎调试(iOS篇)🛠
    • Flutter - 引擎调试bug到提交PR实战 🐞
    • Flutter - 船新升级😱支持观察第三方构建的滚动视图💪
    • Flutter - 瀑布流交替播放视频 🎞
    • Flutter - IM保持消息位置大升级(支持ChatGPT生成式消息) 🤖
    • Flutter - 滚动视图中的表单防遮挡 🗒
    • Flutter - 秒杀1/2曝光统计 📊
    • 一天内加入 Flutter 和 FlutterCandies 两大组织是什么体验 🧐
    • Flutter - 如何快速搓一个微信通讯录列表(azlist) 📓
    • Flutter - 混编项目集成Shorebird热更新🐦(安卓篇)
    • Flutter - 混编项目集成Shorebird热更新🐦(iOS篇)
    • Flutter - 解决返回原生页面时dispose方法未被触发的问题 🐞
    • Flutter - 升级3.19之后页面多次rebuild?🤨
    • Flutter - 热更新 Shorebird 1.0 正式版来了 🐦
    • Flutter - 使用Pigeon实现视频缓存插件 🐌
    • Flutter - 轻松搞定屏幕旋转功能 😎
    • Flutter - 解决Connection closed before full header was received
    • Flutter - 实现聊天键盘与功能面板的丝滑切换 🍻
    • Flutter - 支持观察NestedScrollView,兼容性更强 😈
    • Flutter - 聊天键盘与面板丝滑切换的强势升级 🍻
    • Flutter - 升级到3.24后页面还会多次rebuild吗?🧐
    • Flutter - 轻松实现PageView卡片偏移效果
    • Flutter - 轻松搞定炫酷视差(Parallax)效果
    • Flutter - 危!3.24版本苹果审核被拒!
    • Flutter - 子部件任意位置观察滚动数据
    • Flutter - iOS编译加速
    • Flutter - Xcode16 还原编译速度
    • Flutter - GetX Helper 助你规范应用 tag
    • Flutter - GetX Helper 如何应用于旧页面
    • Flutter - 聊天面板库动画生硬?这次让你丝滑个够
    • Flutter - 使用本地 DevTools 验证 SVG 加载优化
      • 背景
      • SVG 加载优化
      • 使用本地 DevTools
        • 拉源码
        • 调整项目配置
      • 验证
  • 移动端
  • Flutter开发
LinXunFeng
2025-08-07
目录

Flutter - 使用本地 DevTools 验证 SVG 加载优化

欢迎关注微信公众号:[FSA全栈行动 👋]

# 背景

在 Medium 上看到一篇 SVG 加载优化的文章,于是我打算着手试试并验证。

文章链接: https://medium.com/software-genesis-group/supercharging-flutter-vectors-how-i-reduced-svg-rasterization-time-by-98-e5b6c38bc7b7 (opens new window)

文中是通过 raster stats 进行验证的,但是 DevTools 自 2.37.2 版本起移除了 raster stats~

详细说明可看: https://docs.flutter.dev/tools/devtools/release-notes/release-notes-2.37.2 (opens new window)

注:其实在源码中是从 2.37.0 开始就被移除了的,只是正式发布的 2.37.x 版本为 2.37.2,所以官方文档里写的是 2.37.2 这个版本~

移除的原因是 raster stats 对 Impeller 渲染引擎不起作用,但是 Impeller 在安卓上不稳定,所以我们安卓端目前还是使用的 Skia,所以我打算指定使用本地旧的 DevTools 来进行验证。

当然了,新建项目并使用旧的 Flutter 版本也可以,我这里更多的是为了尝试指定本地 DevTools~

如果你有除 raster stats 的其它验证方式,欢迎留言跟大家分享。

# SVG 加载优化

pubspec.yaml

dependencies:
  vector_graphics: any

dev_dependencies:
  vector_graphics_compiler: any
  
flutter:
  assets:
    # 旧的
    # - assets/svg/
    # 新的
    - path: assets/svg/
      transformers:
        - package: vector_graphics_compiler

之前的 SvgPicture 的加载方式

SvgPicture.asset(
  'assets/svg/Chat-bot-cuate.svg',
  width: 300,
  height: 300,
),

调整为 VectorGraphic 去加载

child: const VectorGraphic(
  loader: AssetBytesLoader('assets/svg/Chat-bot-cuate.svg'),
  width: 300,
  height: 300,
),

这里需要注意一下,assets/svg/ 目录加上 transformers 后 SvgPicture.asset 就无法正常加载咯,如果不能一次性迁移调整,建议新增个子目录去处理。

SVG 的加载优化就搞定了,接下来讲讲如何指定使用本地旧的 DevTools 来进行验证。

# 使用本地 DevTools

# 拉源码

# DevTools

git clone https://github.com/flutter/devtools.git

切到你想要使用的版本 tag

git checkout v2.36.0

# Dart

这里看你使用的 Flutter 的版本情况,我当前是 3.24.5,对应的 Dart 版本为 3.6.2

git clone https://github.com/dart-lang/sdk.git

切到你想要使用的版本 tag

git checkout 3.6.2

# 调整项目配置

这里以 VSCode 为例,打开 .vscode/settings.json,添加如下配置

{
    // Flutter SDK 路径
    "dart.flutterSdkPath": "/Users/lxf/fvm/versions/3.24.5",
    // 使用自定义 DevTools
    "dart.customDevTools": {
        "path": "/path/to/devtools",
        "env": {
            // Dart 源码路径
            "LOCAL_DART_SDK": "/path/to/dart-lang/sdk",
            // Flutter 源码路径
            "FLUTTER_ROOT": "/Users/lxf/fvm/versions/3.24.5"
        }
    },
    // devTools 日志文件路径
    "dart.devToolsLogFile": "/path/to/devtools/lxf_devtools_log.txt",
}

注意,配置完成后,需重启 VSCode,或者执行 VSCode 的 Developer: Reload Window 方可生效。

重启后右下角会看到 Starting Custom Dart DevTools…,并且在项目的根目录下会生成对应的 lxf_devtools_log.txt 日志文件。

日志文件的内容大致如下

!! ⚠️ PLEASE REVIEW THIS LOG FOR SENSITIVE INFORMATION BEFORE SHARING ⚠️ !!
Dart Code extension: 3.114.2
Flutter extension: 3.114.0 (not activated)

App: Visual Studio Code
App Host: desktop
Version: mac 1.102.2


Logging Categories:
    DevTools

Thu Jul 26 2025 [17:28:45 GMT+0800 (中国标准时间)] Log file started
[17:28:47] [DevTools] [Info] Spawning /path/to/devtools/tool/bin/dt with args ["serve","--machine","--allow-embedding","--dtd-uri","ws://127.0.0.1:58813/3Td7Xo9WUO0gDIm7"]
...

本地 DevTools 启动失败时长这个样子:

Thu Jul 26 2025 [17:28:45 GMT+0800 (中国标准时间)] Log file started
[17:28:47] [DevTools] [Info] Spawning /path/to/devtools/tool/bin/dt with args ["serve","--machine","--allow-embedding","--dtd-uri","ws://127.0.0.1:58813/3Td7Xo9WUO0gDIm7"]
[DevTools] [Info] ..  in /path/to/devtools
[DevTools] [Info] ..  with {"toolEnv":{"FLUTTER_HOST":"VSCode","PUB_ENVIRONMENT":"vscode.dart-code","FLUTTER_ROOT":"/Users/lxf/fvm/versions/3.24.5"}}
[DevTools] [Info]     PID: 74050
[DevTools] [Info] Process errored! Error: spawn /path/to/devtools/tool/bin/dt ENOENT
[General] [Error] Dart DevTools exited with code -2.

遇到 Error: spawn /path/to/devtools/tool/bin/dt ENOENT 这个错误是因为本地使用的 devtools 比较旧,没有 dt 那些文件,其实就是原来的 devtools_tool 那些文件,将 devtools/tool/bin 下的三个文件名为 devtools_tool 的文件复制粘贴,并重命名为 dt 即可。

完成后再次 Developer: Reload Window 即可,首次启动本地 DevTools 时会去拉源码和安装依赖,时间上会稍久一些。

Thu Jul 24 2025 [17:56:46 GMT+0800 (中国标准时间)] Log file started
[17:56:48] [DevTools] [Info] Spawning /path/to/devtools/tool/bin/dt with args ["serve","--machine","--allow-embedding","--dtd-uri","ws://127.0.0.1:50090/8LqnJWrdN5p7ayst"]
[DevTools] [Info] ..  in /path/to/devtools
[DevTools] [Info] ..  with {"toolEnv":{"FLUTTER_HOST":"VSCode","PUB_ENVIRONMENT":"vscode.dart-code","FLUTTER_ROOT":"/Users/lxf/fvm/versions/3.24.5"},"envOverrides":{"FLUTTER_ROOT":"/Users/lxf/fvm/versions/3.24.5"}}
[DevTools] [Info]     PID: 13860
[DevTools] [Info] <== Running devtools_tool using the Dart SDK from /Users/lxf/fvm/default/bin/dart to create the Flutter SDK in tool/flutter-sdk.
[DevTools] [Info] <== Using Flutter SDK from /Users/lxf/fvm/versions/3.27.4
[DevTools] [Info] <== Updating to Flutter version from cache: tags/3.23.0-13.0.pre
[DevTools] [Info] <== Cloning Flutter into /path/to/devtools/tool/flutter-sdk
[DevTools] [Info] <== /path/to/devtools/tool > git clone https://github.com/flutter/flutter flutter-sdk

成功运行时会输出如下日志

[DevTools] [Info] <== [serve] serving DevTools with a local devtools server...
[DevTools] [Info] <== /path/to/dart-lang/sdk > /path/to/devtools/tool/flutter-sdk/bin/dart pkg/dds/tool/devtools_server/serve_local.dart --devtools-build=/path/to/devtools/packages/devtools_app/build/web --machine --allow-embedding --dtd-uri ws://127.0.0.1:54232/lOgRLna5Xl4Uhu7v
[DevTools] [Info] <== {"event":"server.started","method":"server.started","params":{"host":"127.0.0.1","port":9103,"pid":76659,"protocolVersion":"1.2.0"}}
[DevTools] [Info] ==> {"id":"1","method":"vscode.extensions.discover","params":{"rootPaths":["/path/to/flutter_test_demo"]}}
[DevTools] [Info] <== {"id":"1","result":{"/path/to/flutter_test_demo":{"extensions":[],"parseErrors":[]}}}

Open DevTools in Web Browser,点击右上角的问号验证一下版本号是否正确

# 验证

第三方库 渲染时间(ms) 平均帧率(FPS)
flutter_svg 50 68
vector_graphics 5.1 88

可以看到,使用 vector_graphics 来加载 SVG ,在渲染时间和平均帧率上确实是有很不错的提升的,验证大成功~

#Dart#Flutter#DevTools#SVG
上次更新: 2025/08/10, 11:28:06
Flutter - 聊天面板库动画生硬?这次让你丝滑个够

← Flutter - 聊天面板库动画生硬?这次让你丝滑个够

最近更新
01
AI - Gemini CLI 摆脱终端限制
07-27
02
Flutter - 聊天面板库动画生硬?这次让你丝滑个够
07-20
03
Flutter - GetX Helper 如何应用于旧页面
06-14
更多文章>
Theme by Vdoing | Copyright © 2020-2025 FSA全栈行动
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式
×