Flutter中,可以像Web开发一样使用iconfont,iconfont即“字体图标”,它是将图标做成字体文件,然后通过指定不同的字符而显示不同的图片。
效果如下图:
控制不同颜色和大小的icon
1.体积小:可以减小安装包大小。 2.矢量的:iconfont都是矢量图标,放大不会影响其清晰度。 3.可以应用文本样式:可以像文本一样改变字体图标的颜色、大小对齐等。 4.可以通过TextSpan和文本混用。
在字体文件中,每一个字符都对应一个位码,而每一个位码对应一个显示字形,不同的字体就是指字形不同,即字符对应的字形是不同的。而在iconfont中,只是将位码对应的字形做成了图标,所以不同的字符最终就会渲染成不同的图标。
Flutter默认包含了一套Material Design的字体图标,在pubspec.yaml
文件中的配置如下
(默认配置就有)
flutter:
uses-material-design: true
Material Design所有图标可以在其官网查看:https://material.io/tools/icons/
由此可见,iconfont可以像文字一样被设置大小和颜色。
但是,像"uE914"、" uE000"、" uE90D"这样的图标码并不易懂,也不好记。所以,Flutter封装了IconData
和Icon
来专门显示字体图标。
注:
Icons
类中包含了所有Material Design图标的IconData
静态变量定义。
我们也可以使用自定义字体图标,下面我们来展示如何使用第三方字体库。
到阿里图库挑选合适的图标,加入购物车
之后,点击下载代码
。
解压代码包,将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); }导入第三方字体库效果图
本文参考:《Flutter中文网》