8

如果您将 Flutter SDK 从 v1.12.13 版本更新到 v1.13.8之后的任何版本,您将收到几条与 textTheme 使用相关的警告消息。例如,下面给出的其中之一。

信息:body2 已弃用,不应使用。这是 2014 版材料设计中使用的术语。现代术语是bodyText1。此功能在 v1.13.8 之后已弃用。

新版本有哪些变化?如何迁移?

4

1 回答 1

24

Material Specification 2014的文字主题和Material Specification 2018的文字主题有什么区别?

TextThemeAPI 最初基于原始材料 (2014) 设计规范,使用不同的文本样式名称。

下面给出了这两个值。

2018 年规范 - 文本样式

NAME         SIZE  WEIGHT  SPACING

headline1    96.0  light   -1.5
headline2    60.0  light   -0.5
headline3    48.0  regular  0.0
headline4    34.0  regular  0.25
headline5    24.0  regular  0.0
headline6    20.0  medium   0.15
subtitle1    16.0  regular  0.15
subtitle2    14.0  medium   0.1
body1        16.0  medium   0.5   (bodyText1)
body2        14.0  regular  0.25  (bodyText2)
button       14.0  medium   1.25
caption      12.0  regular  0.4
overline     10.0  regular  1.5

2014 年规范 - 文本样式

NAME       SIZE   WEIGHT   SPACING  2018 NAME

display4   112.0  thin     0.0      headline1
display3   56.0   normal   0.0      headline2
display2   45.0   normal   0.0      headline3
display1   34.0   normal   0.0      headline4
headline   24.0   normal   0.0      headline5
title      20.0   medium   0.0      headline6
subhead    16.0   normal   0.0      subtitle1
body2      14.0   medium   0.0      body1 (bodyText1)
body1      14.0   normal   0.0      body2 (bodyText2)
caption    12.0   normal   0.0      caption
button     14.0   medium   0.0      button
subtitle   14.0   medium   0.0      subtitle2
overline   10.0   normal   0.0      overline

如何使用新的 TextTheme 属性?(flutter版本v1.13.8及以上)

您可以使用所需的属性,如下所示。

Theme.of(context).textTheme.headline1
Theme.of(context).textTheme.headline2
Theme.of(context).textTheme.headline3
Theme.of(context).textTheme.headline4
Theme.of(context).textTheme.headline5
Theme.of(context).textTheme.headline6
Theme.of(context).textTheme.subtitle1
Theme.of(context).textTheme.subtitle2
Theme.of(context).textTheme.body1
Theme.of(context).textTheme.body2
Theme.of(context).textTheme.button
Theme.of(context).textTheme.caption
Theme.of(context).textTheme.overline

什么是不变的属性名称?

只有以下两个属性名称在两个 Theme 类中是通用的。

Theme.of(context).textTheme.caption
Theme.of(context).textTheme.overline
于 2020-03-26T09:25:53.997 回答