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),onpressed: (){
        setState(() {
         _index = 0;
        });
       },IconButton(
       icon: Icon(Icons.airport_shuttle),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、效果展示

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

总结

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

相关文章

Android性能优化——之控件的优化 前面讲了图像的优化,接下...
前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要...
最近项目重构,涉及到了数据库和文件下载,发现GreenDao这个...
WebView加载页面的两种方式 一、加载网络页面 加载网络页面,...
给APP全局设置字体主要分为两个方面来介绍 一、给原生界面设...
前言 最近UI大牛出了一版新的效果图,按照IOS的效果做的,页...