flutter实现底部导航栏

 更新时间:2022年03月23日 10:26:07   作者:伟雪无痕  
这篇文章主要为大家详细介绍了flutter实现底部导航栏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

一.flutter底部导航栏常用组件BottomNavigationBar 属性介绍

BottomNavigationBar({
    Key? key,
    required this.items, //必填项,设置各个按钮
    this.onTap, //点击事件
    this.currentIndex = 0, //当前选中item下标
    this.elevation, //控制阴影高度
    this.type, //BottomNavigationBarType,默认 fixed,设置为 shifting 时,需要设置选中样式,和未选中样式,提供一个特殊动画
    Color? fixedColor, //选中 item 填充色
    this.backgroundColor, //整个BottomNavigationBar 背景色
    this.iconSize = 24.0, //图标大小
    Color? selectedItemColor, //选中title填充色
    this.unselectedItemColor, //未选中title填充色
    this.selectedIconTheme, //选中item图标主题
    this.unselectedIconTheme, //未选中item图标主题
    this.selectedFontSize = 14.0, //选中title字体大小
    this.unselectedFontSize = 12.0, //未选中title字体大小
    this.selectedLabelStyle, //选中title样式 TextStyle
    this.unselectedLabelStyle, //未选中title样式 TextStyle
    this.showSelectedLabels, //是否展示选中title,默认为true
    this.showUnselectedLabels, //是否展示未选中title,默认为true
    this.mouseCursor, //鼠标悬停
    this.enableFeedback,
    this.landscapeLayout,
  }) 

二.BottomNavigationBar的具体实现

1.创建四个页面,分别为,首页,通讯录,发现和我的,这里以homepage.dart为例,其他页面只需要修改对应内容显示即可,eg:

import 'package:flutter/material.dart';
 
class HomePage extends StatefulWidget{
 
  const HomePage({Key? key}) : super(key: key);
 
  @override
  State<StatefulWidget> createState()=>_HomePageState();
 
}
 
class _HomePageState extends State<HomePage>{
 
  @override
  Widget build(BuildContext context) {
    return const Center(
      child: Text(
        "主页",
        style:TextStyle(
          color: Colors.black,
          fontSize: 20
        ),
      ),
    );
  }
 
}

2.添加BottomNavigationBar,需要在主页中实现BottomNavigationBar,eg:

import 'package:flutter/material.dart';
import 'findpage.dart';
import 'mypage.dart';
import 'contactpage.dart';
import 'homepage.dart';
 
class MainPage extends StatefulWidget{
  const MainPage({Key? key}) : super(key: key);
 
  @override
  State<StatefulWidget> createState()=>_MainPageState();
}
 
class _MainPageState extends State<MainPage>{
 
  var allPages=[HomePage(),ContactPage(),FindPage(),MyPage()];
  var currentIndex=0;
 
 
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(
          "导航栏",
          style: TextStyle(
            color: Colors.black,
            fontSize: 30,
          ),
          textAlign: TextAlign.center,
        ),
      ),
      body: allPages[currentIndex],
      backgroundColor: Colors.green,
      bottomNavigationBar: BottomNavigationBar(
        currentIndex: currentIndex,
        type: BottomNavigationBarType.fixed,
        unselectedItemColor: Colors.grey,
        selectedItemColor: Colors.blue,
        /*unselectedLabelStyle:TextStyle(
          color: Colors.black
        ),*/
        items: [
          BottomNavigationBarItem(
              icon: Icon(Icons.home),
              label: "首页",
              //backgroundColor:Colors.blue
          ),
 
          BottomNavigationBarItem(
              icon: Icon(Icons.person),
              label: "通讯录",
              //backgroundColor:Colors.blue
          ),
 
          BottomNavigationBarItem(
              icon: Icon(Icons.find_in_page),
              label: "发现",
              //backgroundColor:Colors.blue
          ),
 
          BottomNavigationBarItem(
              icon: Icon(Icons.flip_outlined),
              label: "我的",
              //backgroundColor:Colors.blue
          ),
        ],
 
        onTap: (index){
          setState(() {
            print("the index is :$index");
            currentIndex=index;
          });
        },
      ),
    );
  }
}

三.实际效果展示,eg:

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • Android Flutter实战之为照片添加颜色滤镜

    Android Flutter实战之为照片添加颜色滤镜

    这篇文章我们将利用TweenAnimationBuilder来实现一个图片调色的过渡动画,从而实现为照片添加颜色滤镜的效果,感兴趣的可以了解一下
    2022-12-12
  • Android Studio 配置忽略文件的方法实现

    Android Studio 配置忽略文件的方法实现

    这篇文章主要介绍了Android Studio 配置忽略文件的方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-10-10
  • Android 物理游戏之重力系统开发示例代码

    Android 物理游戏之重力系统开发示例代码

    介绍Android 物理游戏之重力系统,这里提供了详细的资料整理,并附示例代码和实现效果图,有兴趣的小伙伴可以参考下
    2016-08-08
  • Android自定义View实现打字机效果

    Android自定义View实现打字机效果

    最近在做Android开发的时候,需要做类似于打字机打字的效果,字一个一个地蹦出来,显示每一个字都带有打字的声音。现在分享给大家,有需要的可以参考借鉴。
    2016-08-08
  • 解决Could not find com.android.tools.build:gradle:3.0.0

    解决Could not find com.android.tools.build:gradle:3.0.0

    这篇文章主要介绍了在Android Studio升级时碰到Could not find com.android.tools.build:gradle:3.0.0问题的解决方法,需要的朋友跟随小编一起看看吧
    2021-08-08
  • Android自定义Dialog实现加载对话框效果

    Android自定义Dialog实现加载对话框效果

    这篇文章将介绍如何定制当今主流的对话框,通过自定义dialog实现加载对话框效果,具体实现代码大家通过本文学习吧
    2018-05-05
  • 使用Android的OkHttp包实现基于HTTP协议的文件上传下载

    使用Android的OkHttp包实现基于HTTP协议的文件上传下载

    OkHttp(GitHub主页https://github.com/square/okhttp)是近来人气攀升的一款安卓第三方HTTP包,这里我们来讲解一下如何使用Android的OkHttp包实现基于HTTP协议的文件上传下载:
    2016-07-07
  • Android获取、更改包名的小技巧分享(超实用)

    Android获取、更改包名的小技巧分享(超实用)

    这篇文章主要给大家分享介绍了关于利用Android更改包名的一个小技巧,通过这个方法大家可以很方便的修改包名,再也不用为频繁修改包名而感到头疼,文中还给大家分享利一个android获取手机所有应用包名的方法,下面随着小编来一起学习学习吧。
    2017-12-12
  • android中的adb命令学习

    android中的adb命令学习

    这篇文章介绍了android中的adb命令,文中通过示例代码介绍的非常详细。对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-04-04
  • viewPager+fragment刷新缓存fragment的方法

    viewPager+fragment刷新缓存fragment的方法

    这篇文章主要介绍了viewPager+fragment刷新缓存fragment的方法,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2017-03-03

最新评论