手把手教你用Spuernova生成flutter代码
作者:Keriy
链接:https://juejin.im/post/5e1c5d7ef265da3df860f9bf
来源:掘金
缘起
周末得空,逛了dribbble,发现了好多好看的设计,馋的不行。相信每个前端都有这样一个梦想:能把设计稿直接生成代码该多好,忽而想起了Flutter Interact
上大佬们演示的插件,感觉有得搞🙃
sketch
准备
没有vip不能下载,就自己照着预览图画一个,丑莫怪~
Spuernova
or xd-to-flutter
xd-to-flutter
在我准备安装的时候,得到了这样的提示:
呵呵~
好在Spuernova
(这货是收费的,哈哈哈)可以同时支持XD
和sketch
,那么话不多说,下载安装,导入
这里直接选择全部页面
搞定~,so easy
生成的代码可以直接点击右上角的到处图标到处成项目或者单个文件,
这样就完工啦~
生成的项目结构大致如下:
运行
生成的代码在安装完成后可以直接运行。用VSCode
打开刚刚生成的项目,flutter pub get
一波没有问题,
flutter run
起来看看
海星,感觉哪里不对?字体图标和字体怎么都这样样子的??
Spuernova
中点击字体图标看看,
原来这里的字体图标被转成了图片,但是字体并没有问题,看来字体阴影的识别还是有一定问题。
不过 Spuernova
提供了修改工具,并且可以实现hot-reload
(但是无论怎样都不能hot-reload
...)
代码品读
简单来看看生成的list
组件:
整个页面全部是stack
,额~,又不是不能用。
虽然做成这样不太智能,但是我们可以手动改生成组件的类型,点击选中要更改类型的组件,右键选择Convert to Component
-> Text Field
,我们尝试将它转换成一个输入框。
/// 更改前的代码 Container( width: 57, height: 57, decoration: BoxDecoration( color: Color.fromARGB(255, 111, 124, 132), boxShadow: [ BoxShadow( color: Color.fromARGB(44, 29, 30, 32), offset: Offset(2, 2), blurRadius: 3, ), ], borderRadius: BorderRadius.all(Radius.circular(8)), ), child: Container(), ) /// 更改后的代码 Container( width: 57, height: 57, decoration: BoxDecoration( color: Color.fromARGB(255, 111, 124, 132), boxShadow: [ BoxShadow( color: Color.fromARGB(44, 29, 30, 32), offset: Offset(2, 2), blurRadius: 3, ), ], borderRadius: BorderRadius.all(Radius.circular(8)), ), child: TextField( style: TextStyle( color: Color.fromARGB(255, 0, 0, 0), fontWeight: FontWeight.w400, fontSize: 12, ), maxLines: 1, autocorrect: false, ), )
还是可以的,只要稍加修改就可以使用。
从上面的代码来看,Spuernova
虽然生成的代码不能直接使用,但是到小组件级别还是可是省不少气力的。
个人认为最好用的其实是帮我们把UI里面的样式全部提取了出来,放在values
目录下:
// colors.dart import 'dart:ui'; class AppColors { static const Color primaryBackground = Color.fromARGB(255, 38, 173, 211); static const Color secondaryBackground = Color.fromARGB(255, 36, 38, 44); static const Color ternaryBackground = Color.fromARGB(255, 74, 78, 122); static const Color primaryElement = Color.fromARGB(255, 38, 43, 47); static const Color secondaryElement = Color.fromARGB(255, 243, 64, 61); static const Color accentElement = Color.fromARGB(255, 47, 52, 57); static const Color primaryText = Color.fromARGB(255, 93, 99, 106); static const Color secondaryText = Color.fromARGB(255, 183, 190, 199); static const Color accentText = Color.fromARGB(255, 137, 145, 152); } // gradients.dart import 'package:flutter/rendering.dart'; class Gradients { static const Gradient primaryGradient = LinearGradient( begin: Alignment(0.5, 0), end: Alignment(0.5, 1), stops: [ 0, 1, ], colors: [ Color.fromARGB(255, 41, 44, 49), Color.fromARGB(255, 49, 54, 59), ], ); static const Gradient secondaryGradient = LinearGradient( begin: Alignment(0.5, 0), end: Alignment(0.5, 1), stops: [ 0, 1, ], colors: [ Color.fromARGB(255, 51, 54, 59), Color.fromARGB(255, 37, 40, 45), ], ); }
实际项目中我们可能不止一套主题,那么将上面的生成的样式稍加组织,就可以生成符合项目需求的主题:
// custom_theme.dart // 蠢蠢的写法,大佬们勿笑 import 'package:flutter/material.dart'; class CustomTheme { CustomTheme({ this.lightShadowColor, this.darkShadowColor, this.lightShadowBlur, this.weightShadowBlur, this.lightShadowOffset, this.weightShadowOffset, }); Color lightShadowColor; Color darkShadowColor; double lightShadowBlur; double weightShadowBlur; Offset lightShadowOffset; Offset weightShadowOffset; factory CustomTheme.light() => CustomTheme( ... ); factory CustomTheme.dark() => CustomTheme( lightShadowColor: Color.fromARGB(255, 46, 42, 53), darkShadowColor: Color.fromARGB(255, 85, 59, 60), lightShadowOffset: Offset.zero, weightShadowOffset: Offset.zero, lightShadowBlur: 3, weightShadowBlur: 3, ); static ThemeData darkTheme = ThemeData( appBarTheme: AppBarTheme(elevation: 0), scaffoldBackgroundColor: Color(0xFF2E3439), primarySwatch: MaterialColor( 0xFF2E3439, { 50: Color(0xFF8293A1), 100: Color(0xFF768693), 200: Color(0xFF6D7B87), 300: Color(0xFF606D78), 400: Color(0xFF515C66), 500: Color(0xFF48535C), 600: Color(0xFF3F4850), 700: Color(0xFF384046), 800: Color(0xFF30383E), 900: Color(0xFF2E3439), }, ), ); static ThemeData lightTheme = ThemeData( appBarTheme: AppBarTheme(elevation: 0), scaffoldBackgroundColor: Color(0xFF2E3439), ..., ); static CustomTheme of(BuildContext context) { Brightness brightness = MediaQuery.of(context).platformBrightness; return brightness == Brightness.dark ? CustomTheme.dark() : CustomTheme.light(); } static ThemeData systemTheme(BuildContext context, [Brightness brightness]) { Brightness _brightness = brightness ?? MediaQuery.of(context).platformBrightness; return _brightness == Brightness.dark ? darkTheme : lightTheme; } }
到这里我们基本就结束了,都学会了吗😺😝😄
总结
- UI直接生成UI代码可行,但离完美还有很长一段路
-
Spuernova
是目前唯一可用的工具,缺点是收费 - 图标字体会直接生成图片,并引入
- 带阴影的字体阴影想过不理想
- 生成的代码不能直接用在项目中,只有个别组件可以直接应用
- 生成的样式可利用价值比较高
学习分享,共勉
题外话,毕竟我在三星小米工作多年,深知技术改革和创新的方向,Flutter作为跨平台开发技术、Flutter以其美观、快速、高效、开放等优势迅速俘获人心,但很多FLutter兴趣爱好者进阶学习确实资料,今天我把我搜集和整理的这份学习资料分享给有需要的人,若有关Flutter学习进阶可以与我在Flutter跨平台开发终极之选交流群一起讨论交流。下载地址:https://shimo.im/docs/yTD3t8Pjq3XJtGv8
下载地址:https://shimo.im/docs/yTD3t8Pjq3XJtGv8
低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
官方文档中文版!Spring Cloud Stream 快速入门
本文内容翻译自官方文档,spring-cloud-stream docs,对 Spring Cloud Stream的应用入门介绍。 一、Spring Cloud Stream 简介 官方定义 Spring Cloud Stream 是一个构建消息驱动微服务的框架。 Spring Cloud Stream构建在SpringBoot之上,提供了Kafka,RabbitMQ等消息中间件的个性化配置,引入了发布订阅、消费组和分区的语义概念,有效的简化了上层研发人员对MQ使用的复杂度,让开发人员更多的精力投入到核心业务的处理。 在实际开发过程中,服务与服务之间通信经常会使用到消息中间件,而以往使用了哪个中间件比如RabbitMQ,那么该中间件和系统的耦合性就会非常高,如果我们要替换为Kafka那么变动会比较大,使用Spring Cloud Stream来整合我们的消息中间件,可以降低系统和中间件的耦合性。 二、Spring Cloud Stream 解决什么问题 无感知的使用消息中间件 Stream解决了开发人员无感知的使用消息中间件的问题,因为Stream对消息中间件的进一步封装,可以做到代...
- 下一篇
Coap协议接入物联网平台(java实现)
概述 物联网平台支持CoAP协议连接通信。CoAP协议适用在资源受限的低功耗设备上,尤其是NB-IoT的设备使用。本文介绍基于开源的CoAP协议进行对称加密自主接入的流程,并提供java示例代码。官方链接 流程 一、连接CoAP服务器endpoint地址为:${YourProductKey}.coap.cn-shanghai.link.aliyuncs.com:${port}${YourProductKey}:您的产品的ProductKey。${port}:端口。使用对称加密时端口为5682。———————————————————————————————————————二、进行设备认证具体请求参数详见官方文档———————————————————————————————————————三、上报数据具体请求参数详见官方文档 示例代码 一、pom.xml依赖 <dependency> <groupId>org.eclipse.californium</groupId> <artifactId>californium-core</arti...
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2配置默认Tomcat设置,开启更多高级功能
- CentOS7编译安装Gcc9.2.0,解决mysql等软件编译问题
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2更换Tomcat为Jetty,小型站点的福音
- Springboot2将连接池hikari替换为druid,体验最强大的数据库连接池
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- Docker使用Oracle官方镜像安装(12C,18C,19C)
- SpringBoot2全家桶,快速入门学习开发网站教程
- CentOS8编译安装MySQL8.0.19
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装