Flutter可滚动重排序导航栏插件scrollable_reorderable_navbar的使用
Flutter可滚动重排序导航栏插件 scrollable_reorderable_navbar
的使用
ScrollableReordableNavbar
是一个用于 Flutter 的插件,可以创建底部导航栏。当导航项超过5个时,导航栏可以滚动显示,并且允许用户通过滑动重新排列导航项,还可以删除导航项。
安装
在您的 pubspec.yaml
文件中添加依赖:
dependencies:
scrollable_reorderable_navbar: ^0.0.1
导入包:
import 'package:scrollable_reorderable_navbar/scrollable_reorderable_navbar.dart';
基本用法
以下是一个基本的示例代码:
import 'package:flutter/material.dart';
import 'package:scrollable_reorderable_navbar/scrollable_reorderable_navbar.dart';
void main() {
runApp(const MyApp());
}
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
[@override](/user/override)
Widget build(BuildContext context) {
return MaterialApp(
title: 'Permissions demo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: const BottomNavBarPage(),
);
}
}
class BottomNavBarPage extends StatefulWidget {
const BottomNavBarPage({Key? key}) : super(key: key);
[@override](/user/override)
_BottomNavBarPageState createState() => _BottomNavBarPageState();
}
class _BottomNavBarPageState extends State<BottomNavBarPage> {
int _selectedIndex = 0;
List<NavBarItem> _items = const [
NavBarItem(widget: Icon(Icons.home), name: "Home"),
NavBarItem(widget: Icon(Icons.group), name: "Social"),
NavBarItem(widget: Icon(Icons.call), name: "Calls"),
NavBarItem(widget: Icon(Icons.image), name: "Pictures"),
NavBarItem(widget: Icon(Icons.message), name: "Messages"),
NavBarItem(widget: Icon(Icons.settings), name: "Settings")
];
[@override](/user/override)
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(title: const Text("Bottom nav bar")),
bottomNavigationBar: ScrollableReorderableNavBar(
onItemTap: (arg) {
setState(() {
_selectedIndex = arg;
});
},
onReorder: (oldIndex, newIndex) {
final currItem = _items[_selectedIndex];
if (oldIndex < newIndex) newIndex -= 1;
final newItems = [..._items], item = newItems.removeAt(oldIndex);
newItems.insert(newIndex, item);
setState(() {
_items = newItems;
_selectedIndex = _items.indexOf(currItem);
});
},
items: _items,
selectedIndex: _selectedIndex,
onDelete: (index) => setState(() => _items.removeAt(index)),
deleteIndicationWidget: Container(
padding: const EdgeInsets.only(bottom: 100),
child: Align(
alignment: Alignment.bottomCenter,
child: Wrap(
alignment: WrapAlignment.center,
crossAxisAlignment: WrapCrossAlignment.center,
direction: Axis.vertical,
children: [
Text("Tap on nav item to delete it.",
style: Theme.of(context).textTheme.bodyText1,
textAlign: TextAlign.center),
TextButton(onPressed: () {}, child: const Text("DONE"))
],
),
),
),
),
);
}
}
更多关于Flutter可滚动重排序导航栏插件scrollable_reorderable_navbar的使用的实战系列教程也可以访问 https://www.itying.com/category-92-b0.html
1 回复