代码
实现效果如下:
data:image/s3,"s3://crabby-images/c6f25/c6f255d1afb0688fc2671df02562867ec0fb749d" alt=""
data:image/s3,"s3://crabby-images/ba27e/ba27e71d33fce767c9239a9f0e11eafff135532e" alt=""
涉及知识点
1、自定义主题
2、BottomNavigationBar、FloatingActionButton(可交互的浮动的按钮)、BottomAppBar
3、级联符号..允许您在同一个对象上进行一系列操作。相当于返回调用者自己
1、自定义主题
data:image/s3,"s3://crabby-images/5aa9e/5aa9e1f3d7f08d106ef3aaefdfacec893734b980" alt=""
对应效果为
data:image/s3,"s3://crabby-images/328b8/328b81bf83e2e73413e9aed062eb77f0cd7d1170" alt=""
2、BottomNavigationBar、FloatingActionButton(可交互的浮动的按钮)、BottomAppBar
-
BottomNavigationBar
data:image/s3,"s3://crabby-images/bbe63/bbe6306c00329e1b33be562f3b6a7a6f4f0f4604" alt=""
bottomNavigationBar: BottomNavigationBar(
items: <BottomNavigationBarItem>[
BottomNavigationBarItem(
icon: Icon(Icons.home, color: Colors.redAccent,),
title: Text('Home',style: TextStyle(color: Colors.redAccent),),
),
BottomNavigationBarItem(
icon: Icon(Icons.email,color: Colors.redAccent,),
title: Text('Email',style: TextStyle(color: Colors.redAccent),),
),
BottomNavigationBarItem(
icon: Icon(Icons.map,color: Colors.redAccent,),
title: Text('Map',style: TextStyle(color: Colors.redAccent),),
),
BottomNavigationBarItem(
icon: Icon(Icons.dashboard,color: Colors.redAccent,),
title: Text('Dashboard',style: TextStyle(color: Colors.redAccent),),
),
],
currentIndex: _currentIndex,
type: BottomNavigationBarType.fixed,
onTap: (int index){
setState(() {
_currentIndex = index;
});
}
),
-
FloatingActionButton(可交互的浮动的按钮)
data:image/s3,"s3://crabby-images/61b6d/61b6d50eba9e3a21d649c5bc48f7bb38a62a1461" alt=""
floatingActionButton: FloatingActionButton(
onPressed: (){
Navigator.push(context, MaterialPageRoute(builder: (context)=>BottomView('不规则加号')));
},
tooltip: '长按了...',
child: Icon(Icons.add, color: Colors.white,)
),
-
BottomAppBar
data:image/s3,"s3://crabby-images/1aa96/1aa961b06026a02441ddd8d2b4a42c8fe1f7315f" alt=""
bottomNavigationBar: BottomAppBar(
color: Colors.purple,
//预留一个间隙,用来存放floatingActionButton
shape: CircularNotchedRectangle(),
child: Row(
//主轴对齐方式
mainAxisAlignment: MainAxisAlignment.spaceAround,
mainAxisSize: MainAxisSize.max,
children: <Widget>[
IconButton(
onPressed: (){
setState(() {
currentIndex = 0;
});
},
icon: Icon(Icons.home),
color: Colors.white,
iconSize: 30,
),
//后面三个代码同上IconButton
],
),
),
3、级联符号..允许您在同一个对象上进行一系列操作。
dataList = List();
//点语法
dataList..add(BottomView('Home'))
..add(BottomView('love'))
..add(BottomView('launch'))
..add(BottomView('dashboard'));
网友评论