详解Flutter如何用思源宋体炫出你的UI
liuian 2025-05-21 14:58 80 浏览
如何实现使用思源宋体字体样式。
首先,让我们来了解一下什么是资源素材管理。简单来说,它就是为了方便我们管理各种资源文件,比如图片、字体、音频等。在Flutter中,我们可以使用pubspec.yaml文件来管理我们的资源。
好了,言归正传,现在我们来看看如何实现思源宋体字体样式。思源宋体是一款开源字体,它是对传统宋体字体的一次优化和完善,所以在我们的应用中使用它可以让我们的字体更加美观。
引入字体文件
第一步,我们需要在pubspec.yaml文件中引入思源宋体字体。我们可以通过以下代码来实现:
- fonts:
- - family: SourceHanSerif
- fonts:
- - asset: fonts/SourceHanSerifCN-Regular.otf
这里,我们定义了一个名为SourceHanSerif的字体组,然后引入了字体文件
SourceHanSerifCN-Regular.otf。请注意,这里的文件路径是相对于pubspec.yaml文件的路径。
指定字体样式
第二步,我们需要在应用中使用这个字体。我们可以在TextStyle中指定字体组的名字,就像这样:
- TextStyle(
- fontFamily: 'SourceHanSerif',
- fontWeight: FontWeight.normal,
- fontSize: 20,)
这里,我们指定了字体族的名字为SourceHanSerif,然后指定了字体的粗细、大小等属性。
好了,现在我们来看看完整的代码:
- fonts:
- - family: SourceHanSerif
- fonts:
- - asset: fonts/SourceHanSerifCN-Regular.otf
- Text('Hello, Flutter!', style: TextStyle(
- fontFamily: 'SourceHanSerif',
- fontWeight: FontWeight.normal,
- fontSize: 20,),)
咦?这个字体好像没有变化啊?别急,我们还需要一步。
加载字体文件
第三步,我们需要在应用启动时,先加载我们的字体。我们可以通过以下代码来实现:
- void main() async {
- // 加载字体
- await loadFonts();
- runApp(MyApp());
- }
- Future<void> loadFonts() async {
- await Future.wait([
- // 加载思源宋体字体
- rootBundle.load('fonts/SourceHanSerifCN-Regular.otf').then(
- (data) {
- final font = FontLoader('SourceHanSerif');
- font.addFont(Future.value(data));
- return font.load();
- },
- ),
- ]);
- }
这里,我们使用了rootBundle来加载我们的字体文件。然后,我们使用FontLoader来加载字体,并将其添加到字体缓存中。请注意,我们需要将FontLoader返回的Future作为Future.wait的一个参数,以便让应用等待字体加载完毕后再启动。
好了,现在我们再次运行应用,看看思源宋体是否生效了。
- void main() async {
- // 加载字体
- await loadFonts();
- runApp(MyApp());
- }
- Future<void> loadFonts() async {
- await Future.wait([
- // 加载思源宋体字体
- rootBundle.load('fonts/SourceHanSerifCN-Regular.otf').then(
- (data) {
- final font = FontLoader('SourceHanSerif');
- font.addFont(Future.value(data));
- return font.load();
- },
- ),
- ]);
- }
- class MyApp extends StatelessWidget {
- @override
- Widget build(BuildContext context) {
- return MaterialApp(
- title: 'Flutter Demo',
- theme: ThemeData(
- primarySwatch: Colors.blue,
- ),
- home: Scaffold(
- appBar: AppBar(
- title: Text('思源宋体'),
- ),
- body: Center(
- child: Text(
- 'Hello, Flutter!',
- style: TextStyle(
- fontFamily: 'SourceHanSerif',
- fontWeight: FontWeight.normal,
- fontSize: 20,
- ),
- ),
- ),
- ),
- );
- }
- }
字体变了!现在我们的应用中使用的是思源宋体字体了。接下来,你可以在应用中随意使用这个字体了。
总结一下,实现思源宋体字体样式需要三个步骤:引入字体文件、指定字体样式、加载字体文件。这里需要特别注意字体文件路径的设置和FontLoader的使用。
好了,我想这篇文章应该已经让你轻松掌握了如何在Flutter应用中使用思源宋体字体了吧,更多关于Flutter思源宋体UI的资料请关注我们其它相关文章!
相关推荐
-
- usb驱动程序在哪里(usb驱动叫什么名字)
-
U盘添加驱动号或路径的方法如下在我的电脑上按右键,在快捷菜单里,选择“管理”,打开“计算机管理”窗口。在计算机管理窗口里,选择“存储”下面的“磁盘管理”,如果看得到没有盘符的U盘,那么在这个U盘上按鼠标右键,选择“更改驱动器名称和路径”选项...
-
2026-01-11 05:05 liuian
- 美德少年事迹材料(美德少年事迹材料500字左右)
-
就写平时做了什么好事就可以了。他们分别是许昌市文化街小学六(1)班学生谭天、许昌市第一中学七(12)班学生安家宝。现年12岁的谭天是一个阳光男孩儿,他性格活泼,热情开朗,富有爱心,品学兼优,有较强的集...
- win7万能网卡驱动离线版安装包
-
要使用Win7网卡驱动离线包,首先将离线包下载到计算机上。然后,打开设备管理器,找到你的网卡设备。右键点击该设备,选择“更新驱动程序软件”。在弹出的对话框中,选择“浏览计算机以查找驱动程序软件”。然后...
-
- 音频驱动器怎么安装(音频驱动程序怎么安装)
-
1、在浏览器中输入并搜索,然后下载并安装。2、安装完成后打开360驱动大师,它就会自动检测你的电脑需要安装或升级的驱动。3、检测完毕后,我们可以看到我们的声卡驱动需要安装或升级,点击安装或升级,就会开始自动安装或升级声卡了。4、升级过程中会...
-
2026-01-11 02:55 liuian
- win11要不要升级
-
答案是:不必强更,稍安勿躁。 没错,Windows11系统的确是微软的最新力作,其中安卓APP可以在桌面系统中直接使用的“噱头”也极有吸引力,但是,按照win10更新后bug层出不穷的情况来看,正...
- windows7联想旗舰版(联想win7旗舰版配置)
-
你好!联想Windows7旗舰版并不是一个显示设备,而是一个操作系统。因此,无法用英寸来描述其大小。旗舰版是指Windows7操作系统的最高版本,具有更多的功能和特性与其他版本不同。Windows...
- 手机刷win10(手机刷win10系统)
-
要给普通的手机刷win10,首先需要确保手机型号支持win10系统,并且进行备份重要数据。然后下载win10系统文件并通过USB连接手机与电脑,使用刷机工具将系统文件刷入手机中。在此过程中需要注意手机...
- 万能网卡驱动离线版xp(万能网卡驱动xp电脑版离线)
-
使用网卡版的驱动精灵或者驱动人生,安装后即可驱动无线网卡。安装网卡驱动是连接网络的关键步骤,即使在没有网络连接的情况下,也可以通过以下步骤来安装网卡驱动:1.下载网卡驱动程序:首先,你需要知道你的网...
- 手机五笔输入法哪个软件最好用
-
百度输入法。百度手机输入法是由百度(中国)有限公司推出的一款安装于手机和平板中的人工智能输入法工具,旨在帮助用户快速、精准的完成多内容输入,使用百度手机输入法,更懂用户的表达。百度手机输入法支持拼音、...
- 电脑公司社会实践内容(电脑店社会实践)
-
办公室社会实践有以下几方面内容:1、环保类:“植树”“清扫公共设施”“社区宣传”等。2、科普类“参观学习科研机构”“动手小发明”等。3、爱心类“帮扶老人”“义捐灾区”“募集贫困儿童”等。4、成长类“义...
- windows7旗舰版怎么升级到windows10
-
Windows7旗舰版32位,可以用U盘升级为windows10吗?这个是肯定可以的呀。Windows7升级为windows10,这是一定是可以的。关键一点。你会用U盘升级系统才可以的呀。如果你不...
- 华为服务器安装系统教程(华为服务器安装步骤)
-
1.准备安装环境:检查服务器的电源、网络连接及其他配件是否正常。2.安装软件:将光盘或U盘中的安装文件拷贝到服务器上,然后执行安装命令。3.配置服务器:根据业务需要对服务器进行IP地址、DNS、...
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
