Flutter Icon IconFont(图标控件)
1、优势
Flutter中,可以像Web开发一样使用iconfont,iconfont即“字体图标”,它是将图标做成字体文件,然后通过指定不同的字符而显示不同的图片。
效果如下图:
控制不同颜色和大小的icon
- 在Flutter开发中,iconfont和图片相比有如下优势:
1.体积小:可以减小安装包大小。 2.矢量的:iconfont都是矢量图标,放大不会影响其清晰度。 3.可以应用文本样式:可以像文本一样改变字体图标的颜色、大小对齐等。 4.可以通过TextSpan和文本混用。
2、原理
在字体文件中,每一个字符都对应一个位码,而每一个位码对应一个显示字形,不同的字体就是指字形不同,即字符对应的字形是不同的。而在iconfont中,只是将位码对应的字形做成了图标,所以不同的字符最终就会渲染成不同的图标。
3、 使用字体库图标
Flutter默认包含了一套Material Design的字体图标,在pubspec.yaml
文件中的配置如下
(默认配置就有)
flutter:
uses-material-design: true
Material Design所有图标可以在其官网查看:https://material.io/tools/icons/
- 我们看一个简单的例子: String icons = ""; icons += "uE914"; icons += " uE000"; icons += " uE90D"; Text( icons, style: TextStyle( fontFamily: "MaterialIcons", fontSize: 24.0, color: Colors.green), ),
- 完整代码如下 import 'package:flutter/material.dart'; class TextDemo extends StatelessWidget { @override Widget build(BuildContext context) { String icons = ""; icons += "uE914"; icons += " uE000"; icons += " uE90D"; return new Scaffold( appBar: new AppBar( title: new Text("图标控件"), ), body: new Column( children: <Widget>[ Text( icons, style: TextStyle( fontFamily: "MaterialIcons", fontSize: 24.0, color: Colors.green), ), ], ), ); } } void main() { runApp(new MaterialApp( title: "图标案例", theme: new ThemeData(primaryColor: Colors.deepOrangeAccent), home: new TextDemo(), )); }
- 运行效果如下图所示:
由此可见,iconfont可以像文字一样被设置大小和颜色。
但是,像"uE914"、" uE000"、" uE90D"这样的图标码并不易懂,也不好记。所以,Flutter封装了IconData
和Icon
来专门显示字体图标。
- 上面的例子也可以用如下方式实现: Row( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ Icon( Icons.accessible, color: Colors.red, size: 30.0, ), Icon( Icons.error, color: Colors.yellow, size: 30.0, ), Icon( Icons.fingerprint, color: Colors.blue, size: 30.0, ), ], )
- 效果图如下:
注:
Icons
类中包含了所有Material Design图标的IconData
静态变量定义。
4、使用自定义字体图标(以导入阿里图库为例)
我们也可以使用自定义字体图标,下面我们来展示如何使用第三方字体库。
- 下载图标
到阿里图库挑选合适的图标,加入购物车
之后,点击下载代码
。
- 取出.ttf文件
解压代码包,将iconfont.ttf文件取出。
- 导入iconfont.ttf文件
假设我们的字体图标文件保存在项目根目录下,路径为"fonts/iconfont.ttf"。
那么我们需要在pubspec.yaml
文件中添加如下代码:
fonts:
- family: myIcon #指定一个字体名
fonts:
- asset: fonts/iconfont.ttf
- 为了使用方便,我们定义一个
MyIcons
类,功能和Icons
类一样:将字体文件中的所有图标都定义成静态变量: import 'package:flutter/widgets.dart'; class MyIcons { // 草莓 static const IconData strawberry = const IconData(0xe605, fontFamily: 'myIcon'); // 冰棒 static const IconData iceLolly = const IconData(0xe60b, fontFamily: 'myIcon', matchTextDirection: true); // 甜甜圈 static const IconData donut = const IconData(0xe606, fontFamily: 'myIcon', matchTextDirection: true); } - 使用 Row( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ Icon( MyIcons.strawberry, color: Colors.red[400], ), Icon( MyIcons.iceLolly, color: Colors.green, ), Icon( MyIcons.donut, color: Colors.pink[300], ), ], ) 运行后效果如下图所示: 注意:该效果只能在手机上显示,模拟器无法显示。
导入第三方字体库效果图
本文参考:《Flutter中文网》
- 3433: [Usaco2014 Jan]Recording the Moolympics
- 3410: [Usaco2009 Dec]Selfish Grazing 自私的食草者
- 3391: [Usaco2004 Dec]Tree Cutting网络破坏
- 3404: [Usaco2009 Open]Cow Digit Game又见数字游戏
- GIF/PNG/JPG和WEBP/base64/apng图片优点和缺点整理
- 3400: [Usaco2009 Mar]Cow Frisbee Team 奶牛沙盘队
- 3409: [Usaco2009 Oct]Barn Echoes 牛棚回声
- 浅谈webp
- 3385: [Usaco2004 Nov]Lake Counting 数池塘
- 2761: [JLOI2011]不重复数字(平衡树)
- 无图片字体icon
- 数据结构(三):栈与队列
- 3555: [Ctsc2014]企鹅QQ
- 3381: [Usaco2004 Open]Cave Cows 2 洞穴里的牛之二
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 不支持图形化界面的Linux系统如何显示图像化界面?飞腾服务器显示图像化界面方法,DISPLAY environment variable is undefined问题解决方法
- 一分钟学Python| Python的函数(上)
- 数据分析与数据挖掘 - 07数据处理
- MySql8.0.19最新版本创建用户分配权限演示,You have an error in your SQL syntax权限分配问题解决方法
- linux服务器oracle数据库导出dmp文件功能演示,备份数据库命令。exp命令显示command not found解决方法,EXP-00028: 无法打开dmp进行写入问题解决
- oracle数据库exp命令导入导出dmp文件演示,oracle数据库备份还原功能
- oracle数据库impdp导入dmp文件功能演示,imp导入IMP-00038: Could not convert to environment character sets handle问题解决
- 弄懂这 5 个问题,拿下 Python 迭代器!
- windows、linux下命令行登录oracle数据库方法,查询sga参数值sql语句
- oracle数据库查询open_cursors值的sql语句,达梦数据库查询MAX_SESSION_STATEMENT值方法,MAX_SESSION_STATEMENT的最大值、上限是多少。
- 达梦数据库启用日志方法,达梦数据库查看日志是否启用,达梦数据库日志文件位置查找
- JavaScript 技术篇 - js 查看哪个元素获取了焦点,js 指定元素获取焦点方法
- 工作10年后,再看String s = new String("xyz") 创建了几个对象?
- Linux达梦数据库:通过disql登录命令行操作数据库,打开达梦数据库自带的数据库管理连接工具
- Dbvis数据库连接工具将查询出数据转化为sql插入语句方法