flutter R库对图片资源进行自动管理

项目中对资源的使用是开发过程中再常见不过的一环。 一般我们在将资源导入到项目中后,会通过资源名称来访问。 但在很多情况下由于我们疏忽输入错了资源名称,从而导致资源无法访问。 所以,急需解决两个问题:

  • 资源编译期可检查
  • 可方便预览资源

安装相关插件

在vscode中安装两个插件, 如下 :

● Flutter Assets Gen 插件: 负责资源生成

● Image preview 插件 : 负责资源图片预览

使用后的效果如下:

配置

插件安装完成后, 在pub.yaml中配置 。可放到文件最后, 最左对齐

yaml 复制代码
flutter_assets:
  assets_path: assets/images/
  output_path: lib/
  filename: r.dart
  classname: R

接着执行如下操作:

vscode 上点击 '查看' 下的 "命令面板" . 输入 Flutter Assets: Generate

如果配置都正确, 这时会在指定目录下生成 r.dart文件 。

类似如下 :

dart 复制代码
// ignore_for_file: prefer_single_quotes
class R {
  R._();

  /// Assets for assetsImagesIcLauncher
  /// assets/images/ic_launcher.png
  static const String assetsImagesIcLauncher = "assets/images/ic_launcher.png";

  /// Assets for assetsImagesIconBack
  /// assets/images/icon_back.png
  static const String assetsImagesIconBack = "assets/images/icon_back.png";

  /// Assets for assetsImagesIconCommunityGrey
  /// assets/images/icon_community_grey.png
  static const String assetsImagesIconCommunityGrey = "assets/images/icon_community_grey.png";

  /// Assets for assetsImagesIconCommunitySelected
  /// assets/images/icon_community_selected.png
  static const String assetsImagesIconCommunitySelected = "assets/images/icon_community_selected.png";

  /// Assets for assetsImagesIconHomeGrey
  /// assets/images/icon_home_grey.png
  static const String assetsImagesIconHomeGrey = "assets/images/icon_home_grey.png";
}

r.dart 文件将资源都声明为了全局常量,对比直接录入字符串的方式,减少了因录入不对而导致的加载失败问题。

使用

需要先导入 r.dart文件

dart 复制代码
import 'package:getx_demo/r.dart';
  • 显示本地图片 :
dart 复制代码
Image.asset(R.assetsImagesIconBack);
相关推荐
YUFENGSHI.LJ1 天前
Flutter 如何使用fvm进行多项目sdk管理
flutter
开心-开心急了1 天前
关于Flutter与Qt for python 的一些技术、开源、商用等问题
开发语言·python·qt·flutter
猫林老师1 天前
Flutter for HarmonyOS开发指南(四):国际化与本地化深度实践
flutter·华为·harmonyos
猫林老师2 天前
Flutter for HarmonyOS 开发指南(一):环境搭建与项目创建
flutter·华为·harmonyos
sunly_2 天前
Flutter:视频预览功能
javascript·flutter·音视频
勤劳打代码2 天前
条分缕析 —— 通过 Demo 深入浅出 Provider 原理
flutter·面试·dart
2501_915918412 天前
Flutter 加固方案对比与实战,多工具组合的跨平台安全体系(Flutter App 加固/IPA 成品混淆/Ipa Guard CLI/自动化安全流程)
安全·flutter·ios·小程序·uni-app·自动化·iphone
Bryce李小白2 天前
Flutter中mixing的原理及应用场景
flutter
_大学牲2 天前
从 0 到上架:用 Flutter 一天做一款功德木鱼
前端·flutter·apple
嚴寒2 天前
2025最终!Mac配置Flutter全平台开发环境完整指南(亲测有效)
前端·flutter