建设一个网站需要什么/凡科建站教程

建设一个网站需要什么,凡科建站教程,马云为啥说2025年房价如葱,如何做网站霸屏Flutter 学习之旅 之 flutter 不使用插件,实现简单带加载动画的 LoadingToast 功能 目录 Flutter 学习之旅 之 flutter 不使用插件,实现简单带加载动画的 LoadingToast 功能 一、简单介绍 二、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.mzph.cn/bicheng/73118.shtml

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

相关文章

Spring (八)AOP-切面编程的使用

目录 实现步骤&#xff1a; 1 导入AOP依赖 2 编写切面Aspect 3 编写通知方法 4 指定切入点表达式 5 测试AOP动态织入 图示&#xff1a; 一 实现步骤&#xff1a; 1 导入AOP依赖 <!-- Spring Boot AOP依赖 --><dependency><groupId>org.springframewor…

开源数字人模型Heygem

一、Heygem是什么 Heygem 是硅基智能推出的开源数字人模型&#xff0c;专为 Windows 系统设计。基于先进的AI技术&#xff0c;仅需1秒视频或1张照片&#xff0c;能在30秒内完成数字人形象和声音克隆&#xff0c;在60秒内合成4K超高清视频。Heygem支持多语言输出、多表情动作&a…

神经网络为什么要用 ReLU 增加非线性?

在神经网络中使用 ReLU&#xff08;Rectified Linear Unit&#xff09; 作为激活函数的主要目的是引入非线性&#xff0c;这是神经网络能够学习复杂模式和解决非线性问题的关键。 1. 为什么需要非线性&#xff1f; 1.1 线性模型的局限性 如果神经网络只使用线性激活函数&…

使用SSH密钥连接本地git 和 github

目录 配置本地SSH&#xff0c;添加到github首先查看本地是否有SSH密钥生成SSH密钥&#xff0c;和邮箱绑定将 SSH 密钥添加到 ssh-agent&#xff1a;显示本地公钥*把下面这一串生成的公钥存到github上* 验证SSH配置是否成功终端跳转到本地仓库把http协议改为SSH&#xff08;如果…

关于AI数据分析可行性的初步评估

一、结论&#xff1a;可在部分环节嵌入&#xff0c;无法直接处理大量数据 1.非本地部署的AI应用处理非机密文件没问题&#xff0c;内部文件要注意数据安全风险。 2.AI&#xff08;指高规格大模型&#xff09;十分适合探索性研究分析&#xff0c;对复杂报告无法全流程执行&…

矩阵分析-浅要理解(深度学习方向)

梯度分析与最优化 在深度学习的任务中&#xff0c;我们所期望的是训练一个神经网络&#xff0c;使得预测结果与真实标签之间的误差最小化&#xff0c;这可以近似看作是一个提供梯度下降等优化找到全局最优解的凸优化问题。 奇异值分解 在信息工程领域&#xff0c;对数据处理的…

使用DeepSeek+蓝耘快速设计网页简易版《我的世界》小游戏

前言&#xff1a;如今&#xff0c;借助先进的人工智能模型与便捷的云平台&#xff0c;即便是新手开发者&#xff0c;也能开启创意游戏的设计之旅。DeepSeek 作为前沿的人工智能模型&#xff0c;具备强大的功能与潜力&#xff0c;而蓝耘智算云平台则为其提供了稳定高效的运行环境…

固定表头、首列 —— uniapp、vue 项目

项目实地&#xff1a;也可以在 【微信小程序】搜索体验&#xff1a;xny.handbook 另一个体验项目&#xff1a;官网 一、效果展示 二、代码展示 &#xff08;1&#xff09;html 部分 <view class"table"><view class"tr"><view class&quo…

每天一道算法题【蓝桥杯】【在排序数组中查找元素的第一个位置和最后一个位置】

思路 本题为查找左边界和右边界的标准模型 查找左边界 int left 0, right nums.size() - 1, mid 0; //查找左边界 while (left < right) { mid left (right - left) / 2; if (nums[mid] < target) left mid 1; else right mid; } 查找右边界 int left 0, r…

Python数据分析之机器学习基础

Python 数据分析重点知识点 本系列不同其他的知识点讲解&#xff0c;力求通过例子让新同学学习用法&#xff0c;帮助老同学快速回忆知识点 可视化系列&#xff1a; Python基础数据分析工具数据处理与分析数据可视化机器学习基础 五、机器学习基础 了解机器学习概念、分类及…

Excel多级联动下拉菜单设置

1.问题描述 现有数据表如下图所示&#xff1a; 该表中包括省、市、县三级目录。 现要将其整理成数据表模板&#xff0c;如下图所示&#xff1a; 要求制作成下拉菜单的形式&#xff0c;且每一级目录的下拉菜单列表要根据上一级目录的内容来确定。 如上图所示&#xff0c;只有…

SpringMVC执行的流程

SpringMVC 基于 MVC 架构模式&#xff0c;核心流程时前端控制室 DispathcherServlet 统一调度&#xff0c;通过组件协作完成 http 的请求与响应。 对于 dispatchServlet 作为前端请求的控制器&#xff0c;全局的访问点&#xff0c;首先将根据 URL 调用 HandlerMapping 获取 Han…

存储过程和自定义函数在银行信贷业务中的应用(oracle)

数据校验和清洗 例如&#xff0c;检查客户的年龄是否在合理范围内&#xff0c;贷款金额是否符合规定的上下限等。 对于不符合规则的数据&#xff0c;可以进行清洗和修正。比如&#xff0c;将空值替换为默认值&#xff0c;或者对错误的数据进行纠正。 CREATE OR REPLACE PROC…

指令微调 (Instruction Tuning) 与 Prompt 工程

引言 预训练语言模型 (PLMs) 在通用语言能力方面展现出强大的潜力。然而&#xff0c;如何有效地引导 PLMs 遵循人类指令&#xff0c; 并输出符合人类意图的响应&#xff0c; 成为释放 PLMs 价值的关键挑战。 指令微调 (Instruction Tuning) 和 Prompt 工程 (Prompt Engineerin…

【c++】反转字符串

说明 将string类型的字符串本身反转 用到库&#xff1a;algorithm 示例代码 #include <iostream> #include <string> #include <algorithm> using namespace std;int main() {string str "123";reverse(str.begin(), str.end());cout <<…

ARMV8的64位指令

一、介绍 ARMv8 体系结构最大的改变是增加了一个新的 64 位的指令集&#xff0c;这是早前 ARM 指令集 的有益补充和增强。它可以处理 64 位宽的寄存器和数据并且使用 64 位的指针来访问内存。这 个新的指令集称为 A64 指令集&#xff0c;运行在 AArch64 状态。 ARMv8 兼容旧的…

线性代数之矩阵特征值与特征向量的数值求解方法

文章目录 前言1. 幂迭代法&#xff08;Power Iteration&#xff09;幂法与反幂法求解矩阵特征值幂法求最大特征值编程实现补充说明 2. 逆幂迭代法&#xff08;Inverse Iteration&#xff09;移位反幂法 3. QR 算法&#xff08;QR Algorithm&#xff09;——稠密矩阵理论推导编程…

VScode:运行程序停止后,频繁出现终端进程被终止

VScode里面powershell被迫关闭 bug场景排查原因解决办法 bug场景 系统&#xff1a;Windows IDE&#xff1a;Visual Studio Code 停止运行程序后&#xff0c;按向上箭头想要执行上一步命令&#xff0c;忽然终端页面强行关闭&#xff0c;并报错如下&#xff1a; 终端进程 &quo…

【菜鸟飞】Conda安装部署与vscode的结合使用

介绍 Conda 是一个跨平台的开源工具&#xff0c;用于管理软件包和环境。最初由 Anaconda 公司开发&#xff0c;它的设计目标是支持数据科学和机器学习领域&#xff0c;但其功能不仅局限于此。 以下是 Conda 的核心特点&#xff1a; 包管理&#xff1a;安装、更新、卸载各种库…

单例模式的五种实现方式

1、饿汉式 ①实现&#xff1a;在类加载的时候就初始化实例 ②优点&#xff1a;线程安全 ③缺点&#xff1a;实例在类加载的时候创建&#xff0c;可能会浪费资源 //饿汉式 public class EagerSingleton{private EagerSingleton(){} //私有构造方法private static EagerSingle…