Flutter 设置全局字体的实现

 更新时间:2022年02月16日 15:24:29   作者:BennuCTech  
本文主要介绍了Flutter 设置全局字体的实现,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

引入字体

首先在项目中创建fonts目录,然后将将ttf文件放到该目录下,然后在pubspec文件中添加该字体文件,如:

...
flutter:
  fonts:
    - family: PingFang
      fonts:
        - asset: fonts/PingFang-Regular.ttf

  assets:
    - assets/exit_icon.png

这里family是我们自定义的,对应该字体,这里每个字体可以对应多个ttf文件,比如区分加粗:

flutter:
  fonts:
    - family: Raleway
      fonts:
        - asset: assets/fonts/Raleway-Regular.ttf
        - asset: assets/fonts/Raleway-Medium.ttf
          weight: 500
        - asset: assets/fonts/Raleway-SemiBold.ttf
          weight: 600
    - family: AbrilFatface
      fonts:
        - asset: assets/fonts/abrilfatface/AbrilFatface-Regular.ttf
  • family 是字体的名称, 你可以在TextStyle的 fontFamily 属性中使用.
  • asset 是相对于 pubspec.yaml 文件的路径.这些文件包含字体中字形的轮廓。在构建应用程序时,这些文件会包含在应用程序的asset包中。

可以给字体设置粗细、倾斜等样式

  • weight属性指定字体的粗细,取值范围是100到900之间的整百数(100的倍数). 这些值对应 FontWeight, 可以用于 TextStyle的fontWeight属性
  • style 指定字体是倾斜还是正常,对应的值为italic和 normal. 这些值对应 FontStyle 可以用于TextStyle的 fontStyle TextStyle 属性

引入字体后可以在Text的sytle中使用即可

Text(
    "test",
    style: TextStyle(fontFamily: "Rock Salt",),
)

全局字体

想设置全局字体,则需要在App中设置,如下:

MaterialApp(
  title: title,
  theme: ThemeData(
    primarySwatch: Colors.blue,
    visualDensity: VisualDensity.comfortable,
    fontFamily: "PingFang",
    textTheme: TextTheme(
      ...
    )
  ),
  ...
);

这样全局字体都变成了我们设定的字体。

问题

但是这里有两个小问题(flutter web,其他平台未测):

library中设置失效

我们将基础功能封装到一个library(gitsubmodule形式,所以没有发布)中,其实承载MaterialApp的BaseApp也在library中,所以最开始将字体文件放在了library中,然后在BaseApp的MaterialApp中设置了fontFamily。
但是运行发现字体根本没变化,通过flutter build web编译后发现在build目录下生成的文件中没有这个字体文件。
目前未找到原因,不过有解决方法,简单的解决方法就是在主工程中也放一份该字体文件,同时在主工程的pubspec中也添加该字体(名称与library中保持一致)。这样运行就会发现字体都变过来了,build编译后也生成了该字体文件。

TextSpan中字体未生效

TextSpan可以用来处理图文混合的需求。比如前面一个图片标签,后面是文字,但是文字第二行还要从图片最左端开始,即环绕图片,这种时候就需要TextSpan+WidgetSpan配合只用即可。
但是在flutter web中(其他平台未测),通过上面设置全局字体后,发现TextSpan中的字体并未生效,还是系统字体。
说明TextSpan稍微特殊一些,我们知道Text的源码中style实际上做了一步merge操作,merge了默认的style(defaultTextStyle)。但是在TextSpan的源码中,发现并没有这一步操作,所以设置的全局字体对它不起作用。
所以使用TextSpan的地方如果需要则必须单独设置字体。

到此这篇关于Flutter 设置全局字体的实现的文章就介绍到这了,更多相关Flutter 全局字体内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • android实现widget时钟示例分享

    android实现widget时钟示例分享

    这篇文章主要介绍了android实现widget时钟示例,需要的朋友可以参考下
    2014-03-03
  • 基于Android实现自动滚动布局

    基于Android实现自动滚动布局

    在平时的开发中,有时会碰到这样的场景,设计上布局的内容会比较紧凑,导致部分机型上某些布局中的内容显示不完全,或者在数据内容多的情况下,单行无法显示所有内容,这里给大家简单介绍下布局自动滚动的一种实现方式,感兴趣的朋友可以参考下
    2023-12-12
  • Android编程之OpenGL绘图技巧总结

    Android编程之OpenGL绘图技巧总结

    这篇文章主要介绍了Android编程之OpenGL绘图技巧,结合实例形式总结分析了Android基于OpenGL绘图的原理与具体步骤,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-11-11
  • android 默认时间格式修改方法

    android 默认时间格式修改方法

    在android使用中,遇到修改默认时间格式时,总是束手无策,本文将以此问题提供解决方案,需要了解的朋友可以参考下
    2012-11-11
  • android利用消息机制获取网络图片

    android利用消息机制获取网络图片

    这篇文章主要为大家详细介绍了android利用消息机制获取网络图片的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • Android实现九宫格横向左右滑动

    Android实现九宫格横向左右滑动

    这篇文章主要为大家详细介绍了Android实现九宫格横向左右滑动,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-08-08
  • Android下修改SeekBar样式的解决办法

    Android下修改SeekBar样式的解决办法

    本篇文章是对在Android下修改SeekBar样式的解决办法进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • Android ScrollView取消惯性滚动的方法

    Android ScrollView取消惯性滚动的方法

    下面小编就为大家带来一篇Android ScrollView取消惯性滚动的方法。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-04-04
  • Android性能优化之JVMTI与内存分配

    Android性能优化之JVMTI与内存分配

    这篇文章主要为大家介绍了Android性能优化之JVMTI与内存分配,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-10-10
  • Android 退出应用程序的实现方法

    Android 退出应用程序的实现方法

    这篇文章主要介绍了Android 退出应用程序的实现方法的相关资料,需要的朋友可以参考下
    2017-04-04

最新评论