flutter BottomAppBar实现不规则底部导航栏

作者:早起的年轻人 时间:2023-06-19 23:40:19 

本文实例为大家分享了flutter实现不规则底部导航栏的具体代码,供大家参考,具体内容如下

实现底部导航栏并点击切换页面可简述为有三种方式

  • TabBar + TabBarView

  • BottomNavigationBar + BottomNavigationBarItem

  • 自定义 BottomAppBar

在这里 使用 BottomAppBar 来实现

flutter 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
  • asp之家 软件编程 m.aspxhome.com