单击通知时路由到特定的颤动屏幕

Dja*_*ada 1 push-notification flutter google-cloud-functions firebase-cloud-messaging

如何在点击通知时转到特定屏幕?我在javascript中使用了云功能,当我点击通知时,它打开了我的应用程序而不是特定的屏幕

 _fcm.configure(
  onMessage: (Map<String, dynamic> message) async {
    print("onMessage: $message");
    getOrder(message['data']['order_id']);
    showDialog(
      context: context,
      builder: (context) => AlertDialog(
        content: ListTile(
          title: Text(message['notification']['title']),
          subtitle: Text(message['notification']['body']),
        ),
        actions: <Widget>[
          FlatButton(
            child: Text('Ok'),
            onPressed: () => Navigator.of(context).pop(),
          ),
        ],
      ),
    );
  },
  onLaunch: (Map<String, dynamic> message) async {
    print("onLaunch: $message");
    Navigator.push(
        context,
        MaterialPageRoute(
            builder: (context) => DetailOrder()));
  },
  onResume: (Map<String, dynamic> message) async {
    print("onResume: $message");
    Navigator.push(
        context,
        MaterialPageRoute(
            builder: (context) => DetailOrder()));
  },
);
Run Code Online (Sandbox Code Playgroud)

小智 8

您可以尝试使用命名路由 + 全局导航键,它在稍微不同的情况下对我有用。
首先设置一个全局导航键,如下所示:

...
class MyApp extends StatelessWidget {
  static final navigatorKey = GlobalKey<NavigatorState>();
  ...
Run Code Online (Sandbox Code Playgroud)

然后在下面定义命名的路由管理器:

...
Route routes(RouteSettings settings) {
  if (settings.name == "/") {
    return MaterialPageRoute(
      builder: (_) => HomePage(),
    );
  } else if (settings.name.startsWith("/details/")) {
    try {
      String id = settings.name.split("/")[2];
      return MaterialPageRoute(
        builder: (_) => DetailPage(id),
      );
    } catch (e) {
      return MaterialPageRoute(
        builder: (_) => HomePage(),
      );
    }
  } else {
    return MaterialPageRoute(
      builder: (_) => HomePage(),
    );
  }
}
...
Run Code Online (Sandbox Code Playgroud)

并将 navigatorKey 和路由添加到 MaterialApp:

...
@override
Widget build(BuildContext context) {
  return MaterialApp(
    initialRoute: "/",
    onGenerateRoute: routes,
    title: 'MyApp',
    navigatorKey: navigatorKey,
    theme: ThemeData(
      primarySwatch: Colors.blue,
    ),
    home: HomePage(),
  );
}
...
Run Code Online (Sandbox Code Playgroud)

设置完所有这些后,您可以使用导航键在主页和详细信息之间导航,如下所示:

MyApp.navigatorKey.currentState.pushNamed("/"); // to navigate to HomePage
MyApp.navigatorKey.currentState.pushNamed("/details/1"); // to navigate to DetailPage
Run Code Online (Sandbox Code Playgroud)

希望它有效,祝你好运!