美文网首页
flutter RichText在iOS上文本显示问题

flutter RichText在iOS上文本显示问题

作者: AndroidXing | 来源:发表于2022-03-06 21:23 被阅读0次

问题:

在Flutter中有一些场景会需要展示多格式的文本也就是富文本,这个时候我们可以使用RichText+TextSpan的方式来做展示。不过会发现iOS系统中如果设置字体显示很大,这里的文本显示就会很小。

先直接说解决方式:

用Text.rich来代替RichText

原因分析

问题的关键是textScaleFactor,代表字体缩放因子,是指每个逻辑像素对应的实际字体像素,例如如果textScaleFactor这个值是1.5,那么字体将会比指定的字体大小大50%

在Text.rich的实现中,最终构建widget仍然是RichText:

  Widget result = RichText(
      textAlign: textAlign ?? defaultTextStyle.textAlign ?? TextAlign.start,
      textDirection: textDirection, // RichText uses Directionality.of to obtain a default if this is null.
      locale: locale, // RichText uses Localizations.localeOf to obtain a default if this is null
      softWrap: softWrap ?? defaultTextStyle.softWrap,
      overflow: overflow ?? defaultTextStyle.overflow,
      textScaleFactor: textScaleFactor ?? MediaQuery.textScaleFactorOf(context),
      maxLines: maxLines ?? defaultTextStyle.maxLines,
      strutStyle: strutStyle,
      textWidthBasis: textWidthBasis ?? defaultTextStyle.textWidthBasis,
      textHeightBehavior: textHeightBehavior ?? defaultTextStyle.textHeightBehavior ?? DefaultTextHeightBehavior.of(context),
      text: TextSpan(
        style: effectiveTextStyle,
        text: data,
        children: textSpan != null ? <InlineSpan>[textSpan] : null,
      ),
    );

其中textScaleFactor是这样实现的:
textScaleFactor: textScaleFactor ?? MediaQuery.textScaleFactorOf(context),
如果传来的参数为空,则去用mediaQuery查询获得。

而直接使用RichText时,默认的textScaleFactor为1,不会随着系统字体设置而变化。

 RichText({
    Key key,
    @required this.text,
    this.textAlign = TextAlign.start,
    this.textDirection,
    this.softWrap = true,
    this.overflow = TextOverflow.clip,
    this.textScaleFactor = 1.0,
    this.maxLines,
    this.locale,
    this.strutStyle,
    this.textWidthBasis = TextWidthBasis.parent,
    this.textHeightBehavior,
  }) 

总结

从Text.rich和RichText的构造方式中也可以看出,Text.rich本身的实现也是调用RichText,不过有了更多默认属性的设置,这就给开发带来一些便利,特别是可以覆盖开发考虑不到的属性,因此在实际开发中,需要在Flutter中使用富文本时,开发中推荐使用Text.rich这种方式。

相关文章

网友评论

      本文标题:flutter RichText在iOS上文本显示问题

      本文链接:https://www.haomeiwen.com/subject/pcbwrrtx.html