Flutter tabbar中文字體抖動(dòng)簡單處理方案

  • tabbar在中文字體大小變化過程中會(huì)出現(xiàn)抖動(dòng)問題,比較影響使用體驗(yàn)蛤奥,網(wǎng)上文章中有兩種解決方案:
  • 方案1:修改flutter源碼,這種方法的弊端是在flutter更新后會(huì)丟失原有改動(dòng)。
  • 方案2:自定義tab的child楼誓,在tabbar點(diǎn)擊切換索引時(shí)修改tab的child中TextStyle,這種方案簡單一些名挥,但是會(huì)存在滾動(dòng)切換時(shí)文本變化更不上的情況慌随,也是比較影響用戶體驗(yàn)。
  • 我在方案二的基礎(chǔ)上優(yōu)化了一下切換索引的實(shí)現(xiàn)方案躺同,通過監(jiān)聽tabbarView的滾動(dòng)來實(shí)現(xiàn)切換索引阁猜,比原方案用戶體驗(yàn)更好。
    代碼:
int _index = 0;
  set index(int i) {
    if (_index != i) {
      _index = i;
      setState(() {});
    }
  }

// tabbarView的滾動(dòng)監(jiān)聽
NotificationListener(
      child: TabBarView(
        controller: _tabController,
        children: [
          Container(),
          Container(),
          Container(),
          Container(),
          Container(),
        ],
      ),
      onNotification: (scrollNotification) {
        // print('$scrollNotification');
        if (scrollNotification is ScrollUpdateNotification) {
          double progress = scrollNotification.metrics.pixels /
              scrollNotification.metrics.maxScrollExtent;
          // 這里需要根據(jù)自己tabbar的數(shù)量修改計(jì)算方法
          index = (progress + 0.125) ~/ 0.25;
        }
        return true;
      },
    )

ps:如果TabBarView的children里面包含scroll蹋艺,需要children實(shí)現(xiàn)NotificationListener并在onNotification里面返回true剃袍。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市捎谨,隨后出現(xiàn)的幾起案子民效,更是在濱河造成了極大的恐慌,老刑警劉巖涛救,帶你破解...
    沈念sama閱讀 222,590評(píng)論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件畏邢,死亡現(xiàn)場離奇詭異,居然都是意外死亡检吆,警方通過查閱死者的電腦和手機(jī)舒萎,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,157評(píng)論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來蹭沛,“玉大人臂寝,你說我怎么就攤上這事章鲤。” “怎么了咆贬?”我有些...
    開封第一講書人閱讀 169,301評(píng)論 0 362
  • 文/不壞的土叔 我叫張陵败徊,是天一觀的道長。 經(jīng)常有香客問我掏缎,道長皱蹦,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,078評(píng)論 1 300
  • 正文 為了忘掉前任眷蜈,我火速辦了婚禮根欧,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘端蛆。我一直安慰自己凤粗,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 69,082評(píng)論 6 398
  • 文/花漫 我一把揭開白布今豆。 她就那樣靜靜地躺著嫌拣,像睡著了一般。 火紅的嫁衣襯著肌膚如雪呆躲。 梳的紋絲不亂的頭發(fā)上异逐,一...
    開封第一講書人閱讀 52,682評(píng)論 1 312
  • 那天,我揣著相機(jī)與錄音插掂,去河邊找鬼灰瞻。 笑死,一個(gè)胖子當(dāng)著我的面吹牛辅甥,可吹牛的內(nèi)容都是我干的酝润。 我是一名探鬼主播,決...
    沈念sama閱讀 41,155評(píng)論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼璃弄,長吁一口氣:“原來是場噩夢啊……” “哼要销!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起夏块,我...
    開封第一講書人閱讀 40,098評(píng)論 0 277
  • 序言:老撾萬榮一對(duì)情侶失蹤疏咐,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后脐供,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體浑塞,經(jīng)...
    沈念sama閱讀 46,638評(píng)論 1 319
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 38,701評(píng)論 3 342
  • 正文 我和宋清朗相戀三年政己,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了酌壕。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,852評(píng)論 1 353
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖仅孩,靈堂內(nèi)的尸體忽然破棺而出托猩,到底是詐尸還是另有隱情印蓖,我是刑警寧澤辽慕,帶...
    沈念sama閱讀 36,520評(píng)論 5 351
  • 正文 年R本政府宣布,位于F島的核電站赦肃,受9級(jí)特大地震影響溅蛉,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜他宛,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 42,181評(píng)論 3 335
  • 文/蒙蒙 一船侧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧厅各,春花似錦镜撩、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,674評(píng)論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至憔古,卻和暖如春遮怜,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背鸿市。 一陣腳步聲響...
    開封第一講書人閱讀 33,788評(píng)論 1 274
  • 我被黑心中介騙來泰國打工锯梁, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人焰情。 一個(gè)月前我還...
    沈念sama閱讀 49,279評(píng)論 3 379
  • 正文 我出身青樓陌凳,卻偏偏與公主長得像,于是被迫代替她去往敵國和親内舟。 傳聞我的和親對(duì)象是個(gè)殘疾皇子冯遂,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,851評(píng)論 2 361

推薦閱讀更多精彩內(nèi)容