Android Flutter BottomNavigationBar:該如何優(yōu)雅實(shí)現(xiàn)底部導(dǎo)航欄磷醋?


前言

Flutter 作為Google出品的一個(gè)新興的跨平臺(tái)移動(dòng)客戶端UI開發(fā)框架猫牡,正在被越來越多的開發(fā)者和組織使用,包括阿里的咸魚邓线、騰訊的微信等淌友。

示意圖

示意圖

今天,我主要講解Flutter中布局方面的底部導(dǎo)航欄:BottomNavigationBar骇陈,希望你們會(huì)喜歡震庭。


目錄

示意圖

1. 簡介

底部導(dǎo)航欄控件,屬于 Scaffold 組件你雌。

配合使用 BottomNavigationBarItem :底部導(dǎo)航欄要顯示的Item = 圖標(biāo) + 標(biāo)題


2. 屬性介紹

BottomNavigationBar({
    Key key,
    @required this.items,  // 底部導(dǎo)航欄的顯示項(xiàng) = BottomNavigationBarItem類型的List  
    this.onTap, // 點(diǎn)擊導(dǎo)航欄子項(xiàng)時(shí)的回調(diào) = ValueChanged < int >
    this.currentIndex = 0, // 當(dāng)前顯示項(xiàng)的下標(biāo) = int
    BottomNavigationBarType type, // 底部導(dǎo)航欄的類型器联,有fixed和shifting兩個(gè)類型,顯示效果不一樣 = BottomNavigationBarType 
    this.fixedColor, // 底部導(dǎo)航欄type為fixed時(shí)導(dǎo)航欄的顏色婿崭,如果為空的話默認(rèn)使用ThemeData.primaryColor = Color
    this.iconSize = 24.0, // BottomNavigationBarItem icon的大小 = double
  })

const BottomNavigationBarItem({
  @required this.icon, // 要顯示的圖標(biāo)控件拨拓,一般是Iocn
  this.title, // 要顯示的標(biāo)題控件,一般是Text
  Widget activeIcon, // 選中時(shí)要顯示的icon氓栈,一般是Icon
  this.backgroundColor, // BottomNavigationBarType為shifting時(shí)的背景顏色
})

3. 使用步驟

// 需要在Scaffold內(nèi)部使用
Scaffold(
      appBar: AppBar(
        title: Text("底部導(dǎo)航欄"),
      ),
      bottomNavigationBar: BottomNavigationBar(
        items: bottomNavItems, // 導(dǎo)航欄下標(biāo)item
        currentIndex: currentIndex, // 當(dāng)前下標(biāo)
        type: BottomNavigationBarType.fixed, // 點(diǎn)擊導(dǎo)航欄樣式
        fixedColor: Colors.green, // 點(diǎn)擊icon顏色
        iconSize: 15, // icon大小
        onTap: (index) {
          _changePage(index); // 點(diǎn)擊回調(diào)
        },
      ),
      body: pages[currentIndex], // 每個(gè)item的回調(diào)頁面
    );

// 回調(diào)頁面
  void _changePage(int index) {
    // 若點(diǎn)擊的導(dǎo)航項(xiàng)不是當(dāng)前項(xiàng)渣磷,則切換
    if (index != currentIndex) {
      setState(() {
        currentIndex = index;
      });
    }
  }

4. 實(shí)例講解

4.1 設(shè)置要回調(diào)的頁面

為了方便顯示,僅顯示一個(gè)文本


// 頁面1
import 'package:flutter/material.dart';

class PageA extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Text("PageA"),
    );
  }
}

// 頁面2
import 'package:flutter/material.dart';

class PageB extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Text("PageB"),
    );
  }
}

// 頁面3
import 'package:flutter/material.dart';

class PageC extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Text("PageC"),
    );
  }
}

// 頁面4
import 'package:flutter/material.dart';

class PageD extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Center(
      child: Text("PageD"),
    );
  }
}

4.2 核心代碼

main.dart

/**
 *  導(dǎo)入庫
 **/
import 'package:flutter/material.dart';

import 'PageA.dart';
import 'PageB.dart';
import 'PageC.dart';
import 'PageD.dart'; // Material UI組件庫

void main() => runApp(MyApp());

// 無狀態(tài)控件顯示
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
// 主界面入口返回的組件 = MaterialApp
    return MaterialApp(
      title: 'Widget_Demo', //標(biāo)題
      theme: ThemeData(primarySwatch: Colors.blue), //主題色
      home: MyWidget(), // 返回一個(gè)Widget對(duì)象授瘦,用來定義當(dāng)前應(yīng)用打開的時(shí)候醋界,所顯示的界面
    );
  }
}

class MyWidget extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return new _MyWidgetState();
  }
}

class _MyWidgetState extends State<MyWidget> {

  // 導(dǎo)航欄的item
  final List<BottomNavigationBarItem> bottomNavItems = [
    BottomNavigationBarItem(
      backgroundColor: Colors.blue,
      icon: Icon(Icons.home),
      title: Text("首頁"),
    ),
    BottomNavigationBarItem(
      backgroundColor: Colors.green,
      icon: Icon(Icons.message),
      title: Text("消息"),
    ),
    BottomNavigationBarItem(
      backgroundColor: Colors.amber,
      icon: Icon(Icons.shopping_cart),
      title: Text("購物車"),
    ),
    BottomNavigationBarItem(
      backgroundColor: Colors.red,
      icon: Icon(Icons.person),
      title: Text("個(gè)人中心"),
    ),
  ];

  int currentIndex; // 當(dāng)前下標(biāo)

  final pages = [PageA(), PageB(), PageC(), PageD()];// 下標(biāo)對(duì)應(yīng)顯示的界面

  @override
  void initState() {
    super.initState();
    currentIndex = 0;
  }

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text("底部導(dǎo)航欄"),
      ),
      bottomNavigationBar: BottomNavigationBar(
        items: bottomNavItems, // 導(dǎo)航欄下標(biāo)item
        currentIndex: currentIndex, // 當(dāng)前下標(biāo)
        type: BottomNavigationBarType.fixed,
        fixedColor: Colors.green,
        iconSize: 15,
        onTap: (index) {
          _changePage(index); // 點(diǎn)擊回調(diào)
        },
      ),
      body: pages[currentIndex],
    );
  }

  // 切換頁面
  void _changePage(int index) {
    // 若點(diǎn)擊的導(dǎo)航項(xiàng)不是當(dāng)前項(xiàng)切換
    if (index != currentIndex) {
      setState(() {
        currentIndex = index;
      });
    }
  }
}

4.3 示意圖


總結(jié)

  • 本文全面介紹了Flutter的布局組件中頂部導(dǎo)航欄的實(shí)現(xiàn):BottomNavigationBar
  • 接下來推出的文章祟身,我將繼續(xù)講解Flutter的相關(guān)知識(shí),包括使用語法物独、實(shí)戰(zhàn)等袜硫,感興趣的讀者可以繼續(xù)關(guān)注我的博客哦:Carson_Ho的Android博客

請(qǐng)點(diǎn)贊!因?yàn)槟銈兊馁澩?鼓勵(lì)是我寫作的最大動(dòng)力挡篓!

相關(guān)文章閱讀
Android開發(fā):最全面婉陷、最易懂的Android屏幕適配解決方案
Android開發(fā):史上最全的Android消息推送解決方案
Android開發(fā):最全面、最易懂的Webview詳解
Android開發(fā):JSON簡介及最全面解析方法!
Android四大組件:Service服務(wù)史上最全面解析
Android四大組件:BroadcastReceiver史上最全面解析


歡迎關(guān)注Carson_Ho的簡書官研!

不定期分享關(guān)于安卓開發(fā)的干貨秽澳,追求短、平戏羽、快担神,但卻不缺深度

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末始花,一起剝皮案震驚了整個(gè)濱河市妄讯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌酷宵,老刑警劉巖亥贸,帶你破解...
    沈念sama閱讀 219,270評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異浇垦,居然都是意外死亡炕置,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,489評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門男韧,熙熙樓的掌柜王于貴愁眉苦臉地迎上來朴摊,“玉大人,你說我怎么就攤上這事此虑∩醺伲” “怎么了?”我有些...
    開封第一講書人閱讀 165,630評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵寡壮,是天一觀的道長贩疙。 經(jīng)常有香客問我讹弯,道長况既,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,906評(píng)論 1 295
  • 正文 為了忘掉前任组民,我火速辦了婚禮棒仍,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘臭胜。我一直安慰自己莫其,他們只是感情好癞尚,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,928評(píng)論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著乱陡,像睡著了一般浇揩。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上憨颠,一...
    開封第一講書人閱讀 51,718評(píng)論 1 305
  • 那天胳徽,我揣著相機(jī)與錄音,去河邊找鬼爽彤。 笑死养盗,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的适篙。 我是一名探鬼主播往核,決...
    沈念sama閱讀 40,442評(píng)論 3 420
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼嚷节!你這毒婦竟也來了聂儒?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,345評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤硫痰,失蹤者是張志新(化名)和其女友劉穎薄货,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體碍论,經(jīng)...
    沈念sama閱讀 45,802評(píng)論 1 317
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡谅猾,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,984評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了鳍悠。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片税娜。...
    茶點(diǎn)故事閱讀 40,117評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖藏研,靈堂內(nèi)的尸體忽然破棺而出敬矩,到底是詐尸還是另有隱情,我是刑警寧澤蠢挡,帶...
    沈念sama閱讀 35,810評(píng)論 5 346
  • 正文 年R本政府宣布弧岳,位于F島的核電站,受9級(jí)特大地震影響业踏,放射性物質(zhì)發(fā)生泄漏禽炬。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,462評(píng)論 3 331
  • 文/蒙蒙 一勤家、第九天 我趴在偏房一處隱蔽的房頂上張望腹尖。 院中可真熱鬧,春花似錦伐脖、人聲如沸热幔。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,011評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽绎巨。三九已至近尚,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間场勤,已是汗流浹背肿男。 一陣腳步聲響...
    開封第一講書人閱讀 33,139評(píng)論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留却嗡,地道東北人舶沛。 一個(gè)月前我還...
    沈念sama閱讀 48,377評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像窗价,于是被迫代替她去往敵國和親如庭。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,060評(píng)論 2 355