Flutter鸿蒙next 封装对话框详解
✅近期推荐:求职神器
https://bbs.csdn.net/topics/619384540
🔥欢迎大家订阅系列专栏:flutter_鸿蒙next
💬淼学派语录:只有不断的否认自己和肯定自己,才能走出弯曲不平的泥泞路,因为平坦的大路,太tm无趣了!
写在前面
在 Flutter 中,对话框(Dialog)是非常常用的 UI 组件,可以用来展示信息、确认操作或者输入数据。通过封装自定义对话框,我们可以提升代码的可复用性和可维护性。本文将详细介绍如何在 Flutter 中封装一个对话框,并提供示例代码。
1. 创建 Flutter 项目
首先,确保你已经创建了一个 Flutter 项目。如果还没有,可以通过以下命令创建:
flutter create dialog_example
cd dialog_example
2. 添加依赖
在 pubspec.yaml
文件中添加必要的依赖(如果需要额外的 UI 库,可以在这里添加)。我们以标准 Flutter 组件为例,所以不需要额外依赖。
3. 封装对话框
我们将创建一个简单的自定义对话框类。这个对话框将包含标题、内容和两个按钮(确认和取消)。
3.1 创建 CustomDialog 类
在 lib
目录下创建一个新文件 custom_dialog.dart
,并编写以下代码:
import 'package:flutter/material.dart';class CustomDialog {static Future<void> showDialogBox(BuildContext context, {required String title,required String content,String confirmText = "确认",String cancelText = "取消",required VoidCallback onConfirm,}) {return showDialog<void>(context: context,builder: (BuildContext context) {return AlertDialog(title: Text(title),content: Text(content),actions: <Widget>[TextButton(child: Text(cancelText),onPressed: () {Navigator.of(context).pop();},),TextButton(child: Text(confirmText),onPressed: () {onConfirm();Navigator.of(context).pop();},),],);},);}
}
3.2 代码解析
showDialogBox
方法是一个静态方法,用于显示对话框。- 参数:
context
: 上下文。title
: 对话框标题。content
: 对话框内容。confirmText
和cancelText
: 自定义按钮文本。onConfirm
: 确认按钮的回调函数。
- 使用
AlertDialog
创建对话框,包含标题、内容和操作按钮。
4. 使用自定义对话框
在 lib/main.dart
中,调用我们刚刚封装的对话框。示例代码如下:
import 'package:flutter/material.dart';
import 'custom_dialog.dart'; // 导入自定义对话框void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(title: 'Flutter Dialog Example',home: Scaffold(appBar: AppBar(title: Text('Dialog Example'),),body: Center(child: ElevatedButton(onPressed: () {CustomDialog.showDialogBox(context,title: '确认操作',content: '你确定要执行此操作吗?',onConfirm: () {// 处理确认操作print('操作已确认');},);},child: Text('显示对话框'),),),),);}
}
高级封装对话框、定制样式、动画效果
1. 创建自定义对话框
首先,我们需要创建一个自定义对话框组件。在这个组件中,我们将使用 TextField
来接收用户输入。
1.1 代码实现
import 'package:flutter/material.dart';class CustomDialog extends StatelessWidget {final TextEditingController controller;final String title;CustomDialog({Key? key, required this.controller, required this.title}) : super(key: key);@overrideWidget build(BuildContext context) {return AlertDialog(title: Text(title),content: TextField(controller: controller,decoration: InputDecoration(hintText: '请输入内容',),),actions: [TextButton(onPressed: () {Navigator.of(context).pop(controller.text);},child: Text('提交'),),TextButton(onPressed: () {Navigator.of(context).pop();},child: Text('取消'),),],);}
}
1.2 解释代码
- TextEditingController: 用于控制和获取
TextField
的内容。 - AlertDialog: Flutter 提供的对话框组件,用于显示提示信息。
- TextButton: 用于实现按钮功能。
2. 样式定制
我们可以根据需要修改对话框的样式,比如背景颜色、字体等。
2.1 修改样式
在 AlertDialog
中,我们可以通过 backgroundColor
和 titleTextStyle
来定制样式。
@override
Widget build(BuildContext context) {return AlertDialog(backgroundColor: Colors.blue[50],title: Text(title,style: TextStyle(color: Colors.blue, fontWeight: FontWeight.bold),),content: TextField(controller: controller,decoration: InputDecoration(hintText: '请输入内容',border: OutlineInputBorder(),),),actions: [// 按钮部分不变],);
}
3. 动画效果
为对话框添加动画,可以使其展示更加生动。我们可以使用 showDialog
方法并结合 PageRouteBuilder
来实现。
3.1 添加动画
void _showCustomDialog(BuildContext context) {showDialog(context: context,builder: (context) {return PageRouteBuilder(pageBuilder: (context, animation, secondaryAnimation) {return FadeTransition(opacity: animation,child: CustomDialog(controller: TextEditingController(), title: '自定义对话框'),);},transitionsBuilder: (context, animation, secondaryAnimation, child) {const begin = Offset(0.0, 1.0);const end = Offset.zero;const curve = Curves.easeInOut;var tween = Tween(begin: begin, end: end).chain(CurveTween(curve: curve));var offsetAnimation = animation.drive(tween);return SlideTransition(position: offsetAnimation,child: child,);},);},);
}
3.2 解释动画代码
- PageRouteBuilder: 用于自定义页面路由,允许我们定义自己的动画。
- FadeTransition: 为对话框添加渐变效果。
- SlideTransition: 为对话框添加滑动效果。
4. 使用自定义对话框
最后,我们在主页面中调用这个自定义对话框。
4.1 主页面代码
import 'package:flutter/material.dart';void main() {runApp(MyApp());
}class MyApp extends StatelessWidget {@overrideWidget build(BuildContext context) {return MaterialApp(home: Scaffold(appBar: AppBar(title: Text('自定义对话框示例')),body: Center(child: ElevatedButton(onPressed: () => _showCustomDialog(context),child: Text('显示对话框'),),),),);}void _showCustomDialog(BuildContext context) {// 在这里调用自定义对话框}
}
总结
通过以上步骤,我们实现了一个包含输入框、样式定制和动画效果的自定义对话框。这个对话框不仅美观,还能增强用户体验。你可以根据需要进一步扩展和定制这个对话框,使其适应不同的场景。
相关文章:
Flutter鸿蒙next 封装对话框详解
✅近期推荐:求职神器 https://bbs.csdn.net/topics/619384540 🔥欢迎大家订阅系列专栏:flutter_鸿蒙next 💬淼学派语录:只有不断的否认自己和肯定自己,才能走出弯曲不平的泥泞路,因为平坦的大路…...
【项目实战】通过LLaMaFactory+Qwen2-VL-2B微调一个多模态医疗大模型
前言 随着多模态大模型的发展,其不仅限于文字处理,更能够在图像、视频、音频方面进行识别与理解。医疗领域中,医生们往往需要对各种医学图像进行处理,以辅助诊断和治疗。如果将多模态大模型与图像诊断相结合,那么这会…...
SCSI驱动与 UFS 驱动交互概况
SCSI子系统概况 SCSI(Small Computer System Interface)子系统是 Linux 中的一个模块化框架,用于提供与存储设备的通用接口。通过 SCSI 子系统,可以支持不同类型的存储协议(如 UFS、SATA、SAS),…...
软件工程实践项目:人事管理系统
一、项目的需求说明 通过移动设备登录app提供简单、方便的操作。根据公司原来的考勤管理制度,为公司不同管理层次提供相应的权限功能。通过app上面的各种标准操作,考勤管理无纸化的实现,使公司的考勤管理更加科学规范,从而节省考…...
不使用三方软件,win系统下禁止单个应用联网能力的详细操作教程
本篇文章主要讲解,在win系统环境下,禁止某个应用联网能力的详细操作教程,通过本教程您可以快速掌握自定义对单个程序联网能力的限制和禁止。 作者:任聪聪 日期:2024年10月30日 步骤一、按下win按键(四个小方…...
近似线性可分支持向量机的原理推导
近似线性可分的意思是训练集中大部分实例点是线性可分的,只是一些特殊实例点的存在使得这种数据集不适用于直接使用线性可分支持向量机进行处理,但也没有到完全线性不可分的程度。所以近似线性可分支持向量机问题的关键就在于这些少数的特殊点。 相较于…...
Golang开发环境
Golang开发环境搭建 Go 语言开发包 国外:https://golang.org/dl/ 国内(推荐): https://golang.google.cn/dl/ 编辑器 Golang:https://www.jetbrains.com/go/ Visual Studio Code: https://code.visualstudio.com/ 搭建 Go 语言开发环境,需要…...
测试华为GaussDB(DWS)数仓,并通过APISQL快速将(表、视图、存储过程)发布为API
华为数据仓库服务 数据仓库服务(Data Warehouse Service,简称DWS)是一种基于公有云基础架构和平台的在线数据处理数据库,提供即开即用、可扩展且完全托管的分析型数据库服务。DWS是基于华为融合数据仓库GaussDB产品的云原生服务&a…...
使用GetX实现GetPage中间件
前言 GetX 中间件(Middleware)是 GetX 框架中的一种机制,用于在页面导航时对用户进行权限控制、数据预加载、页面访问条件设置等。通过使用中间件,可以有效地控制用户的访问流程,并在适当条件下引导用户到所需页面。 这…...
Navicat 17 功能简介 | SQL 预览
Navicat 17 功能简介 | SQL 预览 随着 17 版本的发布,Navicat 也带来了众多的新特性,包括兼容更多数据库、全新的模型设计、可视化智能 BI、智能数据分析、可视化查询解释、高质量数据字典、增强用户体验、扩展MongoDB 功能、轻松固定查询结果、便捷URI …...
ubuntu、Debian离线部署gitlab
一、软件包下载 gitlab安装包下载链接 ubuntu: ubuntu/focal 适用于 ubuntu20系列 ubuntu/bionic 适用于 ubuntu18 系列 Debian: debian/buster 适用于 Debian10系列 debian/bullseye 适用于 Debian11、12系列 二、安装gitlab ubuntu需要安装一些环境…...
数据库编程 SQLITE3 Linux环境
永久存储程序数据有两种方式: 用文件存储用数据库存储 对于多条记录的存储而言,采用文件时,插入、删除、查找的效率都会很差,为了提高这些操作的效率,有计算机科学家设计出了数据库存储方式 一、数据库 数据库的基本…...
独孤思维:总有一双眼睛默默观察你做副业
01 独孤昨天在陪伴群,分享了近期小白做副业的一些困扰。 并且以自己经历作为案例,分享了一些经验和方法。 最后顺势推出xx博主的关于365条赚钱信息小报童专栏。 订阅后,可以开拓副业赚钱思路,避免走一些弯路。 甚至于&#x…...
医院信息化与智能化系统(10)
医院信息化与智能化系统(10) 这里只描述对应过程,和可能遇到的问题及解决办法以及对应的参考链接,并不会直接每一步详细配置 如果你想通过文字描述或代码画流程图,可以试试PlantUML,告诉GPT你的文件结构,让他给你对应…...
基于YOLO11/v10/v8/v5深度学习的危险驾驶行为检测识别系统设计与实现【python源码+Pyqt5界面+数据集+训练代码】
《博主简介》 小伙伴们好,我是阿旭。专注于人工智能、AIGC、python、计算机视觉相关分享研究。 ✌更多学习资源,可关注公-仲-hao:【阿旭算法与机器学习】,共同学习交流~ 👍感谢小伙伴们点赞、关注! 《------往期经典推…...
Flink CDC系列之:学习理解核心概念——Transform
Flink CDC系列之:学习理解核心概念——Transform Transform参数元数据字段函数比较函数逻辑函数字符串函数时间函数条件函数 示例添加计算列参考元数据列使用通配符投影所有字段添加过滤规则重新分配主键重新分配分区键指定表创建配置分类映射用户定义函数已知限制 …...
MyBatis-Plus:简化 CRUD 操作的艺术
一、关于MyBatis-Plus 1.1 简介 MyBatis-Plus 是一个基于 MyBatis 的增强工具,它旨在简化 MyBatis 的使用,提高开发效率。 关于Mybatis 简介 MyBatis 是一款流行的 Java 持久层框架,旨在简化 Java 应用程序与数…...
Windows on ARM编译安装openBLAS
Windows on ARM编译安装openBLAS 要求下载源码OpenBLAS可以使用LLVM工具链(clang-cl和flang)从源代码为Windows on ARM(WoA)进行构建。v0.3.24版本(预构建包)的构建和测试已通过。 要求 LLVM:版本需大于等于17.0.4 LLVM版本16及以下会生成冲突的符号(如_QQ*等)。 LL…...
FPGA编程语言VHDL与Verilog的比较分析!!!
VHDL(VHSIC硬件描述语言)和Verilog都是用于硬件描述和FPGA编程的工业标准语言。它们在语法和设计理念上存在一些差异,以下是两者的比较分析: 1. 历史背景 VHDL: 开发于1980年代初期,最初用于美国国防部的…...
C语言——八股文(笔试面试题)
1、 什么是数组指针,什么是指针数组? 数组指针:指向数组的指针 指针数组:数组中的元素都是指针 2、 什么是位段,什么是联合体 位段(Bit Field):在C语言中,允许在一个整数…...
解决 Oracle 数据库错误 ORA-12516:监听器无法找到匹配协议栈的处理程序
在使用 Oracle 数据库时,有时会遇到错误 ORA-12516,这个错误表明 Oracle 数据库的监听器无法为新的连接请求找到一个可用的处理程序,这通常是因为达到了连接数上限、配置问题或资源限制。本文将详细介绍如何解决这个问题。 一、错误描述 当…...
Flarum:简洁而强大的开源论坛软件
Flarum简介 Flarum是一款开源论坛软件,以其简洁、快速和易用性而闻名。它继承了esoTalk和FluxBB的优良传统,旨在提供一个不复杂、不臃肿的论坛体验。Flarum的核心优势在于: 快速、简单: Flarum使用PHP构建,易于部署&…...
方法+数组
1. 方法 1. 什么是方法 方法定义: // []表示可写可不写[public] [static] type name ( [type formal , type formal , ...]){方法体;[return value ;] }[修饰符] 返回值类型 方法名称([参数类型 形参 , 参数类型 形参 ...]){方法体代码;[return 返回值…...
驱动-----adc
在key1.c的基础上进行对adc1.c进行编写 首先将文件里面的key全部改为adc 再修改一下设备号 按键和adc的区别是什么,按键只需要按一下就触发了,并且不需要返回一个值出来, adc要初始化,启动,返回值 以下是裸机adc的代码: #include <s3c2440.h> #include "ad…...
js实现点击图片,使图片跟随鼠标移动(把注释打开是图片随机位置)
代码: <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>Document</title>&l…...
MacOS的powermetrics命令查看macbook笔记本的耗能情况,附带查看ANE的工作情况
什么是 powermetrics? powermetrics 是 macOS 系统自带的一个命令行工具,用于收集和分析系统能源消耗数据。通过它,我们可以深入了解 Mac 的硬件性能、软件行为以及能源使用情况,从而优化系统配置,提高电池续航时间。…...
字符串函数
大家好,今天我们来了解几个字符串函数 1.strcpy函数 这个函数是一个字符串复制函数,其全称为string copy,它可以将一个源字符数组的内容复制到目标字符数组中,我们需要关注几个问题,首先源字符串必须以\0…...
Java数组的地址和元素访问 C语言空指针与野指针
1. public static void main(String[] args) {int []arr{1,2,3,4,5};int numarr[0];System.out.println(num);System.out.println(arr[1]);System.out.println(arr);//[I610f87f48//[表示地址 I表示数据类型 表示间隔符号(固定格式)//10f87f48表示地址…...
如何在Linux系统中使用SSH进行安全连接
如何在Linux系统中使用SSH进行安全连接 SSH简介 安装SSH 在Debian/Ubuntu系统中安装 在CentOS/RHEL系统中安装 启动SSH服务 验证SSH是否安装成功 SSH配置 配置监听端口 配置登录方式 SSH客户端 安装SSH客户端 使用SSH客户端 SSH密钥认证 生成SSH密钥对 复制公钥到远程服务器…...
Pandas 数据可视化指南:从散点图到面积图的全面展示
Pandas 数据可视化指南:从散点图到面积图的全面展示 本文介绍了使用 Pandas 进行数据可视化的多种方法,包括散点图、折线图、条形图、直方图、饼图和面积图等,涵盖了常见的图表类型及其实现方式。通过提供详细的代码示例,展示了如…...
网站后台需要ie6修改/南宁网站seo优化公司
后台写了个方法,接收前台插件 bootstrap-table 的queryParams的参数,但是不能拿到。 解决办法,添加配置项:contentType:"application/x-www-form-urlencoded; charsetUTF-8", 这样取得了。 参数传递过去了,但…...
网站建设费计入那个科目/seo网站搭建是什么
由于druid的大查询会产生很多临时的中间文件,如/tmp/druid/druid-groupBy-27e88733-d1f1-4589-bf63-ef3a40d4d945_273009ff-02cd-4085-b9f6-e94c7931111c/02135564.tmp (Too many open files)",会造成查询中断,需修改相应的系统的open f…...
wordpress博客建设与经营/制作网站需要什么技术
XPS是2012年为国内某股份制商业银行开发的一套信用卡业务流程处理系统,基于公司的Workbench 2.0框架进行开发。所谓Workbench 2.0,实际是2009年我在公司的Workbench 1.0的基础上,把底层的各开源框架更新到当时相对较新的版本,例如…...
wordpress 评论邮件通知/设计网站模板
在数据库中,有一个值是日期来的。但在ASP.NET显示时,它还是有显示时间部分: 解决这个问题,也许你第一时间想到,在前端页去format一下日期格式,如:http://www.cnblogs.com/insus/archive/2010/05…...
如何小企业网站建设/东莞全网营销推广
import randomimport datetime# 选择排序def getMaxIndex(index, ls) -> int:""":type ls list:type index: int:return:"""# 选择排序时 一开始就认为当前的数的最大的maxIndex indexlength len(ls)for i in range(index, length):if ls[i…...
佛山企业网站建设多少钱/买链接官网
SRWLock的目的和关键段相同:对一个资源进行保护,不让其它线程访问它。但是,与关键段不同的是,SRWLock允许我们区分哪些想要读取资源的值 的线程(读取者线程)和想要更新资源的值的线程(写入者线程…...