[重磅发布] Flutter Chen Generator 必备脚本工具

Flutter Chen Generator

🚀 一个强大的Flutter代码生成工具包,目前包含资源文件自动生成器,未来将添加更多实用工具。

✨ 功能特性

📁 资源生成器 (Assets Generator)

  • 🔄 自动扫描assets目录并生成Dart常量
  • 🧠 智能驼峰命名转换,保持原有驼峰格式
  • 🔧 处理文件命名冲突(同名不同扩展名)
  • 📝 自动更新pubspec.yaml配置
  • 🚫 支持忽略指定文件夹
  • ⚙️ 丰富的命令行参数配置
  • 📦 支持短命名和完整路径命名两种模式

🚀 安装

全局安装(推荐)

bash 复制代码
dart pub global activate flutter_chen_generator

本地依赖

yaml 复制代码
dev_dependencies:
  flutter_chen_generator: ^1.0.0

📖 使用方法

统一入口使用

bash 复制代码
# 生成资源文件
flutter_chen_generator assets

# 查看帮助
flutter_chen_generator --help

# 查看资源生成器帮助
flutter_chen_generator assets --help

直接使用资源生成器

bash 复制代码
# 基本使用
flutter_chen_assets

# 自定义配置
flutter_chen_assets \
  --assets-dir my_assets \
  --output lib/my_assets.dart \
  --class-name MyAssets \
  --full-naming \
  --ignore web,fonts,temp

📋 参数说明

资源生成器参数

参数 短参数 说明 默认值
--assets-dir -a 资源目录 assets
--output -o 输出文件 lib/generated/assets.dart
--class-name -c 类名 Assets
--short-naming - 简短命名 true
--full-naming - 完整命名 false
--ignore -i 忽略文件夹
--help -h 帮助信息 -

📂 生成示例

文件结构

arduino 复制代码
assets/
├── images/
│   ├── home/
│   │   ├── icon.png
│   │   └── icon.svg
│   └── user/
│       └── avatar.jpg
└── json/
    └── config.json

生成的代码 (短命名模式)

dart 复制代码
/// 自动生成的资源文件索引,请勿手动修改此文件
/// Generated by flutter_chen_assets_generator
class Assets {
  Assets._();

  static const String homeIcon = 'assets/images/home/icon.png';
  static const String homeIconSvg = 'assets/images/home/icon.svg';
  static const String jsonConfig = 'assets/json/config.json';
  static const String userAvatar = 'assets/images/user/avatar.jpg';
}

更新的pubspec.yaml

yaml 复制代码
flutter:
  assets:
    - assets/
    - assets/images/
    - assets/images/home/
    - assets/images/user/
    - assets/json/

🎯 命名规则

短命名模式(默认)

  • assets/images/home/icon.pnghomeIcon
  • assets/images/user/avatar.jpguserAvatar
  • assets/json/config.jsonjsonConfig

完整命名模式

  • assets/images/home/icon.pngimagesHomeIcon
  • assets/images/user/avatar.jpgimagesUserAvatar
  • assets/json/config.jsonjsonConfig

冲突处理

当同一文件夹存在同名不同扩展名文件时:

  • icon.pnghomeIcon (第一个保持原名)
  • icon.svghomeIconSvg (后续添加扩展名后缀)
  • icon.jpghomeIconJpg

智能驼峰处理

保持原有的驼峰格式:

  • inviteShare.pnghomeInviteShare (保持驼峰)
  • user_profile.pnghomeUserProfile (转换驼峰)

💡 使用技巧

1. CI/CD 集成

yaml 复制代码
# .github/workflows/flutter.yml
- name: Generate Assets
  run: flutter_chen_assets --no-update-pubspec

2. 忽略特定文件夹

bash 复制代码
# 忽略web相关文件
flutter_chen_assets --ignore web,fonts,node_modules

3. 多项目配置

bash 复制代码
# 项目A
flutter_chen_assets -a assets -o lib/assets.dart

# 项目B  
flutter_chen_assets -a resources -o lib/resources.dart -c Resources

🔮 未来计划

  • 🌐 国际化自动化脚本: 自动把项目国际化、导入导出excel
  • 📱 ScreenUtil自动化脚本: 自动智能添加ScreenUtil后缀
  • 🎨 图标生成器: 自动生成iconfont图标类

📄 许可证

MIT License - 查看 LICENSE 文件了解详情

⭐ 如果这个工具对你有帮助,请给个星标支持一下!

相关推荐
奋斗的小青年!!5 小时前
Flutter浮动按钮在OpenHarmony平台的实践经验
flutter·harmonyos·鸿蒙
程序员老刘8 小时前
一杯奶茶钱,PicGo + 阿里云 OSS 搭建永久稳定的个人图床
flutter·markdown
奋斗的小青年!!11 小时前
OpenHarmony Flutter 拖拽排序组件性能优化与跨平台适配指南
flutter·harmonyos·鸿蒙
小雨下雨的雨13 小时前
Flutter 框架跨平台鸿蒙开发 —— Stack 控件之三维层叠艺术
flutter·华为·harmonyos
行者9613 小时前
OpenHarmony平台Flutter手风琴菜单组件的跨平台适配实践
flutter·harmonyos·鸿蒙
小雨下雨的雨15 小时前
Flutter 框架跨平台鸿蒙开发 —— Flex 控件之响应式弹性布局
flutter·ui·华为·harmonyos·鸿蒙系统
cn_mengbei15 小时前
Flutter for OpenHarmony 实战:CheckboxListTile 复选框列表项详解
flutter
cn_mengbei15 小时前
Flutter for OpenHarmony 实战:Switch 开关按钮详解
flutter
奋斗的小青年!!15 小时前
OpenHarmony Flutter实战:打造高性能订单确认流程步骤条
flutter·harmonyos·鸿蒙
Coder_Boy_16 小时前
Flutter基础介绍-跨平台移动应用开发框架
spring boot·flutter