掌握 Flutter 中的 `Overlay` 和 `OverlayEntry`:弹窗管理的艺术

news2024/9/21 2:31:38

掌握 Flutter 中的 OverlayOverlayEntry:弹窗管理的艺术

在 Flutter 应用开发中,弹窗是一种常见的用户交互方式,用于显示警告、提示或额外信息。为了确保这些弹窗能够按预期显示,并且能够在需要时覆盖其他弹窗,我们需要精细地控制它们的层级和显示顺序。本文将介绍如何使用 Flutter 的 OverlayOverlayEntry 来管理弹窗,确保它们始终显示在最上层。

弹窗管理工具类:DialogManager

为了更好地管理弹窗的显示和隐藏,我们可以创建一个名为 DialogManager 的工具类。这个类将负责创建和管理 OverlayEntry,确保弹窗能够正确地显示在应用的最上层。

创建 DialogManager

import 'package:flutter/material.dart';

class DialogManager {
  static OverlayEntry? _overlayEntry;

  static Future<void> showVersionUpdateDialog({
    required BuildContext context,
    required VersionUpdateShowModel versionUpdateShowModel,
  }) {
    // 移除已存在的弹窗
    _overlayEntry?.remove();
    _overlayEntry = _createOverlayEntry(context, versionUpdateShowModel);
    Overlay.of(context)?.insert(_overlayEntry!);
    return Future.value();
  }

  static OverlayEntry _createOverlayEntry(
      BuildContext context, VersionUpdateShowModel versionUpdateShowModel) {
    return OverlayEntry(
      builder: (context) => GestureDetector(
        onTap: () {
          if (!versionUpdateShowModel.isForceUpdate) {
            _overlayEntry?.remove();
            _overlayEntry = null;
          }
        },
        child: Dialog(
          backgroundColor: Colors.transparent,
          child: PopScope(
            canPop: !versionUpdateShowModel.isForceUpdate,
            child: ShowVersionUpdatePage(
              updateVersion: versionUpdateShowModel.updateVersion,
              updateContentList: versionUpdateShowModel.updateContentList,
              enableClose: !versionUpdateShowModel.isForceUpdate,
            ),
          ),
        ),
      ),
    );
  }

  static void dismiss() {
    _overlayEntry?.remove();
    _overlayEntry = null;
  }
}

定义 ShowVersionUpdatePage 组件

为了使弹窗内容可重用,我们可以将 ShowVersionUpdatePage 定义为一个独立的组件。

import 'package:flutter/material.dart';

class ShowVersionUpdatePage extends StatelessWidget {
  final String updateVersion;
  final List<String> updateContentList;
  final bool enableClose;

  const ShowVersionUpdatePage({
    Key? key,
    required this.updateVersion,
    required this.updateContentList,
    this.enableClose = true,
  }) : super(key: key);

  
  Widget build(BuildContext context) {
    return Container(
      padding: EdgeInsets.all(16),
      decoration: BoxDecoration(
        color: Colors.white,
        borderRadius: BorderRadius.circular(8),
      ),
      child: Column(
        mainAxisSize: MainAxisSize.min,
        children: [
          Text('更新版本 $updateVersion', style: Theme.of(context).textTheme.headline6),
          ...updateContentList.map((content) => Padding(
                padding: const EdgeInsets.symmetric(vertical: 8.0),
                child: Text(content),
              )),
          if (!enableClose)
            TextButton(
              child: Text('更新'),
              onPressed: () {
                Navigator.of(context).pop();
                // 处理更新逻辑
              },
            ),
        ],
      ),
    );
  }
}

使用 DialogManager 显示弹窗

在需要显示弹窗的地方,调用 DialogManagershowVersionUpdateDialog 方法。

import 'package:flutter/material.dart';
import 'dialog_manager.dart';

class YourWidget extends StatelessWidget {
  final VersionUpdateShowModel versionUpdateShowModel = VersionUpdateShowModel();

  void _showDialog() {
    DialogManager.showVersionUpdateDialog(
      context: Get.context!,
      versionUpdateShowModel: versionUpdateShowModel,
    );
  }

  
  Widget build(BuildContext context) {
    return ElevatedButton(
      onPressed: _showDialog,
      child: Text('显示版本更新弹窗'),
    );
  }
}

确保弹窗在最上层

通过在显示新弹窗之前移除已有的 OverlayEntry,我们可以确保弹窗始终显示在最上层。

总结

通过使用 OverlayOverlayEntry,我们可以更精细地控制弹窗的显示和层级,确保它们能够覆盖其他弹窗。DialogManager 类提供了一个可重用的方式来管理弹窗的显示和隐藏,使得在多个地方调用和控制弹窗变得轻松而高效。这种方法不仅提高了代码的可维护性,也提升了用户体验。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2150876.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

攻防世界--->gametime

做题笔记。 前言&#xff1a; 因为有意思&#xff0c;所以&#xff0c;&#xff0c;&#xff0c;打通关了。。哈哈哈。 题外话&#xff1a;哦&#xff0c;程序结果还在&#xff0c;是因为我是在WSL—Debian上运行的。你还别说&#xff0c;真挺好用的&#xff0c;vm虚拟机能不…

Node-RED和物联网分析:实时数据处理和可视化平台

这篇论文的标题是《Node-RED and IoT Analytics: A Real-Time Data Processing and Visualization Platform》&#xff0c;发表在《Tech-Sphere Journal of Pure and Applied Sciences (TSJPAS)》2024年第一期上。论文主要探讨了Node-RED和物联网分析在物联网(IoT)实时数据处理…

列表、数组排序总结:Collections.sort()、list.sort()、list.stream().sorted()、Arrays.sort()

列表类型 一.Collections.sort() Collections.sort()用于List类型的排序&#xff0c;其提供了两个重载方法&#xff1a; 1.sort(List<T> list) &#xff08;1&#xff09;List指定泛型时只能指定引用数据类型&#xff0c;也就是说无法用于基本数据类型的排序。 &am…

9.20作业

手动封装一个顺序表&#xff08;SeqList&#xff09;,分文件编译实现 有私有成员&#xff1a; 顺序表数组的起始地址 ptr、 顺序表的总长度&#xff1a;size、顺序表的实际长度&#xff1a;len 成员函数&#xff1a; 初始化 init(int n) 判空&#xff1a;empty 判满&#xff1…

Rust语言入门第七篇-控制流

文章目录 Rust语言入门第七篇-控制流If 表达式基本结构特点和规则示例 let 语句中使用 ifloop 循环基本结构特点示例综合示例 while 循环基本结构特点示例综合示例 与 loop 循环的区别 for 循环基本结构详细说明特点示例综合示例 match 表达式match表达式的语法结构示例代码 Ru…

Mysql存储过程详细解读

目录 存储过程介绍 创建与调用 查看与删除 变量 系统变量 用户自定义变量 ​编辑局部变量 ​编辑​编辑IF判断 存储过程参数​编辑​编辑​编辑 CASE ​编辑 WHILE​编辑 ​编辑REPEAT​编辑​编辑 LOOP 游标 条件处理程序 存储函数 存储过程介绍 创建与调用 查…

GNN-RAG:用于大模型推理的图神经检索

GNN-RAG&#xff1a;用于大模型推理的图神经检索 秒懂大纲提出背景解法拆解全流程优化创意总结 论文&#xff1a;GNN-RAG: Graph Neural Retrieval for Large Language Model Reasoning 代码&#xff1a;https://github.com/cmavro/GNN-RAG 秒懂大纲 ├── GNN-RAG【主题】…

【刷题日记】43. 字符串相乘

43. 字符串相乘 其实就是大数乘法题&#xff0c;这道题用草稿纸演练一下&#xff0c;其实很好找到方法&#xff0c;模拟大数乘法即可。需要注意的是进位和迭代值&#xff0c;还有注意向下取整和去除前导0&#xff08;容易遗漏&#xff09;。去除前导0的时候还要注意如果全是0&…

命令行运行python时找不到模块怎么解决

问题&#xff1a; 新建了一个项目&#xff0c;目录结构如下&#xff1a; 然后在pycharm中运行glovar是没有问题的&#xff0c;但是在命令行中运行就会提示找不到init模块。 这是因为在pycharm中运行的时候&#xff0c;pycharm会自动将项目所在目录添加到了sys.path中&#xf…

天宝Trimble RealWorks2024.0.2注册机 点云后处理软件 点云三维重建软件

一、功能特色 1、强大的点云数据处理平台 Trimble Realworks2024是市面上先进的点云数据处理软件&#xff0c;能够配准、可视化、浏览和直接处理市面上几乎所有主流品牌扫描仪点云数据&#xff0c;包括Leica、Riegl、ZF、Faro、Topcon等。 2、业界领先的无目标全自动配准 T…

Apache Flink 流批融合技术介绍

摘要&#xff1a;本文整理自阿里云高级研发工程师、Apache Flink Contributor 周云峰老师在 Apache Asia CommunityOverCode 2024中的分享。内容主要分为以下三个部分&#xff1a; 从流批一体到流批融合流批融合的技术解决方案社区进展及未来展望 一、从流批一体到流批融合 1&…

记忆化搜索专题——算法简介力扣实战应用

目录 1、记忆化搜索算法简介 1.1 什么是记忆化搜索 1.2 如何实现记忆化搜索 1.3 记忆化搜索与动态规划的区别 2、算法应用【leetcode】 2.1 题一&#xff1a;斐波那契数 2.1.1 递归暴搜解法代码 2.1.2 记忆化搜索解法代码 2.1.3 动态规划解法代码 2.2 题二&#xff1…

网络模型的保存与读取

文章目录 一、模型的保存二、文件的加载三、模型加载时容易犯的陷阱 一、模型的保存 方式1:torch.save(vgg16, “vgg16_method1.pth”) import torch import torchvision.modelsvgg16 torchvision.models.vgg16(pretrainedFalse) torch.save(vgg16, "vgg16_method1.pth…

oracle数据库启动

文章目录 背景一、步骤1.登录oracle用户2.启动监听服务3.启动数据库 背景 oracle数据库启动 一、步骤 1.登录oracle用户 代码如下&#xff08;示例&#xff09;&#xff1a; su - oracle2.启动监听服务 代码如下&#xff08;示例&#xff09;&#xff1a; lsnrctl start成…

【C++】STL----vector常见用法

&#x1f525;个人主页&#x1f525;&#xff1a;孤寂大仙V &#x1f308;收录专栏&#x1f308;&#xff1a;C从小白到高手 &#x1f339;往期回顾&#x1f339;&#xff1a;[C]string类 &#x1f516; 流水不争&#xff0c;争的是滔滔不息。 文章目录 一、vector的介绍vector…

MATLAB绘图基础8:双变量图形绘制

参考书&#xff1a;《 M A T L A B {\rm MATLAB} MATLAB与学术图表绘制》(关东升)。 8.双变量图形绘制 8.1 散点图 散点图用于显示两个变量间的关系&#xff0c;每个数据点在图上表示为一个点&#xff0c;一个变量在 X {\rm X} X轴&#xff0c;一个变量在 Y {\rm Y} Y轴&#…

【Python报错已解决】AttributeError: ‘DataFrame‘ object has no attribute ‘append‘

&#x1f3ac; 鸽芷咕&#xff1a;个人主页 &#x1f525; 个人专栏: 《C干货基地》《粉丝福利》 ⛺️生活的理想&#xff0c;就是为了理想的生活! 专栏介绍 在软件开发和日常使用中&#xff0c;BUG是不可避免的。本专栏致力于为广大开发者和技术爱好者提供一个关于BUG解决的经…

暴雨信息|《2024 年全球人工智能趋势报告》发布,GPU仍是AI发展最大关键之一

全球著名调研机构WEKA近日正式发布《2024年全球人工智能趋势报告》&#xff0c;该报告是基于全球1500人工智能决策者的深度调查&#xff0c;覆盖金融、政府、医疗保健等多个行业&#xff0c;解锁了人工智能领域的关键见解和策略。 人工智能正成为许多组织战略的一个基本面&…

滑动窗口(8)_最小覆盖字串

个人主页&#xff1a;C忠实粉丝 欢迎 点赞&#x1f44d; 收藏✨ 留言✉ 加关注&#x1f493;本文由 C忠实粉丝 原创 滑动窗口(8)_最小覆盖字串 收录于专栏【经典算法练习】 本专栏旨在分享学习算法的一点学习笔记&#xff0c;欢迎大家在评论区交流讨论&#x1f48c; 目录 1. 题…

6.C++程序中的基本数据类型

数据类型是指在C中用于声明不同类型变量或函数的一个系统或抽象或者是一个分类&#xff0c;它决定了变量存储占用的内存空间以及解析存储的位模式。其实数据类型可以理解为固定内存大小的别名&#xff0c;是创建变量的模具&#xff0c;具体使用哪种模具&#xff08;包括自定义&…