Flutter 学习之旅 之 flutter 不使用插件,实现简单带加载动画的 LoadingToast 功能

Flutter 学习之旅 之 flutter 不使用插件,实现简单带加载动画的 LoadingToast 功能

目录

Flutter 学习之旅 之 flutter 不使用插件,实现简单带加载动画的 LoadingToast 功能

一、简单介绍

二、LoadingToast

三、简单案例实现

四、关键代码


一、简单介绍

Flutter 是一款开源的 UI 软件开发工具包,由 Google 开发和维护。它允许开发者使用一套代码同时构建跨平台的应用程序,包括移动设备(iOS 和 Android)、Web 和桌面平台(Windows、macOS 和 Linux)。

Flutter 使用 Dart 编程语言,它可以将代码编译为 ARM 或 Intel 机器代码以及 JavaScript,从而实现快速的性能。Flutter 提供了一个丰富的预置小部件库,开发者可以根据自己的需求灵活地控制每个像素,从而创建自定义的、适应性强的设计,这些设计在任何屏幕上都能呈现出色的外观和感觉。

二、LoadingToast

LoadingToast 是一种用户界面元素,通常用于移动和桌面应用程序中,以向用户显示一个过程正在进行中,比如数据加载或后台任务处理。在Flutter框架中,LoadingToast可以通过一个浮动的图形用户界面(GUI)元素实现,这个元素通常包含一个旋转的加载图标和/或相应的文字提示,如“正在加载”或“请稍候”。

LoadingToast的设计目的是提高用户体验,通过提供即时的视觉反馈来告知用户应用程序没有冻结或停止响应,而是在后台进行操作。这种提示有助于减少用户的焦虑感,并增强对应用程序的信任感。在Flutter中实现LoadingToast,可以通过Overlay或其他类似的机制来创建一个覆盖在应用主界面上的浮动提示框。

在使用LoadingToast进行开发时,应注意以下几个关键事项以确保最佳用户体验和代码的健壮性:

  1. 全局访问:确保LoadingToast的显示和隐藏方法可以在应用的任何地方被调用。这通常通过使用GlobalKey和静态方法实现。

  2. 性能考虑:由于LoadingToast是一个覆盖在应用主界面上的浮动元素,频繁地显示和隐藏可能会影响应用性能。应优化其显示逻辑,避免不必要的渲染。

  3. 用户体验LoadingToast应仅在必要时显示,以避免干扰用户操作或分散用户注意力。同时,应提供清晰的信息,让用户了解当前正在进行的操作。

  4. 可访问性:考虑到不同用户的需求,LoadingToast应包含适当的文本描述,以支持屏幕阅读器等辅助技术。

  5. 多任务处理:在多任务或长时间运行的操作中,应确保LoadingToast能够正确地显示和更新,以反映操作的进度或状态。

  6. 错误处理:在操作失败或出现错误时,应提供一种机制来更新LoadingToast的内容或隐藏它,并给出相应的错误信息。

  7. 样式一致性LoadingToast的样式应与应用的整体设计和风格保持一致,以提供统一的用户体验。

  8. 测试:在开发过程中,应充分测试LoadingToast在不同场景下的行为,包括快速连续触发显示和隐藏的情况。

  9. 资源管理:确保在LoadingToast不再需要时正确地移除和清理资源,避免内存泄漏。

  10. 自定义:根据应用的具体需求,可能需要对LoadingToast进行自定义,如调整位置、大小、颜色等,以适应不同的用户界面布局。

通过注意这些事项,可以确保LoadingToast不仅能够有效地传达信息,还能增强应用的整体质量和用户满意度。

这个案例的实现过程主要涉及创建一个自定义的加载提示,它可以在Flutter应用中以悬浮窗的形式显示。以下是实现过程的简单介绍:

  1. 定义LoadingToast

    • 创建一个名为LoadingToast的类,用于封装加载提示的显示和隐藏逻辑。

  2. 使用OverlayEntry

    • LoadingToast类中定义一个静态的OverlayEntry?类型的变量_overlayEntry,用于存储创建的悬浮窗实例,以便之后可以移除它。

  3. 创建navigatorKey

    • 定义一个静态的GlobalKey<NavigatorState>类型的变量navigatorKey,用于访问应用的Navigator,从而获取到Overlay

  4. 实现show方法

    • LoadingToast类中实现一个静态的show方法,该方法接受一个BuildContext和一个String类型的message作为参数。

    • show方法中,首先获取OverlayState,如果为空,则打印错误信息并返回。

    • 创建一个新的OverlayEntry实例,其builder属性返回一个Material widget,该widget包含一个透明的背景和一个居中的Center widget。

    • Center widget中包含另一个Material widget,用于显示加载提示的背景和内容,如加载图标和文本信息。

    • 将创建的OverlayEntry实例插入到Overlay中,以显示加载提示。

  5. 实现remove方法

    • LoadingToast类中实现一个静态的remove方法,用于移除显示的加载提示。

    • 如果_overlayEntry不为空,则调用其remove方法移除悬浮窗,并将其设置为null。

  6. main函数中使用LoadingToast

    • main函数中创建并运行MyApp应用。

    • MyAppbuild方法中,使用MaterialApp并设置navigatorKey

    • Scaffoldbody中添加一个ElevatedButton,当按钮被点击时,调用LoadingToast.show方法显示加载提示,并在3秒后调用LoadingToast.remove方法隐藏提示。

通过以上步骤,我们实现了一个可以在Flutter应用中显示和隐藏的自定义加载提示Toast组件。这个组件可以用于在执行长时间操作时向用户显示加载状态,提高用户体验。

三、简单案例实现

1、这里使用 Android Studio 进行创建 Flutter 项目

2、创建一个 application 的 Flutter 项目

3、初次的项目结构如下

4、编写一个 LoadingToast 逻辑,实现 show 调用

5、在 main 中调用Loading 功能

6、连接设备,运行效果如下

四、关键代码

1、LoadingToast

import 'package:flutter/material.dart';class LoadingToast {// 定义一个静态的OverlayEntry?类型的变量,用于存储Toast的OverlayEntry实例,以便后续可以移除它static OverlayEntry? _overlayEntry;// 定义一个静态的GlobalKey,用于访问NavigatorState,进而获取Overlaystatic final GlobalKey<NavigatorState> navigatorKey = GlobalKey<NavigatorState>();/// 显示加载提示Toast的静态方法static void show(BuildContext context, String message) {// 获取当前NavigatorState的OverlayStatefinal OverlayState? overlayState = navigatorKey.currentState?.overlay;// 如果overlayState为空,则打印错误信息并返回if (overlayState == null) {print("[LoadingToast] show : OverlayState is null. Make sure to use MaterialApp with navigatorKey.");return;}// 创建一个新的OverlayEntry实例_overlayEntry = OverlayEntry(builder: (context) {// 返回一个Material widget,设置颜色为透明,作为Toast的背景return Material(color: Colors.transparent,// 设置Material的子widget为Center,用于居中显示Toastchild: Center(child: Material(// 设置Toast背景颜色为半透明黑色color: Colors.black.withOpacity(0.8),// 设置Toast背景的圆角shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10.0),),// 设置Material的子widget为Padding,用于添加内边距child: Padding(padding: const EdgeInsets.all(16.0), // 设置内边距大小child: Column(mainAxisSize: MainAxisSize.min, // 设置Column的主轴尺寸为最小children: <Widget>[// 添加一个CircularProgressIndicator作为加载提示CircularProgressIndicator(strokeWidth: 2,// 设置加载提示的颜色为白色valueColor: AlwaysStoppedAnimation<Color>(Colors.white),),SizedBox(height: 8), // 设置加载提示和文本之间的间距// 添加一个Text widget作为Toast的消息文本Text(message,style: TextStyle(color: Colors.white, // 设置文本颜色为白色fontSize: 16, // 设置文本字体大小),),],),),),),);},);// 将OverlayEntry实例插入到Overlay中,以显示ToastoverlayState.insert(_overlayEntry!);}/// 移除加载提示Toast的静态方法static void remove() {// 如果存在_overlayEntry实例,则移除它并将其设置为nullif (_overlayEntry != null) {_overlayEntry!.remove();_overlayEntry = null;}}
}

这段代码定义了一个名为LoadingToast的类,该类提供了两个静态方法:showremoveshow方法用于显示一个加载提示Toast,而remove方法用于移除该Toast。Toast的显示是通过创建一个OverlayEntry实例并将其插入到Overlay中实现的。Toast的移除是通过调用OverlayEntryremove方法实现的。

2、main

import 'package:flutter/material.dart';
// 引入自定义的LoadingToast类,该类负责显示和隐藏加载提示Toast
import 'package:test_loading_toast/loading_toast.dart';void main() {// 运行Flutter应用程序runApp(MyApp());
}// 定义应用程序的根组件MyApp
class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {// 返回MaterialApp组件,它是Flutter应用程序的主要入口点return MaterialApp(// 设置navigatorKey,这是为了确保LoadingToast类能够访问到OverlaynavigatorKey: LoadingToast.navigatorKey,// 设置MaterialApp的主页为Scaffold组件home: Scaffold(// 设置Scaffold的AppBar,其中包含一个标题appBar: AppBar(title: Text('Loading Toast Example'),),// 设置Scaffold的主体为Center组件,其中包含一个Columnbody: Center(// 设置Column的mainAxisAlignment属性为MainAxisAlignment.center,使其子组件垂直居中child: Column(mainAxisAlignment: MainAxisAlignment.center,// 设置Column的子组件为一个ElevatedButtonchildren: <Widget>[ElevatedButton(// 设置按钮的点击事件处理函数onPressed: () {// 调用LoadingToast的show方法显示加载提示ToastLoadingToast.show(context, '正在加载');// 使用Future.delayed模拟异步操作,并在3秒后调用LoadingToast的remove方法隐藏ToastFuture.delayed(Duration(seconds: 3)).then((_) {LoadingToast.remove();});},// 设置按钮的子组件为Text,显示按钮的文本child: Text('Show Loading Toast'),),],),),),);}
}

这段代码定义了一个简单的Flutter应用程序,其中包含一个按钮。当按钮被点击时,它将显示一个加载提示Toast,并在3秒后自动隐藏。LoadingToast类负责管理Toast的显示和隐藏,它通过操作Overlay来实现Toast的显示效果。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

289. 生命游戏

根据 百度百科 &#xff0c; 生命游戏 &#xff0c;简称为 生命 &#xff0c;是英国数学家约翰何顿康威在 1970 年发明的细胞自动机。 给定一个包含 m n 个格子的面板&#xff0c;每一个格子都可以看成是一个细胞。每个细胞都具有一个初始状态&#xff1a; 1 即为 活细胞 &am…

滑动窗口及边缘化直观理解

文章目录 问题例子example求解思路边缘化边缘化原理边缘化的实际步骤marg先验约束公式先验约束公式1先验约束公式2 marg的问题及FEJ实例分析&#xff1a;VINS-Mono中的滑动窗口策略 边缘化的代码实现&#xff08;伪代码&#xff09; 参考 本文简要介绍VIO常用的滑动窗口及边缘化…

类和对象(下)

一.再谈构造函数 构造函数有构造函数体赋值实现和初始化列表两种方式 1.构造函数体赋值 在创建对象时&#xff0c;编译器通过调用构造函数&#xff0c;给对象中各个成员变量一个合适的初始值. 虽然上述构造函数调用之后&#xff0c;对象中已经有了一个初始值&#xff0c;但是…

在资源有限中逆势突围:从抗战智谋到寒门高考的破局智慧

目录 引言 一、历史中的非对称作战&#xff1a;从李牧到八路军的智谋传承 李牧戍边&#xff1a;古代军事博弈中的资源重构 八路军的游击战&#xff1a;现代战争中的智慧延续 二、创业界的逆袭之道&#xff1a;小米与拼多多的资源重构 从MVP到杠杆解 社交裂变与资源错配 …

eLection: 1靶场渗透测试

eLection: 1 来自 <eLection: 1 ~ VulnHub> 1&#xff0c;将两台虚拟机网络连接都改为NAT模式 2&#xff0c;攻击机上做namp局域网扫描发现靶机 nmap -sn 192.168.23.0/24 那么攻击机IP为192.168.23.182&#xff0c;靶场IP192.168.23.196 3&#xff0c;对靶机进行端口服…

RuleOS:区块链开发的“新引擎”,点燃Web3创新之火

RuleOS&#xff1a;区块链开发的“新引擎”&#xff0c;点燃Web3创新之火 在区块链技术的浪潮中&#xff0c;RuleOS宛如一台强劲的“新引擎”&#xff0c;为个人和企业开发去中心化应用&#xff08;DApp&#xff09;注入了前所未有的动力。它以独特的设计理念和强大的功能特性&…

【MySQL篇】MySQL基本查询详解

目录 前言&#xff1a; 1&#xff0c;Create 1.1&#xff0c;单行数据全列插入 1.2&#xff0c;单行数据指定列插入 1.3&#xff0c;多行数据全列插入 1.4&#xff0c;多行数据指定列插入 1.5&#xff0c;插入否则更新 1.6&#xff0c;替换 2&#xff0c;Retrieve …

第十七:go 反射

fmt.printf("%T"&#xff0c;obj) // 打印 reflect 的类型 fmt.Printf("%T", obj) // *reflect.rtype //打印的是一个指针类型 reflect包 在Go语言中反射的相关功能由内置的reflect包提供&#xff0c;任意接口值在反射中都可以理解为由reflect.Type和…

热门的壁纸创作风格呈现多元化发展趋势

下热门的壁纸创作风格呈现多元化发展趋势&#xff0c;以下是几种主流风格及其特点&#xff1a; 简约现代风格 流行元素&#xff1a;以简洁的线条、纯净的色彩块面和少量的抽象图形为主。摒弃过多繁杂的装饰&#xff0c;强调形式追随功能的设计理念。热度分析&#xff1a;在各大…

【SpringMVC】深入解析使用 Postman 在请求中传递对象类型、数组类型、参数类型的参数方法和后端参数重命名、及非必传参数设置的方法

SpringMVC—请求传参 1. 传递对象 如果参数比较多时&#xff0c;方法声明就需要有很多形参&#xff1b;并且后续每次新增一个参数&#xff0c;也需要修改方法声明. 我们不妨把这些参数封装为一个对象&#xff1b; Spring MVC 也可以自动实现对象参数的赋值&#xff0c;比如 Us…

AI智能眼镜的视觉革命:算法如何重塑人机交互新纪元

引言&#xff1a;视觉算法的核心地位与AI智能眼镜的崛起 AI智能眼镜作为下一代交互终端&#xff0c;其核心价值在于将视觉感知与人工智能深度融合&#xff0c;通过实时环境解析与动态反馈&#xff0c;重新定义人机交互的边界。据预测&#xff0c;2025年全球AI智能眼镜销量将突…

掌握 ArcGIS Pro:古地图制作技巧与方法

在探索历史的长河中&#xff0c;古地图以其独特的魅力承载着丰富的地理信息和历史文化价值。 随着技术的进步&#xff0c;现代地理信息系统&#xff08;GIS&#xff09;如ArcGIS Pro为我们提供了强大的工具&#xff0c;使制作古地图成为可能。 本文将详细介绍如何使用ArcGIS …

MySQL的安装及配置

一.以安装包方式下载 1.进入MySQL官网&#xff0c;下载安装包 官网链接&#xff1a;https://downloads.mysql.com/archives/installer/ 2.安装MySQL 二.压缩包方式下载 下载位置&#xff1a;mysql下载位置 解压缩后位置&#xff1a;D:\mysql-8.0.15-winx64 在主目录下复制…

Python实例:PyMuPDF实现PDF翻译,英文翻译为中文,并按段落创建中文PDF

基于PyMuPDF与百度翻译的PDF翻译处理系统开发:中文乱码解决方案与自动化排版实践 一 、功能预览:将英文翻译为中文后创建的PDF 二、完整代码 from reportlab.lib.pagesizes import letter from reportlab.lib.styles import getSampleStyleSheet, ParagraphStyle

『VUE』vue 引入Font Awesome图标库(详细图文注释)

目录 Font Awesome介绍安装引入npm 安装导入src/main.js 使用总结 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 欢迎关注 『VUE』 专栏&#xff0c;持续更新中 Font Awesome介绍 我一般是中文网搜索找到图标的英文名然后去官方网站搜索 官方网站(英文名搜索) https://font…

0基础 | 看懂原理图Datasheet 系列1

原理图功能分类 控制部分&#xff1a;整个电路板的核心控制和计算部分&#xff08;CPU&#xff09; CPU最小系统是什么?电源时钟复位 接口部分&#xff1a;实现特定功能的部分 如Wife模块、通讯接口 电源部分&#xff1a;整个电路板的供电部分 任何电路板都是必要的&…

python-leetcode-删掉一个元素以后全为 1 的最长子数组

1493. 删掉一个元素以后全为 1 的最长子数组 - 力扣(LeetCode) 可以使用滑动窗口的方式来解决这个问题。我们要找到最长的全 1 子数组,但必须删除一个元素,因此可以将问题转化为寻找最多包含一个 0 的最长子数组。 解题思路 使用双指针(滑动窗口),维护窗口内最多包含一…

ubuntu挂载新硬盘

在准备数据的时候出现空间不够的问题&#xff1a; 添加200G的空间&#xff0c;挂在到/home/vipuser/BEV_Depth/BEVDepth/data/nuScenes 使用lsblk查看挂载的盘 有两块硬盘 vda 和 vdb&#xff0c;其中 vda 已经用于系统安装&#xff0c;vdb 尚未分区和挂载。 1. **分区新磁盘…

Java 生成图形验证码

一、图形验证码的意义 图形验证码是一种广泛应用于互联网领域的安全验证机制&#xff0c;它通过向用户展示包含字符、数字、图形等信息的图片&#xff0c;要求用户正确识别并输入其中的内容&#xff0c;以此来区分用户是人类还是机器程序。图形验证码具有多方面重要意义&#…

Qwen/QwQ-32B 基础模型上构建agent实现ppt自动生成

关心Qwen/QwQ-32B 性能测试结果可以参考下 https://zhuanlan.zhihu.com/p/28600079208https://zhuanlan.zhihu.com/p/28600079208 官方宣传上是该模型性能比肩满血版 DeepSeek-R1&#xff08;671B&#xff09;&#xff01; 我们实现一个 使用Qwen/QwQ-32B 自动生成 PowerPoi…