flutter RichText在iOS上文本顯示問題

問題:

在Flutter中有一些場(chǎng)景會(huì)需要展示多格式的文本也就是富文本,這個(gè)時(shí)候我們可以使用RichText+TextSpan的方式來做展示。不過會(huì)發(fā)現(xiàn)iOS系統(tǒng)中如果設(shè)置字體顯示很大,這里的文本顯示就會(huì)很小。

先直接說解決方式:

用Text.rich來代替RichText

原因分析

問題的關(guān)鍵是textScaleFactor,代表字體縮放因子,是指每個(gè)邏輯像素對(duì)應(yīng)的實(shí)際字體像素,例如如果textScaleFactor這個(gè)值是1.5,那么字體將會(huì)比指定的字體大小大50%

在Text.rich的實(shí)現(xiàn)中,最終構(gòu)建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是這樣實(shí)現(xiàn)的:
textScaleFactor: textScaleFactor ?? MediaQuery.textScaleFactorOf(context),
如果傳來的參數(shù)為空,則去用mediaQuery查詢獲得。

而直接使用RichText時(shí),默認(rèn)的textScaleFactor為1,不會(huì)隨著系統(tǒng)字體設(shè)置而變化。

 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,
  }) 

總結(jié)

從Text.rich和RichText的構(gòu)造方式中也可以看出,Text.rich本身的實(shí)現(xiàn)也是調(diào)用RichText,不過有了更多默認(rèn)屬性的設(shè)置,這就給開發(fā)帶來一些便利,特別是可以覆蓋開發(fā)考慮不到的屬性,因此在實(shí)際開發(fā)中,需要在Flutter中使用富文本時(shí),開發(fā)中推薦使用Text.rich這種方式。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 跟隨《Flutter實(shí)戰(zhàn)·第二版》[https://book.flutterchina.club]學(xué)習(xí),建議直接看...
    QYCD閱讀 407評(píng)論 0 0
  • Text Widget “文本”小組件顯示單個(gè)樣式的文本字符串。字符串可能會(huì)跨越多行,也可能全部顯示在同一行上,具...
    飛羽_ifeiyv閱讀 894評(píng)論 0 2
  • 邂逅FLutter 萬物皆是Widget 一般縮進(jìn)2個(gè)空格 文字居中 Widget Center() Materi...
    JackLeeVip閱讀 3,485評(píng)論 0 4
  • 原文在此,此處只為學(xué)習(xí) Text Text文本屬性如下所示 Text用于顯示簡(jiǎn)單樣式文本,它包含一些控制文本顯示樣...
    lltree閱讀 733評(píng)論 0 0
  • 一、Widget Flutter設(shè)計(jì)思想,Everything is Widget。 Widget 是一個(gè)比較寬泛...
    磊Se閱讀 773評(píng)論 0 1

友情鏈接更多精彩內(nèi)容