flutter BottomAppBar实现不规则底部导航栏
作者:早起的年轻人 时间:2023-06-19 23:40:19
本文实例为大家分享了flutter实现不规则底部导航栏的具体代码,供大家参考,具体内容如下
实现底部导航栏并点击切换页面可简述为有三种方式
TabBar + TabBarView
BottomNavigationBar + BottomNavigationBarItem
自定义 BottomAppBar
在这里 使用 BottomAppBar 来实现
/**
* 有状态StatefulWidget
* 继承于 StatefulWidget,通过 State 的 build 方法去构建控件
*/
class BotomeMenumBarPage extends StatefulWidget {
////通过构造方法传值
BotomeMenumBarPage();
//主要是负责创建state
@override
BotomeMenumBarPageState createState() => BotomeMenumBarPageState();
}
/**
* 在 State 中,可以动态改变数据
* 在 setState 之后,改变的数据会触发 Widget 重新构建刷新
*/
class BotomeMenumBarPageState extends State<BotomeMenumBarPage> {
BotomeMenumBarPageState();
@override
void initState() {
///初始化,这个函数在生命周期中只调用一次
super.initState();
}
@override
Widget build(BuildContext context) {
//构建页面
return buildBottomTabScaffold();
}
//当前显示页面的
int currentIndex = 0;
//点击导航项是要显示的页面
final pages = [
ChildItemView("首页"),
ChildItemView("发现"),
ChildItemView("动态"),
ChildItemView("我的")
];
Widget buildBottomTabScaffold() {
return SizedBox(
height: 100,
child: Scaffold(
//对应的页面
body: pages[currentIndex],
//appBar: AppBar(title: const Text('Bottom App Bar')),
//悬浮按钮的位置
floatingActionButtonLocation:
FloatingActionButtonLocation.centerDocked,
//悬浮按钮
floatingActionButton: FloatingActionButton(
child: const Icon(Icons.add),
onPressed: () {
print("add press ");
},
),
//其他菜单栏
bottomNavigationBar: BottomAppBar(
//悬浮按钮 与其他菜单栏的结合方式
shape: CircularNotchedRectangle(),
// FloatingActionButton和BottomAppBar 之间的差距
notchMargin: 6.0,
color: Colors.white,
child: Row(
mainAxisSize: MainAxisSize.max,
mainAxisAlignment: MainAxisAlignment.spaceAround,
children: <Widget>[
buildBotomItem(currentIndex, 0, Icons.home, "首页"),
buildBotomItem(currentIndex, 1, Icons.library_music, "发现"),
buildBotomItem(currentIndex, -1, null, "发现"),
buildBotomItem(currentIndex, 2, Icons.email, "消息"),
buildBotomItem(currentIndex, 3, Icons.person, "我的"),
],
),
),
));
}
// ignore: slash_for_doc_comments
/**
* @param selectIndex 当前选中的页面
* @param index 每个条目对应的角标
* @param iconData 每个条目对就的图标
* @param title 每个条目对应的标题
*/
buildBotomItem(int selectIndex, int index, IconData iconData, String title) {
//未选中状态的样式
TextStyle textStyle = TextStyle(fontSize: 12.0,color: Colors.grey);
MaterialColor iconColor = Colors.grey;
double iconSize=20;
EdgeInsetsGeometry padding = EdgeInsets.only(top: 8.0);
if(selectIndex==index){
//选中状态的文字样式
textStyle = TextStyle(fontSize: 13.0,color: Colors.blue);
//选中状态的按钮样式
iconColor = Colors.blue;
iconSize=25;
padding = EdgeInsets.only(top: 6.0);
}
Widget padItem = SizedBox();
if (iconData != null) {
padItem = Padding(
padding: padding,
child: Container(
color: Colors.white,
child: Center(
child: Column(
children: <Widget>[
Icon(
iconData,
color: iconColor,
size: iconSize,
),
Text(
title,
style: textStyle,
)
],
),
),
),
);
}
Widget item = Expanded(
flex: 1,
child: new GestureDetector(
onTap: () {
if (index != currentIndex) {
setState(() {
currentIndex = index;
});
}
},
child: SizedBox(
height: 52,
child: padItem,
),
),
);
return item;
}
}
//子页面
class ChildItemView extends StatefulWidget {
String _title;
ChildItemView(this._title);
@override
_ChildItemViewState createState() => _ChildItemViewState();
}
class _ChildItemViewState extends State<ChildItemView> {
@override
Widget build(BuildContext context) {
return Container(
child: Center(child: Text(widget._title)),
);
}
}
来源:https://blog.csdn.net/zl18603543572/article/details/94876972
标签:flutter,导航栏
0
投稿
猜你喜欢
关于jdk环境变量的配置方式解读
2023-04-22 14:53:05
SpringMVC使用MultipartResolver实现文件上传
2023-02-19 08:34:38
聊聊SpringMVC项目依赖和静态资源导出问题
2023-03-26 13:32:20
Android 存储路径选择方法
2022-04-03 21:05:42
使用jdk1.8实现将list根据指定的值去分组的操作
2022-10-04 18:12:48
Java深入讲解Object类常用方法的使用
2022-11-22 00:16:51
c# 值类型实例构造器
2023-12-23 16:10:10
Android内置SQLite的使用详细介绍
2021-10-24 11:44:17
基于Android实现桌面悬浮清内存app概述
2023-05-02 22:56:35
Spring Boot+Shiro实现一个Http请求的Basic认证
2022-06-01 22:22:31
Android通过SOCKET下载文件的方法
2023-08-27 01:11:48
Android使用分类型RecyclerView仿各大商城首页
2021-06-29 12:08:23
Java Socket编程(五) 简单的WEB服务器
2023-05-23 01:00:04
java property配置文件管理工具框架过程详解
2023-10-12 04:35:50
c#求范围内素数的示例分享(c#求素数)
2022-07-09 22:20:10
Java Gradle项目中的资源正确获取方式
2022-10-05 09:00:50
java 实现截取字符串并按字节分别输出实例代码
2021-08-28 08:10:44
C# 16进制与字符串、字节数组之间的转换
2021-07-13 08:08:10
Android Service中使用Toast无法正常显示问题的解决方法
2022-01-23 08:38:12
c# wpf使用GMap.NET类库,实现地图轨迹回放
2023-04-20 06:46:27