在 Flutter 中使用 flutter_gen 简化图像资产管理

开发 前端
你在 Flutter 的世界里 ,创建你很棒的应用程序。你有这些很酷的图片,但问题是,你必须手动输入这些图片的路径。这就像写下美味蛋糕的食谱 ,但有很多机会把配料混在一起或拼错 。这不好玩,对吧?

你是否厌倦了在 Flutter 项目中手动管理图像资产的繁琐任务?

告别手工输入资源路径的痛苦,欢迎使用“Flutter Gen”高效资源管理的时代。在本文中,我将带您从手动处理图像资源的挫折到动态生成它们的便利。

选择1:痛苦手动添加--管理图像资产的传统方法  😥

想象一下,你在 Flutter 的世界里 ,创建你很棒的应用程序。你有这些很酷的图片,但问题是,你必须手动输入这些图片的路径。这就像写下美味蛋糕的食谱 ,但有很多机会把配料混在一起或拼错 。这不好玩,对吧?

这是手动向项目添加图像的方法:

  1. 将所需的图片添加到项目中的  assets  文件夹中。
  2. 将图像的路径添加到  pubspec.yaml  文件中。
  3. 直接在代码中输入路径来获取图像。

图片图片

选择2:为所有资产创建一个常量变量  🤔

让我们创建一个名为  constants.dart  的常量文件,在这个文件中,创建一个名为  Constants  的类,这个类将包含存储资源路径的变量。

图片图片

在代码中直接使用这个变量来获取图像。

图片图片

选择3:动态生成资产 🤯🪄

现在,神奇的事情发生了,我们将使用一个包, flutter_gen[1]  一个 flutter 代码生成器,用于我们的资产、字体、颜色等,以生成所需的资产。

将所需的包添加到  pubspec.yaml   文件中。

  • 首先,在应用的依赖中添加  flutter_gen 。
  • 然后,在你的应用的 dev_dependencies 中添加  flutter_gen_runner  和  build_runner 。
  • 在终端中运行  flutter pub get 。

图片图片

生成资产。

在终端中运行以下命令来生成所有资源:flutter packages pub run build_runner build。这将创建一个文件夹  lib/gen  ,在该文件夹中,将有一个名为  assets.gen.dart  的文件。该文件夹包含所有资产信息!

图片图片

图片图片

正如你所看到的,生成的文件有一个变量 dash,它保存了图像的路径。

在代码中直接使用生成的文件来获取图像。

图片图片

import 'package:asset_generation/gen/assets.gen.dart';
import 'package:flutter/material.dart';

class Page1 extends StatelessWidget {
  const Page1({super.key});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: const Text('Assets'),
      ),
      body: Center(
        child:
            // Image.asset('assets/dash.png'),
            // Image.asset(Constants.dashImage),
            Image.asset(Assets.dash.path),
      ),
    );
  }
}

可以将其视为拥有一位神奇的厨师 👩🏻🍳,他可以随时烹制新菜肴,而无需新食谱。想要向您的应用程序添加新图像吗?没问题——Flutter Gen 为您提供支持。

如果您有兴趣了解有关 flutter_gen 包的更多信息,我建议您查看官方文档:https://pub.dev/packages/flutter_gen。

https://medium.com/flutter-community/streamlining-image-asset-management-b57b7fcb5b9d

责任编辑:武晓燕 来源: 独立开发者张张
相关推荐

2021-10-04 09:25:28

Flutter图像Web

2024-01-08 11:39:57

FlutterUI设计

2020-10-10 19:14:09

FlutterApp软件开发

2010-01-18 09:37:39

JSF 2.0Java EE 6

2019-11-25 11:20:08

FlutterWeb应用软件开发

2023-07-07 12:26:39

携程开发

2009-04-12 08:46:43

Symbian诺基亚移动OS

2023-11-12 11:54:55

UX性能widget

2020-07-08 08:22:08

FlutterSVGPNG

2021-01-22 14:03:34

Flutter系统鸿蒙

2021-05-06 08:04:37

存储StratisCentos 8

2021-10-14 18:00:51

systemd系统管理员系统运维

2023-11-01 07:44:29

转转Flutter业务

2022-12-21 16:53:59

LinuxConverterGUI

2013-11-20 15:32:13

红帽RedHatYUM包

2019-09-12 13:54:09

谷歌 Flutter开发者

2024-04-26 14:25:58

工业物联网资产管理

2022-03-15 08:00:00

Flutter开发工具

2013-12-13 17:21:14

Lua脚本语言

2009-06-25 16:49:24

Hibernate
点赞
收藏

51CTO技术栈公众号