如何在颤动的任何屏幕上显示弹出消息?

Posted

技术标签:

【中文标题】如何在颤动的任何屏幕上显示弹出消息?【英文标题】:How to display pop up message in any screen in flutter? 【发布时间】:2021-08-17 07:49:48 【问题描述】:

我需要在任何屏幕上显示一个带有消息的弹出窗口。它可以是教程/介绍屏幕、登录或主屏幕。基本上,弹出窗口会指示该应用程序是否有新的可下载版本。现在这没有任何条件。所以我应该能够在每次启动应用程序时向用户显示弹出消息。

同样是通过在 ios 中的 didFinishLaunchingWithOptions 中添加弹出消息来实现的。我如何在颤振中做同样的事情?

【问题讨论】:

【参考方案1】:

弹出消息是通过flutter AlertDialog 小部件实现的。因此,如果您想在每次应用启动时提醒用户,您应该在应用启动的第一个屏幕中显示此小部件。这是文档中的一个示例:

// Flutter code sample for AlertDialog
//
// This demo shows a [TextButton] which when pressed, calls [showDialog]. When called, this method
// displays a Material dialog above the current contents of the app and returns
// a [Future] that completes when the dialog is dismissed.

import 'package:flutter/material.dart';

void main() => runApp(const MyApp());

/// This is the main application widget.
class MyApp extends StatelessWidget 
  const MyApp(Key? key) : super(key: key);

  static const String _title = 'Flutter Code Sample';

  @override
  Widget build(BuildContext context) 
    return MaterialApp(
      title: _title,
      home: Scaffold(
        appBar: AppBar(title: const Text(_title)),
        body: const Center(
          child: MyStatelessWidget(),
        ),
      ),
    );
  


/// This is the stateless widget that the main application instantiates.
class MyStatelessWidget extends StatelessWidget 
  const MyStatelessWidget(Key? key) : super(key: key);

  @override
  Widget build(BuildContext context) 
    return TextButton(
      onPressed: () => showDialog<String>(
        context: context,
        builder: (BuildContext context) => AlertDialog(
          title: const Text('AlertDialog Title'),
          content: const Text('AlertDialog description'),
          actions: <Widget>[
            TextButton(
              onPressed: () => Navigator.pop(context, 'Cancel'),
              child: const Text('Cancel'),
            ),
            TextButton(
              onPressed: () => Navigator.pop(context, 'OK'),
              child: const Text('OK'),
            ),
          ],
        ),
      ),
      child: const Text('Show Dialog'),
    );
  

更多信息请访问here

【讨论】:

感谢您的回答!但我想在任何地方显示登录/注册/主屏幕中的弹出窗口......我的意思是当应用程序在不同条件下启动时用户获得的屏幕......您共享的代码需要一个上下文。我应该从每个屏幕上调用它吗?在 iOS 中它非常简单...... 检查这里***.com/questions/44740617/…或这里***.com/questions/59162178/…

以上是关于如何在颤动的任何屏幕上显示弹出消息?的主要内容,如果未能解决你的问题,请参考以下文章

如何在颤动的屏幕上显示一个小部件?

如何在颤动中创建无限网格?

如何在颤动中允许浮动通知和锁定屏幕通知编程

安装时颤动显示消息[重复]

如何确保我在颤动中的图像 url 不会显示在屏幕上而不是图像上?

如何在颤动的两个不同屏幕上使用相同的块?