世界看点:iFlutter - 加速Flutter开发
2023-04-25 12:16:52 博客园

iFlutter是一款辅助Flutter开发的 IDEA 插件


(相关资料图)

插件安装

插件已上传官方Plugins仓库,可在IDEA Plugins界面搜索 iFlutter下载

iFlutter生态

功能说明

注册资源

Flutter开发过程中,不可避免地需要使用到本地资源。比如:使用 bg_login.png文件作为背景图,开发一个登录界面,步骤如下:

  1. 在项目根目录创建 images文件夹,并把 bg_login.png添加到 images;
  2. 注册资源到 pubspec.yaml
···flutter:  uses-material-design: true  assets:    - images/bg_login.png    #注册资源    ···  
  1. 使用资源:
Image.asset("images/bg_login");

使用资源前都需要在 pubspec.yaml文件中注册,并且通过 硬编码引用,凸显出两个问题:

  1. 存在繁琐的机械劳动
  2. 出错率高

iFlutter解决方案: 当在 指定的目录中添加、删除、重命名文件时,iFlutter插件都会感知,并自动修改 pubspec.yaml文件,同时生成配套的 _res.dart文件(类似Android中的R文件),通过 R.xx的方式就能使用资源,效果如下:

注册字体

指定的目录添加文件,如果该文件后缀为:ttf, font, fon, otf, eot, woff, ttc,则 iFlutter会视该文件为字体文件,便自动注册自定义字体到 pubspec.yaml中,同时创建或修改 lib/res/i_font_res.dart以生成引用字段。

如果项目已经有自定义字体配置,首次使用 iFlutter需要确保family:xxx和字体文件名(不包括后缀)一致,例如:

flutter:  ...  fonts:    - family: a      fonts:        - asset: relative/path/b.ttf

则需要修改 relative/path/b.ttf文件名为 a.ttf

资源重置

当合并分支代码时,如果出现 _res.darti_font_res文件冲突,可重新生成:

iFlutter通过以下两个步骤,对资源进行重置:

检查重复资源

在项目版本需求开发周期内,同一个设计资源可能被不同的开发小伙伴重复引入,导致包体积增涨,iFlutter支持重复资源检测,效果如下:

归纳资源

随着Flutter项目的不断迭代,项目中所使用的资源也会越来越多。大部分的情况下,项目所使用的资源文件都是直接平展在目录下,类似:

images  - login_wx.png  - login_qq.png  - login_phone.png  - mine_setting.png  - mine_defailt_portrait.png  - launcher.png  ...

为了方便项目模块化,iFlutter支持对目录下的文件进行归类,以 _为规则进行分类,分类结果如下:

images  - login    - login_wx.png    - login_qq.png    - login_phone.png  - mine    - mine_setting.png    - mine_defailt_portrait.png  - launcher.png  ...

资源归类后,iFlutter会重新注册资源到 pubspec.yaml中,并修改受影响的 *.dart文件。

具体效果如下:

依赖树生成

用于分析Flutter项目 包依赖关系,对于生成的结果支持 Command/Control+ F搜索,功能入口:

Json 转 Dart Entity

在Flutter项目的 lib目录及其 子目录下,iFlutter支持 JsonDart Entity功能,在其他目录下该功能不可用,使用效果如下:

Dart Entity 补全 fromJsontoJson方法

对于新的实体类,可以通过上一节 Json 转 Dart Entity工具自动生成。针对项目中已有的类,那我们又该如何生成 toJsonfromJson方法呢?先看使用效果:

Live Template

使用效果:

使用说明:

快捷键代码片段
importMimport "package:flutter/material.dart;
importCimport "package:flutter/cupertino.dart;
f_ColumnColumn(...)
f_ContainerContainer(...)
f_GestureDetectorGestureDetector(...)
f_RowRow(...)
f_StackStack(...)
f_TextText(...)

代码细节:

Http接口Mock

功能使用:

包检查更新

iFlutter插件会定时(5min)检查项目中直接依赖的Packages是否可更新,如果远程有最新版本,则 pubspec.yaml对应节点会高亮显示,点击右侧 icon会打开对应的页面,效果如下:

提取远程依赖

iFlutter支持将远程依赖一键修改成本地依赖,方便对 Package进一步扩展或者修复。将光标停留在对应的 Package上,右键选择 convert to local dependency后,在弹出目录选择对话框中,选择需要存储的位置。

热门推荐

文章排行

  1. 2023-04-25世界看点:iFlutter - 加速Flutter开发
  2. 2023-04-25每日资讯:2023北京各火车站五一地铁运营时间延长方便抵京旅客出行
  3. 2023-04-25热议:国网永泰县供电公司召开2023年第一次大监督联席会
  4. 2023-04-25特斯拉 Q1 中国市场收入 48.91 亿美元,同比增长 5%
  5. 2023-04-25浙江发布2023年元宇宙产业发展工作要点 引育4个行业头部企业等
  6. 2023-04-25天天观焦点:奔腾早知道|李佳琦等主播被点名!持中国护照上车!数字人民币当工资发 五一前油价又有调整 108个项目签约落地内蒙古…
  7. 2023-04-25美出圈啦!广西两家高颜值书店获评年度全国“最美书店”
  8. 2023-04-25绿城房地产关联方已累计购买其债券金额超3.32亿元
  9. 2023-04-25打破垄断、开拓海外 国产肺炎疫苗厚积薄发_天天热点评
  10. 2023-04-25第二季DDR5 Server DRAM价格跌幅将收敛
  11. 2023-04-25湘南学院:让书香飘进村小 阅读陪伴孩子成长
  12. 2023-04-25一整个优秀!原来你是这样的“95后”航天人_天天视讯
  13. 2023-04-25销售非注册证股票000831券案 互有过失抗辩
  14. 2023-04-25全球观热点:国内商品期货开盘涨跌不一 纯碱跌近3%
  15. 2023-04-25精选!小米王化回应13 Ultra可变光圈晃动问题:正常物理现象,并非故障
  16. 2023-04-25当前简讯:百余幅水彩画记录时代风采
  17. 2023-04-25广交会增设孕婴童用品展区助力企业转内销 促进国内国际双循环|世界热文
  18. 2023-04-25声测管的预埋方式 世界新动态
  19. 2023-04-25世界新资讯:聚焦环境监测目标任务 皖仪科技于IEexpo2023书写新篇章
  20. 2023-04-25长安Lumin推出至高5000元限时补贴|环球播报