flutter 如何设置app的图标?

来源:AI回答,亲测可用。

在 Flutter 中设置 App 图标,最推荐、最高效的方法是使用 flutter_launcher_icons 插件。手动替换每个尺寸的图片非常繁琐且容易出错,而这个插件可以自动为你生成所有适配尺寸。

以下是具体的操作步骤:


第一步:准备图标文件

准备一张高分辨率的图标图片(建议 1024x1024 像素,格式为 .png)。

在你的 Flutter 项目根目录下创建一个 assets 文件夹(如果还没有的话),并将图标放入其中,例如命名为 logo.png

第二步:添加插件依赖

打开项目中的 pubspec.yaml 文件,在 dev_dependencies 下添加该插件:

yaml 复制代码
dev_dependencies:
  flutter_test:
    sdk: flutter
    flutter_launcher_icons: ^0.14.4  # 请检查 pub.dev 获取最新版本

第三步:配置插件

同样在 pubspec.yaml 文件中,添加插件的配置参数(可以放在文件最底部):

yaml 复制代码
flutter_launcher_icons:
  android: "launcher_icon"
  ios: true
  image_path: "assets/logo.png"
  min_sdk_android: 21 # android min sdk warning fix
  # 如果需要 Android 的自适应图标(Adaptive Icon),可以添加以下两行:
  # adaptive_icon_background: "#ffffff" # 背景颜色或背景图
  # adaptive_icon_foreground: "assets/logo_foreground.png" # 前景图

第四步:运行命令生成图标

在终端(Terminal)中运行以下两条命令:

  1. 获取插件:
bash 复制代码
flutter pub get
  1. 执行生成脚本:
bash 复制代码
flutter pub run flutter_launcher_icons

以上执行会有个警告提示Deprecated. Use dart run instead.,更优的方式:

bash 复制代码
dart run flutter_launcher_icons

常见注意事项

  • Android 自适应图标: 从 Android 8.0 开始,建议使用 adaptive_icon。如果你只提供了一张图,插件会将其居中处理,但效果可能不如专门设计的"前景+背景"组合好。
  • 缓存问题: 有时候运行完命令后,模拟器上的图标没有变化。这通常是缓存导致的,请尝试卸载 App 后重新运行 flutter run
  • 图标透明度: iOS 图标不能有透明度(必须是实色背景),否则在上架 App Store 审核时会被拒绝。

手动更改方式(不推荐)

如果你不想使用插件,可以手动替换以下路径的文件:

  • Android: android/app/src/main/res/mipmap-* 目录下的所有文件。
  • iOS: ios/Runner/Assets.xcassets/AppIcon.appiconset 目录下的所有尺寸。

你想了解如何为 Android 设置那种可以变换形状的"自适应图标(Adaptive Icons)"的具体设计规范吗?

相关推荐
月光下的丝瓜8 小时前
Flutter 国内安装指南
前端·flutter
恋猫de小郭3 天前
Amper 正式转正 Kotlin Toolchain ,Gradle 未来何去何从
android·前端·flutter
张风捷特烈3 天前
Flutter 类库大揭秘#02 | path_provider 各平台实现
前端·flutter
TT_Close4 天前
别劝退了!5秒搞定 Flutter 鸿蒙 FVM 起跑线
flutter·harmonyos·visual studio code
你听得到114 天前
用户说 App 卡,但说不清在哪?我把 Flutter 监控 SDK 升级成了链路观测工作台
前端·flutter·性能优化
stringwu5 天前
Flutter 开发必备:MVI 架构的高效实现指南
前端·flutter
程序员老刘6 天前
Flutter版本选择指南:3.44系列继续观望 | 2026年6月
flutter·ai编程·客户端
用户965597361908 天前
Provider vs Bloc vs GetX vs Riverpod:Flutter 状态管理方案怎么选?
flutter
恋猫de小郭8 天前
Flutter Patchwork,不用 Fork 改依赖包源码的第三方工具
android·前端·flutter
程序员老刘8 天前
跑分第一的编程大模型,我为啥不用?
flutter·ai编程·vibecoding