MaterialApp 詳解

MaterialApp 代表使用紙墨設(shè)計(jì)(Material Design)風(fēng)格的應(yīng)用毒姨。里面包含了紙墨設(shè)計(jì)風(fēng)格應(yīng)用所需要的基本控件。

MaterialApp 主要屬性如下:

  • title : 在任務(wù)管理窗口中所顯示的應(yīng)用名字
  • theme : 應(yīng)用各種 UI 所使用的主題顏色
  • color : 應(yīng)用的主要顏色值(primary color)胳蛮,也就是安卓任務(wù)管理窗口中所顯示的應(yīng)用顏色
  • home : 應(yīng)用默認(rèn)所顯示的界面 Widget
  • routes : 應(yīng)用的頂級(jí)導(dǎo)航表格坐慰,這個(gè)是多頁(yè)面應(yīng)用用來(lái)控制頁(yè)面跳轉(zhuǎn)的谭期,類(lèi)似于網(wǎng)頁(yè)的網(wǎng)址
  • initialRoute :第一個(gè)顯示的路由名字饱亮,默認(rèn)值為 Navigator.defaultRouteName
  • onGenerateRoute : 生成路由的回調(diào)函數(shù),當(dāng)導(dǎo)航的命名路由的時(shí)候脖岛,會(huì)使用這個(gè)來(lái)生成界面
  • onLocaleChanged : 當(dāng)系統(tǒng)修改語(yǔ)言的時(shí)候朵栖,會(huì)觸發(fā)這個(gè)回調(diào)
  • navigatorObservers : 應(yīng)用 Navigator 的監(jiān)聽(tīng)器
  • debugShowMaterialGrid : 是否顯示 紙墨設(shè)計(jì) 基礎(chǔ)布局網(wǎng)格,用來(lái)調(diào)試 UI 的工具
  • showPerformanceOverlay : 顯示性能標(biāo)簽
  • debugShowCheckedModeBanner :是否顯示右上角DEBUG標(biāo)簽 (調(diào)試開(kāi)關(guān))
  • checkerboardRasterCacheImages :檢查緩存的圖像開(kāi)關(guān)柴梆,檢測(cè)在界面重繪時(shí)頻繁閃爍的圖像(調(diào)試開(kāi)關(guān))
  • showSemanticsDebugger :是否打開(kāi)Widget邊框混槐,類(lèi)似Android開(kāi)發(fā)者模式中顯示布局邊界(調(diào)試開(kāi)關(guān))

下面將介紹重要的幾個(gè)屬性。

title

這個(gè)和啟動(dòng)圖標(biāo)名字是不一樣的轩性,和當(dāng)前 Activity 的名字也是不一樣的。 這個(gè) Title 是用來(lái)定義任務(wù)管理窗口界面所看到應(yīng)用名字的。在原生 Android 系統(tǒng)中點(diǎn)擊圓圈 Home 按鈕右邊的方塊按鈕就會(huì)打開(kāi)多任務(wù)切換窗口揣苏。

theme

定義應(yīng)用所使用的主題顏色悯嗓,在紙墨設(shè)計(jì)中定義了 primaryColor、accentColor卸察、hintColor 等顏色值脯厨。可以通過(guò)這個(gè)來(lái)指定一個(gè) ThemeData 定義應(yīng)用中每個(gè)控件的顏色坑质。

home

這個(gè)是一個(gè) Widget 對(duì)象合武,用來(lái)定義當(dāng)前應(yīng)用打開(kāi)的時(shí)候,所顯示的界面涡扼。

color

定義系統(tǒng)中該應(yīng)用的主要顏色

routes

定義應(yīng)用中頁(yè)面跳轉(zhuǎn)規(guī)則稼跳。 該對(duì)象是一個(gè) Map<String, WidgetBuilder>。

當(dāng)使用 Navigator.pushNamed 來(lái)路由的時(shí)候吃沪,會(huì)在 routes 查找路由名字汤善,然后使用 對(duì)應(yīng)的 WidgetBuilder 來(lái)構(gòu)造一個(gè)帶有頁(yè)面切換動(dòng)畫(huà)的 MaterialPageRoute。如果應(yīng)用只有一個(gè)界面票彪,則不用設(shè)置這個(gè)屬性红淡,使用 home 設(shè)置這個(gè)界面即可。

'/' 和 home 屬性
路由表(也就是我們下面代碼里面定義的routes變量)里面的 '/' 和 home 屬性降铸,二者不能同時(shí)存在在旱,但是必須有一個(gè)存在:


class  MyApp  extends  StatelessWidget  {

  final  Map<String,  WidgetBuilder>  _routes  =  <String,  WidgetBuilder>{

    Navigator.defaultRouteName :  (context)  => new  MyHomePage(title:  'Flutter Demo Home Page') //默認(rèn)路由

  };

  // This widget is the root of your application.

  @override

  Widget build(BuildContext context)  {

    return  new  MaterialApp(

      title:  'Flutter App',

      debugShowMaterialGrid:  true,

      routes:  _routes,  // 使用 _routes 中定義的 默認(rèn)路由來(lái)替代 home

      //home: new MyHomePage(title: 'Flutter Demo Home Page'),  //去掉這里的注釋?zhuān)瑒t需要將_routes里面的默認(rèn)路由刪掉

    );

  }
}

修改了 title、home 被注釋了使用 routes 來(lái)替代推掸。

如果所查找的路由在 routes 中不存在桶蝎,則會(huì)通過(guò) onGenerateRoute 來(lái)查找。

initialRoute

是啟動(dòng)APP的初始頁(yè)面终佛,也就是用戶(hù)看到的第一個(gè)頁(yè)面俊嗽。如果這個(gè)屬性沒(méi)有給值,那么會(huì)去尋找路由表里面的 '/' 铃彰,或者 home 屬性绍豁。

當(dāng)initialRoute沒(méi)有設(shè)置
initialRoute 或者 home 屬性都是定義了主頁(yè)面,當(dāng) initialRoute 沒(méi)有定義的時(shí)候牙捉,用戶(hù)看到的就是 '/' 或者 home 對(duì)應(yīng)的頁(yè)面竹揍。

當(dāng)initialRoute設(shè)置了
當(dāng)initialRoute 和 '/' 或者 home 屬性同時(shí)存在的時(shí)候,initialRoute 的優(yōu)先級(jí)高于二者邪铲。意思就是如果 initialRoute 定義的頁(yè)面和 '/' 或者 home 設(shè)置的頁(yè)面不同時(shí)芬位,用戶(hù)看到的是 initialRoute 定義的頁(yè)面。

onGenerateRoute

路由回調(diào)函數(shù)带到,在打開(kāi)命名路由的時(shí)候可能會(huì)被調(diào)用昧碉,之所以說(shuō)可能,是因?yàn)楫?dāng)調(diào)用Navigator.pushNamed(...)打開(kāi)命名路由時(shí),如果指定的路有名在路由表中已注冊(cè)被饿,則回調(diào)用路由表中的builder函數(shù)來(lái)生成路由組建四康;如果路由表中沒(méi)有注冊(cè),則會(huì)調(diào)用onGenerateRoute來(lái)生成路由狭握。
假設(shè)我們需要開(kāi)發(fā)一個(gè)電商APP闪金,當(dāng)用戶(hù)沒(méi)有登錄的時(shí)候可以查看碘伏、商品等信息论颅,但是交易記錄哎垦、購(gòu)物車(chē)、用戶(hù)個(gè)人信息等頁(yè)面需要登錄后才能查看恃疯。就可以在onGenerateRoute回調(diào)中進(jìn)行統(tǒng)一的權(quán)限控制:

MaterialApp(
      ... //省略無(wú)關(guān)代碼
      onGenerateRoute: (RouteSettings settings){
          return MaterialPageRoute(settings: settings, builder: (BuildContext context) {
              String routeName = settings.name;
              //如果訪問(wèn)的路由頁(yè)需要登錄漏设,但當(dāng)前未登錄,則這里直接返回登錄頁(yè)路由澡谭,引導(dǎo)用戶(hù)登錄愿题;其他情況下則是正常打開(kāi)路由
        });
      },
    );
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市蛙奖,隨后出現(xiàn)的幾起案子潘酗,更是在濱河造成了極大的恐慌,老刑警劉巖雁仲,帶你破解...
    沈念sama閱讀 217,907評(píng)論 6 506
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件仔夺,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡攒砖,警方通過(guò)查閱死者的電腦和手機(jī)缸兔,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,987評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)吹艇,“玉大人惰蜜,你說(shuō)我怎么就攤上這事∈苌瘢” “怎么了抛猖?”我有些...
    開(kāi)封第一講書(shū)人閱讀 164,298評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)鼻听。 經(jīng)常有香客問(wèn)我财著,道長(zhǎng),這世上最難降的妖魔是什么撑碴? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,586評(píng)論 1 293
  • 正文 為了忘掉前任撑教,我火速辦了婚禮,結(jié)果婚禮上醉拓,老公的妹妹穿的比我還像新娘伟姐。我一直安慰自己收苏,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,633評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布愤兵。 她就那樣靜靜地躺著倒戏,像睡著了一般。 火紅的嫁衣襯著肌膚如雪恐似。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,488評(píng)論 1 302
  • 那天傍念,我揣著相機(jī)與錄音矫夷,去河邊找鬼。 笑死憋槐,一個(gè)胖子當(dāng)著我的面吹牛双藕,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播阳仔,決...
    沈念sama閱讀 40,275評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼忧陪,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來(lái)了近范?” 一聲冷哼從身側(cè)響起嘶摊,我...
    開(kāi)封第一講書(shū)人閱讀 39,176評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎评矩,沒(méi)想到半個(gè)月后叶堆,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,619評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡斥杜,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,819評(píng)論 3 336
  • 正文 我和宋清朗相戀三年虱颗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片蔗喂。...
    茶點(diǎn)故事閱讀 39,932評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡忘渔,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出缰儿,到底是詐尸還是另有隱情畦粮,我是刑警寧澤,帶...
    沈念sama閱讀 35,655評(píng)論 5 346
  • 正文 年R本政府宣布返弹,位于F島的核電站锈玉,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏义起。R本人自食惡果不足惜拉背,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,265評(píng)論 3 329
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望默终。 院中可真熱鬧椅棺,春花似錦犁罩、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,871評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至诱渤,卻和暖如春丐巫,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背勺美。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,994評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工递胧, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人赡茸。 一個(gè)月前我還...
    沈念sama閱讀 48,095評(píng)論 3 370
  • 正文 我出身青樓缎脾,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親占卧。 傳聞我的和親對(duì)象是個(gè)殘疾皇子遗菠,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,884評(píng)論 2 354