坐看不如實戰來的有效率,這幾天都在看flutter的一些佈局和特性,打算從零開始搭建一個應用,中間可能會由於一些緣由斷了文章,可是會慢慢補上。bash
學移動端的套路:網絡
在學習移動開發的時候,通常都是按照這幾個套路走,app
固然,接下來的一系列也是按照這個步驟走框架
今天先來搭建一個基礎的佈局,在Android的首頁佈局中,大部分都是Fragment+TabBottom的形式,先來看下效果圖。less
效果圖ide
main.dart 啓動的main.dart是啓動的界面,返回的主佈局是MainPage,而後去佈局
import 'package:flutter/material.dart';
import 'package:codelang/MainPage.dart';
void main() => runApp(new MyApp());
class MyApp extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new MaterialApp(
title: 'Flutter Demo',
theme: new ThemeData(
primarySwatch: Colors.blue,
),
home: MainPage(),
);
}
}
複製代碼
MainPage學習
import 'package:flutter/material.dart';
import 'package:flutter/cupertino.dart';
import 'package:codelang/page/MsgPage.dart';
import 'package:codelang/page/HomePage.dart';
import 'package:codelang/page/ShopPage.dart';
import 'package:codelang/page/MyPage.dart';
import 'package:codelang/widget/Demo1.dart';
class MainPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new MaterialApp(
debugShowCheckedModeBanner: false,
routes: <String, WidgetBuilder>{
"/Demo1": (BuildContext context) => new Demo1(),
},
home: new MainPageWidget());
}
}
class MainPageWidget extends StatefulWidget {
@override
State<StatefulWidget> createState() {
// TODO: implement createState
return new MainPageState();
}
}
class MainPageState extends State<MainPageWidget> {
int _tabIndex = 0;
var tabImages;
var appBarTitles = ['首頁', '商鋪', '消息', '個人'];
/*
* 根據image路徑獲取圖片
* 這個圖片的路徑須要在 pubspec.yaml 中去定義
*/
Image getTabImage(path) {
return new Image.asset(path, width: 20.0, height: 20.0);
}
/*
* 根據索引得到對應的normal或是press的icon
*/
Image getTabIcon(int curIndex) {
if (curIndex == _tabIndex) {
return tabImages[curIndex][1];
}
return tabImages[curIndex][0];
}
/*
* 獲取bottomTab的顏色和文字
*/
Text getTabTitle(int curIndex) {
if (curIndex == _tabIndex) {
return new Text(appBarTitles[curIndex],
style: new TextStyle(color: const Color(0xff63ca6c)));
} else {
return new Text(appBarTitles[curIndex],
style: new TextStyle(color: const Color(0xff888888)));
}
}
/*
* 存儲的四個頁面,和Fragment同樣
*/
var _bodys;
void initData() {
/*
bottom的按壓圖片
*/
tabImages = [
[
getTabImage('images/ic_home_normal.png'),
getTabImage('images/ic_home_press.png')
],
[
getTabImage('images/ic_shop_normal.png'),
getTabImage('images/ic_shop_press.png')
],
[
getTabImage('images/ic_msg_normal.png'),
getTabImage('images/ic_msg_press.png')
],
[
getTabImage('images/ic_my_normal.png'),
getTabImage('images/ic_my_press.png')
]
];
_bodys = [
new HomePage(),
new ShopPage(),
new MsgPage(),
new MyPage()
];
}
@override
Widget build(BuildContext context) {
initData();
// TODO: implement build
return Scaffold(
appBar: new AppBar(
title: new Text("主頁"),
),
body: _bodys[_tabIndex],
bottomNavigationBar: new BottomNavigationBar(
items: <BottomNavigationBarItem>[
new BottomNavigationBarItem(
icon: getTabIcon(0), title: getTabTitle(0)),
new BottomNavigationBarItem(
icon: getTabIcon(1), title: getTabTitle(1)),
new BottomNavigationBarItem(
icon: getTabIcon(2), title: getTabTitle(2)),
new BottomNavigationBarItem(
icon: getTabIcon(3), title: getTabTitle(3)),
],
//設置顯示的模式
type: BottomNavigationBarType.fixed,
//設置當前的索引
currentIndex: _tabIndex,
//tabBottom的點擊監聽
onTap: (index) {
setState(() {
_tabIndex = index;
});
},
),
);
}
}
複製代碼
主界面主要經過bottomNavigationBar定義頁面底部的四個tab,body部分主要是經過_tabIndex
索引在_bodys
中切換頁面,這裏我定義了四個Page,HomePage、ShopPage、MsgPage、MyPage
, 這四個Page都是同樣的,就發一個出來看看,其餘的雷同ui
import 'package:flutter/material.dart';
class MsgPage extends StatelessWidget {
@override
Widget build(BuildContext context) {
return new MaterialApp(
title: 'Flutter Demo',
theme: new ThemeData(
primarySwatch: Colors.blue,
),
debugShowCheckedModeBanner: false,
home: new Scaffold(
body: new Center(child:new Text("消息")),
),
);
}
}
複製代碼
按照開發Android的思路來看這個佈局的話,仍是很容易理解的,這裏面還要注意的幾個點,獲取本地資源的圖片,是須要在pubspec.yaml
中去定義的,定義以下,在assets背後放置圖片的路徑,那麼,這個路徑就能夠被Image識別並使用spa
flutter:
assets:
- images/ic_home_normal.png
- images/ic_home_press.png
- images/ic_shop_normal.png
- images/ic_shop_press.png
- images/ic_msg_normal.png
- images/ic_msg_press.png
- images/ic_my_normal.png
- images/ic_my_press.png
複製代碼
ok,基本的框架起來了