data:image/s3,"s3://crabby-images/dd2c2/dd2c2b9500c04d8c266061e32cec51383eb6da6a" alt="Flutter实战入门"
上QQ阅读APP看书,第一时间看更新
3.2.4 BottomNavigationBar
BottomNavigationBar为底部导航控件,主要属性参见表3-14。
表3-14 BottomNavigationBar属性
data:image/s3,"s3://crabby-images/791cc/791cc16d512b06541e183fe9c27534879f9efde3" alt=""
下面所示代码的效果类似于微信底部导航效果:
class BottomNavigationBarDemo extends StatefulWidget { @override State<StatefulWidget> createState() => _BottomNavigationBar(); } class _BottomNavigationBar extends State<BottomNavigationBarDemo> { int _selectIndex = 0; @override Widget build(BuildContext context) { // TODO: implement build return Scaffold( bottomNavigationBar: BottomNavigationBar( items: <BottomNavigationBarItem>[ BottomNavigationBarItem( title: Text( '微信', ), icon: Icon( Icons.access_alarms, color: Colors.black, ), activeIcon: Icon( Icons.access_alarms, color: Colors.green, ), ), BottomNavigationBarItem( title: Text( '通讯录', ), icon: Icon( Icons.access_alarms, color: Colors.black, ), activeIcon: Icon( Icons.access_alarms, color: Colors.green, ), ), BottomNavigationBarItem( title: Text( '发现', ), icon: Icon( Icons.access_alarms, color: Colors.black, ), activeIcon: Icon( Icons.access_alarms, color: Colors.green, ), ), BottomNavigationBarItem( title: Text( '我', ), icon: Icon( Icons.access_alarms, color: Colors.black, ), activeIcon: Icon( Icons.access_alarms, color: Colors.green, ), ), ], iconSize: 24, currentIndex: _selectIndex, onTap: (index) { setState(() { _selectIndex = index; }); }, fixedColor: Colors.green, type: BottomNavigationBarType.shifting, ), ); } }
运行效果如图3-18所示。
data:image/s3,"s3://crabby-images/66811/66811ae4b6f6e7fc32b850b3b92cb84d45946606" alt=""
图3-18 类似微信底部导航的效果