用法如下:
Scaffold( bottomNavigationBar: BottomAppBar( child: Row( mainAxisAlignment: MainAxisAlignment.spaceAround, children: <Widget>[ IconButton( icon: Icon(Icons.home), ), IconButton( icon: Icon(Icons.people), ) ], ), ), floatingActionButton: FloatingActionButton(), floatingActionButtonLocation: FloatingActionButtonLocation.centerDocked, )效果如下:
data:image/s3,"s3://crabby-images/4745a/4745a3410176699d95cee0f4872d7c8c9a74169b" alt=""
FloatingActionButton是悬浮在BottomAppBar上面,并没有嵌入里面,嵌入里面用法如下:
BottomAppBar( shape: CircularNotchedRectangle(), ... )增加BottomAppBar的形状,效果如下:
data:image/s3,"s3://crabby-images/87c56/87c563443debfb6f6971d603cbf7a8a9481350a8" alt=""
elevation参数为阴影值:
BottomAppBar( elevation: 8.0, ... )notchMargin参数表示缺口外边距:
BottomAppBar( notchMargin: 10, ... )效果如下:
data:image/s3,"s3://crabby-images/42dcd/42dcde80f8686693937ea7fc3b32c635d4d60c73" alt=""
改变FloatingActionButton的形状为足球场形状,切嵌入的形状随之变化,代码如下:
Scaffold( bottomNavigationBar: BottomAppBar( shape: AutomaticNotchedShape( RoundedRectangleBorder(), StadiumBorder(side: BorderSide())), child: Row( mainAxisAlignment: MainAxisAlignment.spaceAround, children: <Widget>[ IconButton( icon: Icon(Icons.home), ), IconButton( icon: Icon(Icons.people), ) ], ), ), floatingActionButton: FloatingActionButton.extended( onPressed: () {}, icon: new Icon(Icons.add), label: const Text("label"), ), floatingActionButtonLocation: FloatingActionButtonLocation.centerDocked, )效果如下:
data:image/s3,"s3://crabby-images/62dc9/62dc9c49b3b35b4df2de7239acc40eb371cf39e1" alt=""
改为多边形:
Scaffold( bottomNavigationBar: BottomAppBar( shape: AutomaticNotchedShape( RoundedRectangleBorder(), BeveledRectangleBorder(borderRadius: BorderRadius.circular(10))), child: Row( mainAxisAlignment: MainAxisAlignment.spaceAround, children: <Widget>[ IconButton( icon: Icon(Icons.home), ), IconButton( icon: Icon(Icons.people), ) ], ), ), floatingActionButton: FloatingActionButton.extended( onPressed: () {}, shape: BeveledRectangleBorder(borderRadius: BorderRadius.circular(10)), icon: new Icon(Icons.add), label: const Text("label"), ), floatingActionButtonLocation: FloatingActionButtonLocation.centerDocked, )效果如下:
data:image/s3,"s3://crabby-images/c3ead/c3ead37a278377d9798b9be476d7dc43db34c8c3" alt=""
当然也可以改为棱形:
Scaffold( bottomNavigationBar: BottomAppBar( shape: AutomaticNotchedShape( RoundedRectangleBorder(), BeveledRectangleBorder(borderRadius: BorderRadius.circular(100))), ... floatingActionButton: FloatingActionButton.extended( onPressed: () {}, shape: BeveledRectangleBorder(borderRadius: BorderRadius.circular(100)), icon: new Icon(Icons.add), label: const Text("label"), ), ... )效果如下:
data:image/s3,"s3://crabby-images/e78b0/e78b0b89216b353c6ffc9186a6363eea2a2eac8b" alt=""
我们可以通过此控件定义任何我们想要的效果。
更多参考:
BottomNavigationBar底部导航栏详解、
BottomAppBar底部应用栏和floatingActionButton实现中间凸起的底部导航
部分素材资源来源网站,本站提供免费下载,如有侵权请联系站长马上删除!