Flutter/画面遷移/画面遷移イベント検知
提供: 初心者エンジニアの簡易メモ
(注意:動作確認できず)
画面でイベント検知する
結局MyAppと Page側の routeObserverが同期されておらず didPush だけ機能したが、他が機能しなかった。
class MyApp extends StatelessWidget {
+ RouteObserver<PageRoute> routeObserver = new RouteObserver<PageRoute>();
@override
Widget build(BuildContext context) {
return MaterialApp(
title: 'Memo',
theme: ThemeData(
primarySwatch: Colors.blue,
),
home: ArticleListTopPage(title: 'Memo List Page'),
+ navigatorObservers: <NavigatorObserver>[routeObserver],
);
}
}
_TextPageState と ArticleTextPage は各々のクラス名を入れる。
class _TextPageState extends State<ArticleTextPage> with RouteAware {
RouteObserver<PageRoute> routeObserver = new RouteObserver<PageRoute>();
@override
void didChangeDependencies() {
super.didChangeDependencies();
routeObserver.subscribe(this, ModalRoute.of(context));
}
@override
void dispose() {
routeObserver.unsubscribe(this);
super.dispose();
}
// この画面に戻ったとき
void didPopNext() {
debugPrint("didPopNext ${runtimeType}");
}
// 画面がpushされたとき
void didPush() {
debugPrint("didPush ${runtimeType}");
}
// 画面がpopされたとき
void didPop() {
debugPrint("didPop ${runtimeType}");
}
// 新しい画面へ移動した時
void didPushNext() {
debugPrint("didPushNext ${runtimeType}");
}
参考
https://qiita.com/najeira/items/89d8014a30102204babb
https://speakerdeck.com/kuwapp/flutterdehua-mian-qian-yi-wojian-zhi-suru?slide=15
