Flutter底部不规则导航的实现过程

 更新时间:2019年08月13日 11:01:31   作者:NiceBrother  
这篇文章主要给大家介绍了关于Flutter底部不规则导航的实现过程,文中通过示例代码介绍的非常详细,对大家学习或者使用Flutter具有一定的参考学习价值,需要的朋友们下面来一起学习学习吧

前言

本文主要介绍的是关于Flutter实现底部不规则导航的相关内容,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧

实现方法:

1、main.dart文件

import 'package:flutter/material.dart';
import 'bootom_appBar.dart';

void main () =>runApp(MyApp());

class MyApp extends StatelessWidget {

 @override
 Widget build(BuildContext context) {
 return MaterialApp(
  title:'不规则底部导航',
  //自定义主题样本
  theme:ThemeData(
   primarySwatch:Colors.lightBlue
  ),
  home:BottomAppBarDemo(),
 );
 }
}

2、bootom_appBar.dart

import 'package:flutter/material.dart';
import 'each_view.dart';

class BottomAppBarDemo extends StatefulWidget {
 @override
 _BottomAppBarDemoState createState() => _BottomAppBarDemoState();
}

class _BottomAppBarDemoState extends State<BottomAppBarDemo> {
 List<Widget> _eachView;
 int _index = 0;
 @override
 void initState() {
  _eachView = List();
  _eachView ..add(EachView('主页的页面'));
  _eachView ..add(EachView('副页的页面'));
  // TODO: implement initState
  super.initState();
 }
 @override
 Widget build(BuildContext context) {
  return Scaffold(
   //变换页面
   body: _eachView[_index],
   floatingActionButton: FloatingActionButton(
    onPressed: (){
     Navigator.of(context).push(MaterialPageRoute(builder: (BuildContext context){
      return EachView('新添加的页面');
     }));
    },
    tooltip: '添加',
    child: Icon(
     Icons.add,
     color: Colors.white,
    ),
   ),
   floatingActionButtonLocation: FloatingActionButtonLocation.centerDocked,
   bottomNavigationBar: BottomAppBar(
    //工具栏比NavigationBar灵活
    color: Colors.lightBlue,
    //与fab融合
    //圆形缺口
    shape: CircularNotchedRectangle(),
    child: Row(
     mainAxisSize: MainAxisSize.max,
     mainAxisAlignment: MainAxisAlignment.spaceAround,
     children: <Widget>[
      IconButton(
       icon: Icon(Icons.home),
       color: Colors.white,
       onPressed: (){
        setState(() {
         _index = 0;
        });
       },
      ),
      IconButton(
       icon: Icon(Icons.airport_shuttle),
       color: Colors.white,
       onPressed: (){
        setState(() {
         _index = 1;
        });
       },
      )
     ],
    ),
   ),
  );
 }
}

3、each_view.dart

import 'package:flutter/material.dart';

class EachView extends StatefulWidget {
 String _title;
 EachView(this._title);
 @override
 _EachViewState createState() => _EachViewState();
}

class _EachViewState extends State<EachView> {
 @override
 Widget build(BuildContext context) {
  return Scaffold(
   appBar: AppBar(title: Text(widget._title),),
   body: Center(child: Text(widget._title),),
  );
 }
}

4、效果展示


总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对脚本之家的支持。

相关文章

  • 安卓(Android)开发之分享带文字的图片

    安卓(Android)开发之分享带文字的图片

    用过微信分享SDK的都应该知道,微信分享到朋友圈的时候是不能同时分享图片和文字的,只要有缩略图,那么文字就不会生效。那么问题就来了,如果我们想把APP内的某些内容连带图片一起分享到微信,是不是没办法了呢?下面一起来看看怎么解决。
    2016-08-08
  • Android开发者常见的UI组件总结大全

    Android开发者常见的UI组件总结大全

    Android开发中UI组件是构建用户界面的基本元素,下面这篇文章主要给大家介绍了关于Android开发者常见的UI组件总结的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-04-04
  • Android Application存取公共数据的实例详解

    Android Application存取公共数据的实例详解

    这篇文章主要介绍了Android Application存取公共数据的实例详解的相关资料,需要的朋友可以参考下
    2017-07-07
  • Android实现带附件的邮件发送功能

    Android实现带附件的邮件发送功能

    这篇文章主要介绍了Android实现带附件的邮件发送功能的相关资料,android发送邮件有两种方式,本文重点介绍基于JMail实现邮件发送功能,感兴趣的小伙伴们可以参考一下
    2016-01-01
  • Android自动测试工具Monkey

    Android自动测试工具Monkey

    Monkey是Android中的一个命令行工具,可以运行在模拟器里或实际设备中。它向系统发送伪随机的用户事件流(如按键输入、触摸屏输入、手势输入等),实现对正在开发的应用程序进行压力测试。Monkey测试是一种为了测试软件的稳定性、健壮性的快速有效的方法
    2016-01-01
  • Android开发获取短信的内容并截取短信

    Android开发获取短信的内容并截取短信

    本文给大家介绍android开发获取短信内容并截取短息的相关内容,本文代码简单易懂,感兴趣的朋友一起学习吧
    2015-12-12
  • android动态布局之动态加入TextView和ListView的方法

    android动态布局之动态加入TextView和ListView的方法

    这篇文章主要介绍了android动态布局之动态加入TextView和ListView的方法,涉及Android动态布局的实现技巧,需要的朋友可以参考下
    2015-05-05
  • flutter PositionedTransition实现缩放动画

    flutter PositionedTransition实现缩放动画

    这篇文章主要为大家详细介绍了flutter PositionedTransition实现缩放动画,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-07-07
  • Android 谷歌推荐的VR实现方式(分享)

    Android 谷歌推荐的VR实现方式(分享)

    下面小编就为大家分享一篇Android 谷歌推荐的VR实现方式。具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2018-01-01
  • Android 下载网络图片并显示到本地

    Android 下载网络图片并显示到本地

    本文主要介绍了Android实现下载网络图片并显示到本地功能的示例代码。具有很好的参考价值,下面跟着小编一起来看下吧
    2017-03-03

最新评论