Flutter如何正确使用图片资源

简介: Flutter如何正确使用图片资源
现况

在使用Flutter中Image控件加载本地图片时,我们一般使用如下:

// 图片资源放在"assets/images"目录下.
Image.asset("assets/images/muma.png"),

那么问题就来了,这样使用可能会出现一些问题。

  • 问题1:如果目录没写对,或者后面路径修改了这里忘记修改了,就会导致图片显示错误。
  • 问题2:如果开发人员误删除图片资源,编译不会报错,会导致问题出现。
  • 问题3:如果后面路径需要更改,那么使用的地方都需要修改,修改起来特别的麻烦。
需求
  • 方便使用图片资源,可以参考Android。
  • 图片资源删除后,编译报错提示。防止图片资源删除导致程序问题。
  • 设计一个脚本,方便一键生成,方便易用。
实现
解决方案1

在刚使用Flutter开发的时候就发现了这个问题,起初解决方案是这样的。定义个类,提供返回图片资源路径。具体如下

class ImageUtils {
  static String getImgPath(String name, {String format: 'png'}) {
    return 'assets/images/$name.$format';
  }
}

其实使用此方式可以解决问题1和问题3,修改路径的话也只需要在此类中修改路径即可。但是没有解决问题2,如果开发人员勿删还在使用的图片资源时,编译是不会报错的,运行也是没有问题的,只有到使用此图片资源的界面才会发现错误,导致bug出现。


解决方案2

我们可以参考android资源的使用方式,在Android中使用资源文件都是 R.id.xxxx来引用的,那么我们是否也可以让Flutter也类似这么使用呢?思路是可行的。

思路
  • 切换到图片资源路径,读取目录图片资源。
  • 创建一个R文件(r.dart),写入一个R类,然后遍历图片资源,在R文件中的R类里,定义静态常量(可以使用图片资源名+后缀名定义常量名,方便用户使用)赋值为图片资源路径。
  • 使用是通过R.xxx即可。

通过这些思路,我们可以写一个脚本,来实现这个效果。你可以选择你擅长的脚本语言,shell或者py都是可以的。如果自己不擅长写脚本可以通过chatgpt来实现,很简单的,只要把自己的需求告诉他就可以了。这里我选择shell来实现。

具体实现
  • 步骤1:首先创建一个文件res_build.sh,内容如下
#!/usr/bin/env bash

# 定义资源目录和输出目录
resourcesDir="assets/images"
outputDir="lib"

# 切换到资源目录,获取资源数量和数据
cd "$resourcesDir" || exit
resCount=$(find ./* | wc -l | sed -e 's/^[[:space:]]*//')
resources=$(ls)

# 切换到输出目录
cd ../..
cd "$outputDir" || exit

# 遍历资源文件并汇总资源名集合
declare -a resNames
for resource in $resources; do
  resNames+=("$resource")
done

# 创建资源r文件
progress=1
# 删除r文件
rm -f r.dart
# 类名写入r文件
echo 'class R {' >>r.dart
# 循环申明常量写入r文件
for resName in "${resNames[@]}"; do
  nameSlices=($(echo "$resName" | tr '_' ' ' | tr '.' ' '))
  str=""
  for slice in "${nameSlices[@]}"; do
    str+="${slice}_"
  done
  resConstant="${str%?}"
  echo -ne "${progress}/${resCount}:${resName} \r"
  printf "  static const String %s = '%s/%s';\n" "$resConstant" "$resourcesDir" "$resName" >>r.dart
  progress=$((progress + 1))
done
echo '}' >>r.dart

# 自动格式化 Dart 代码文件
dart format --fix r.dart

注意:这里是拿我的flutter_xy项目来测试实现的。所以大家可以按照自己的项目情况修改。


  • 步骤2:添加或删除图片后,都需要执行res_build.sh脚本文件

注:如果提示bash: ./res_build.sh: Permission denied,可以执行 chmod +x res_build.sh 授权。

  • 步骤3:执行步骤2后会生成一个R文件
class R {
  static const String fudai_png = 'assets/images/fudai.png';
  static const String fuli1_png = 'assets/images/fuli1.png';
  static const String fuli2_png = 'assets/images/fuli2.png';
  static const String fuli3_png = 'assets/images/fuli3.png';
  static const String img1_jpg = 'assets/images/img1.jpg';
  static const String img2_jpg = 'assets/images/img2.jpg';
  static const String img3_jpg = 'assets/images/img3.jpg';
  static const String img4_jpg = 'assets/images/img4.jpg';
  static const String muma_png = 'assets/images/muma.png';
}
  • 步骤4:在需要使用图片资源的地方,直接使用R.xxx即可。

注意:每次更新图片时,不管是新增还是删除图片,都需要执行脚本更新R文件即可。如果删除了图片,更新脚本后,原来使用的地方会编译报错,这样开发人员就知道了,避免了bug产生。

相关文章
|
9月前
|
缓存 Java 开发工具
Flutter的文本、图片和按钮使用
Flutter的文本、图片和按钮使用
84 0
|
10月前
|
存储 前端开发 文件存储
Flutter笔记:关于应用程序中提交图片作为头像
1. 头像选择与提交的一般步骤Flutter笔记关于应用程序中提交图片作为头像作者目 录1. 头像选择与提交的一般步骤2. 选择本地文件到头像的示例代码3. 将图像提交到后端1. 头像选择与提交的一般步骤image将处理后的图像作为用户的头像显示在应用程序中。您可以使用Image或小部件来加载和显示图像。这些步骤涵盖了从选择图像到上传、处理和显示图像的基本流程。请根据您的具体需求和后端实现来自定义这些步骤。此外,确保您的应用程序有适当的权限以访问设备上的相册或相机,这通常需要在和。
228 0
|
2天前
Flutter-自定义图片3D画廊
Flutter-自定义图片3D画廊
|
2月前
flutter 引用图片资源遇到的问题
flutter 引用图片资源遇到的问题
23 1
|
2月前
|
开发框架 前端开发 定位技术
【Flutter 前端技术开发专栏】Flutter 中的插件市场与开源资源利用
【4月更文挑战第30天】Flutter插件市场和开源资源加速开发进程。pub.dev是官方插件库,提供大量第三方插件,节约时间和保证质量。选择插件时关注功能需求、评价及维护状况。开源资源作为学习、解决问题和创新的平台,需注意版权、代码质量和兼容性。案例分析展示插件应用,开源社区促进交流与技术进步,未来市场将持续发展。善用资源,提升开发效率与项目竞争力。
【Flutter 前端技术开发专栏】Flutter 中的插件市场与开源资源利用
|
2月前
|
XML JSON 前端开发
【Flutter前端技术开发专栏】Flutter中的图片、视频与网络资源加载
【4月更文挑战第30天】Flutter是谷歌的开源前端框架,因其高性能、流畅UI和多端运行能力受开发者喜爱。本文聚焦于Flutter中的资源加载:使用`Image`组件加载静态、网络和本地图片;通过`video_player`库加载和播放视频;利用`http`包进行网络资源请求。掌握这些技巧将有助于提升Flutter应用的开发效率和质量。
【Flutter前端技术开发专栏】Flutter中的图片、视频与网络资源加载
|
2月前
|
Dart
Flutter 学习之图片的选择、裁切、保存
Flutter 学习之图片的选择、裁切、保存 在Flutter中,我们可以通过调用系统的图片选择器来选择一张图片,也可以通过使用插件来实现图片的裁切和保存。
147 0
|
8月前
|
缓存 编解码 JavaScript
快速掌握 Flutter 图片开发核心技能
快速掌握 Flutter 图片开发核心技能
94 0
|
9月前
|
存储 缓存 编解码
Flutter笔记:图片的 precacheImage 函数
precacheImage 是 Flutter 中提供的一个函数。顾名思义,pre预先、cache缓存、Image图片,很容易看出 precacheImage 函数用于预加载图像并将其缓存到图像缓存中。这个函数是非常有用的,因为它可以在用户实际需要显示图像之前,提前将图像加载到内存中,以提高图像的加载速度。这对于提供更好的用户体验和性能非常重要,特别是当项目中有多个图像需要显示时。
103 0
|
12月前
|
存储 Android开发
Flutter控件之图片Image封装
Flutter中偏偏原生的控件,少了很多需要又常用的属性,比如宽高,比如内外边距,又比如点击事件,如果不采取封装,视图的结构会一层嵌套一层,徒增很多的冗余代码,所以,为了简洁代码,还有为了拓展原生组件没有的属性,就不得不进行一次简单的封装,使其在调用的时候,可以很方便的实现某些功能。
107 0