flutter 图片自动化处理

在flutter项目开发中很烦的一点就是资源的使用
在使用时

  • 首先需要我们添加资源到项目中
  • 然后在使用的地方用手动拼写的图片名称

首先用手动拼写的字符串容易出错,其次是需要全部拼写出来,或者是有一个单独的文件来存储图片对应的资源名称,这样也是难于维护,图片删了,但是资源名还留着,图片多了,维护都是问题,为了解决这个痛点,就写了一个自动处理的方法
大体的思路就是获取到所有的图片文件,然后手动拼写存储图片名称的类代码,然后写入规定好的文件中(dart文件)
大概就是生成类似这样的文件

class LXCThemeData {
  static const homeToolGuideClose = "assets/res/images/home_tool_guide_close.png";
}

第一步:把我们的类写出来

void main(List<String> arguments) {
  const clsName = "LXCThemeData";
  StringBuffer warpper = StringBuffer();
  warpper.writeln("class $clsName {");
  warpper.writeln("}");
}

第二部:获取图片文件,这里需要注意的是我们一般都是在asset/images/下面放图片,但是很可能会对图片进一步分文件夹存储,所以需要对asset/images/进行递归遍历,以便把所有的图片都查找出来

writeImagePropertyToWarpper() {
  Directory directory = Directory("assets/res/images");

  //这个files中包含文件夹和文件,所以需要去除文件夹
  List<FileSystemEntity> files = directory.listSync(recursive: true);
  for (FileSystemEntity file in files) {
    if (file is File) {
      print("图片路径 = ${file.path}");
    }
  }
}

第三部: 将warpper传入,然后通过图片路径截取图片名称,一般在dart中文件使用""进行单词分割,而类中的属性一般都是驼峰命名法,所以这里需要多一步操作就是将""分割的图片名称转化为驼峰,然后拼接成

static const homeToolGuideClose = "assets/res/images/home_tool_guide_close.png";
writeImagePropertyToWarpper(StringBuffer warpper) {
  Directory directory = Directory("assets/res/images");

  //这个files中包含文件夹和文件,所以需要去除文件夹
  List<FileSystemEntity> files = directory.listSync(recursive: true);
  for (FileSystemEntity file in files) {
    if (file is File) {
      final imagePathString = file.path;
      var imageName = imagePathString.substring(imagePathString.lastIndexOf("/")+1,imagePathString.lastIndexOf("."));
      imageName = hump(imageName);
      warpper.writeln('  static const $imageName = "$imagePathString"');
    }
  }
}

String hump(String source) {
  return source.split("_").reduce((prev, next) {
    if (next.isNotEmpty) {
      next = next[0].toUpperCase() + next.substring(1);
    }
    return "$prev$next";
  });
}

此时在我的assets/res/images/ 下有一张图片home_tool_guide_close.png

382FE4C9-5277-4EC5-A86A-656F8848D852.png

main函数

void main(List<String> arguments) {
  const clsName = "LXCThemeData";
  StringBuffer warpper = StringBuffer();
  warpper.writeln("class $clsName {");
  writeImagePropertyToWarpper(warpper);
  warpper.writeln("}");
  print(warpper);
}

此时我们运行main函数,打印warpper结果为:

class LXCThemeData {
  static const homeToolGuideClose = "assets/res/images/home_tool_guide_close.png";
}

完美的拼出了我们想要的图片名称类
最后一步: 将这个类字符串写入到我们的dart文件中,我这里将它存放到了lib/theme/image_name.dart文件中


4B45E5C6-CAAC-4FA7-8FC3-E54AD397E9C3.png
void main(List<String> arguments) {
  const clsName = "LXCThemeData";
  StringBuffer warpper = StringBuffer();
  warpper.writeln("class $clsName {");
  writeImagePropertyToWarpper(warpper);
  warpper.writeln("}");
  try {
    File file = File("lib/theme/image_name.dart");
    file.writeAsString(warpper.toString());
  } catch(e) {
    print(e);
  }
}

此时运行main函数,就会将上边打印的类写入到image_name.dart文件中


E4D0E8D6-7A40-4F35-B399-F78022D856F7.png

到此,我们就自动化的将所有的图片资源管理起来了,之后如果删除图片,添加图片,重新运行main函数就可以同步这些资源,我们使用的石磊中的图片名称属性,如果图片被删除了,我们的代码也会第一时间反馈给你错误,是不是很方便呢

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 199,340评论 5 467
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 83,762评论 2 376
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 146,329评论 0 329
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 53,678评论 1 270
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 62,583评论 5 359
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 47,995评论 1 275
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,493评论 3 390
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,145评论 0 254
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,293评论 1 294
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,250评论 2 317
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,267评论 1 328
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,973评论 3 316
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,556评论 3 303
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,648评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,873评论 1 255
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,257评论 2 345
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 41,809评论 2 339

推荐阅读更多精彩内容