gpt4 book ai didi

flutter - 弯曲的导航栏使其可点击

转载 作者:行者123 更新时间:2023-12-02 19:42:35 26 4
gpt4 key购买 nike

我想使用这个导航条码,它工作正常,但问题是我不知道如何使项目可点击到每个项目显示我想要的 dart 文件?例如: add: show add.dart, list :show list.dart 和 ...

这是代码:

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

void main() => runApp(MaterialApp(home: BottomNavBar()));

class BottomNavBar extends StatefulWidget {
@override
_BottomNavBarState createState() => _BottomNavBarState();
}

class _BottomNavBarState extends State<BottomNavBar> {
int _page = 0;
GlobalKey _bottomNavigationKey = GlobalKey();

@override
Widget build(BuildContext context) {
return Scaffold(
bottomNavigationBar: CurvedNavigationBar(
key: _bottomNavigationKey,
index: 0,
height: 50.0,
items: <Widget>[
Icon(Icons.add, size: 30),
Icon(Icons.list, size: 30),
Icon(Icons.compare_arrows, size: 30),
Icon(Icons.call_split, size: 30),
Icon(Icons.perm_identity, size: 30),
],
color: Colors.white,
buttonBackgroundColor: Colors.white,
backgroundColor: Colors.blueAccent,
animationCurve: Curves.easeInOut,
animationDuration: Duration(milliseconds: 600),
onTap: (index) {
setState(() {
_page = index;
});
},
),
body: Container(
color: Colors.blueAccent,
child: Center(
child: Column(
children: <Widget>[
Text(_page.toString(), textScaleFactor: 10.0),
RaisedButton(
child: Text('Go To Page of index 1'),
onPressed: () {
final CurvedNavigationBarState navBarState =
_bottomNavigationKey.currentState;
navBarState.setPage(1);
},
)
],
),
),
));
}
}

最佳答案

您可以使用index来显示您需要的页面。

import 'package:flutter/material.dart';
import 'package:curved_navigation_bar/curved_navigation_bar.dart';
import 'page1.dart'
import 'page2.dart'

void main() => runApp(MaterialApp(home: BottomNavBar()));

class BottomNavBar extends StatefulWidget {
@override
_BottomNavBarState createState() => _BottomNavBarState();
}

class _BottomNavBarState extends State<BottomNavBar> {
int _pageIndex = 0;
GlobalKey _bottomNavigationKey = GlobalKey();

List pages = [
MyRoute(
iconData: Icons.add,
page: Page1(),
),
MyRoute(
iconData: Icons.compare_arrows,
page: Page2(),
)
];

@override
Widget build(BuildContext context) {
return Scaffold(
bottomNavigationBar: CurvedNavigationBar(
key: _bottomNavigationKey,
index: 0,
height: 50.0,
items: pages
.map((p) => Icon(
p.iconData,
size: 30,
))
.toList(),
color: Colors.white,
buttonBackgroundColor: Colors.white,
backgroundColor: Colors.blueAccent,
animationCurve: Curves.easeInOut,
animationDuration: Duration(milliseconds: 600),
onTap: (index) {
setState(() {
_pageIndex = index;
});
},
),
backgroundColor: Colors.blueAccent,
body: pages[_pageIndex].page,
);
}
}

class MyRoute {
final IconData iconData;
final Widget page;

MyRoute({this.iconData, this.page});
}

page1.dart

class Page1 extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Center(child: Text('Page1'));
}
}

page2.dart

class Page2 extends StatelessWidget {
@override
Widget build(BuildContext context) {
return Center(child: Text('Page2'));
}
}

关于flutter - 弯曲的导航栏使其可点击,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59890966/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com