Files
2022-03-26 21:25:40 +08:00

179 lines
4.6 KiB
Dart

import 'package:flutter/material.dart';
/// create by 张风捷特烈 on 2020/7/19
/// contact me by email 1981462002@qq.com
/// 说明:
///
// {
// "widgetId": 232,
// "name": 'Navigator基本用法',
// "priority": 1,
// "subtitle":
// "【initialRoute】 : 最初显示路由 【String】\n"
// "【onGenerateRoute】 : 路由生成器 【RouteFactory】\n"
// "【observers】 : 路由监听器 【List<NavigatorObserver>】\n"
// "【onPopPage】 : 出栈回调 【PopPageCallback】",
// }
class NavigatorDemo extends StatelessWidget {
const NavigatorDemo({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return SizedBox(
height: 200,
width: 300,
child: Navigator(
onPopPage: _onPopPage,
initialRoute: '/home-content',
onGenerateRoute: _onGenerateRoute,
observers: [TolyNavigatorObservers()],
),
);
}
Route _onGenerateRoute(RouteSettings settings) {
switch (settings.name) {
case '/home-content':
return MaterialPageRoute(
builder: (_) => const HomeContent(), settings: settings);
case "/red":
return MaterialPageRoute(builder: (_) => const RedPage(), settings: settings);
case "/yellow":
return MaterialPageRoute(
builder: (_) => const YellowPage(), settings: settings);
case "/green":
return MaterialPageRoute(
builder: (_) => const GreenPage(), settings: settings);
default:
return MaterialPageRoute(
builder: (_) => const HomeContent(), settings: settings);
}
}
bool _onPopPage(Route<dynamic> route, result) {
print('----_onPopPage-----');
return true;
}
}
//路由监听器
class TolyNavigatorObservers extends NavigatorObserver {
@override
void didPush(Route<dynamic> route, Route<dynamic>? previousRoute) {
print(
'--didPush:--route:--${route.settings}--previousRoute:--${previousRoute?.settings}');
}
@override
void didStopUserGesture() {
print('--didStopUserGesture:--');
}
@override
void didStartUserGesture(Route<dynamic> route, Route<dynamic>? previousRoute) {
print(
'--didStartUserGesture:--route:--${route.settings}--previousRoute:--${previousRoute?.settings}');
}
@override
void didReplace({Route<dynamic>? newRoute, Route<dynamic>? oldRoute}) {
print(
'--didReplace:--newRoute:--${newRoute?.settings}--oldRoute:--${oldRoute?.settings}');
}
@override
void didRemove(Route<dynamic>? route, Route<dynamic>? previousRoute) {
print(
'--didRemove:--route:--${route?.settings}--previousRoute:--${previousRoute?.settings}');
}
@override
void didPop(Route<dynamic> route, Route<dynamic>? previousRoute) {
print(
'--didPop:--route:--${route.settings}--previousRoute:--${previousRoute?.settings}');
}
}
class HomeContent extends StatelessWidget {
const HomeContent({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Column(
children: <Widget>[
Row(
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
RaisedButton(
color: Colors.red,
onPressed: () {
Navigator.pushNamed(context, '/red');
},
),
RaisedButton(
color: Colors.yellow,
onPressed: () {
Navigator.pushNamed(context, '/yellow');
},
),
RaisedButton(
color: Colors.green,
onPressed: () {
Navigator.pushNamed(context, '/green');
},
)
],
),
],
);
}
}
class RedPage extends StatelessWidget {
const RedPage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("RedPage"),
),
body: Container(
color: Colors.red,
),
);
}
}
class YellowPage extends StatelessWidget {
const YellowPage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("YellowPage"),
),
body: Container(
color: Colors.yellow,
),
);
}
}
class GreenPage extends StatelessWidget {
const GreenPage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("GreenPage"),
),
body: Container(
color: Colors.green,
),
);
}
}