uniGUI for Delphi UniSweetAlert控件详解

2023-12-16 09:20

本文主要是介绍uniGUI for Delphi UniSweetAlert控件详解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

UniSweetAlert是UniGUI后期版本新增的一个界面友好的消息提示和输入控件,是ShowMessageN的升级版,UniSweetAlert增加了更多的可控制属性。

属性介绍

1、AlertType:提示类型,分为atError、atSuccess、atInfo、atQuestion、atWarning五种类型,主要控制提示界面顶部的图标样式;

2、AllowEscapeKey:是否允许Esc键关闭提示界面;

3、AllowOutsideClick:是否允许点击提示框外部区域关闭提示界面;

4、Animation:动画;

5、CancellButtonText:取消按钮中文内容;

6、ConfirmButtonText:确认按钮中文内容;

7、FocusCancel:焦点定位到取消按钮上;

8、Images:关联的图标控件,提示框中上数第二个图标;

9、InputType:输入类型,有ltNone、ltFile、ltMail、ltSelect、ltPassword、ltRaido等多种类型;

10、InputValue:初始显示的输入内容;

11、ReverseButtons:反向顺序摆放按钮,“确认”“取消”变为“取消”“确认”;

12、ShowCancellButton:显示取消按钮;

13、ShowCloseButton:显示提示框右上角的关闭按钮;

14、ShowConfirmButton:显示确认按钮;

15、ShowLoaderOnConfirm:显示确认前的预处理过程;

16、Title:提示信息;

         创建一个新项目,按照下图添加和摆放各个控件,分别设置UniComboBox1、UniEdit1~4的FieldLabel标签属性,为UniNativImageList1添加一个小图片,让UniSweetAlert1的Images设为UniNativeImageList1,让ImageIndex设为0。三个按钮分别代表不同的应用方法,点击“一般交互提示”按钮将弹出提示框,操作“确认”和“取消”按钮都将提示操作结果;点击“判断执行结果”按钮将弹出提示框,仅操作“确定”按钮有操作结果提示,操作“取消”按钮没有操作结果提示;点击“预处理后执行”按钮将弹出提示框,操作“确定”按钮后将经过一个执行时间后再返回执行结果提示。

   

5.32.2 主要代码main.pas

unit Main;

interface

uses

  Windows, Messages, SysUtils, Variants, Classes, Graphics,

  Controls, Forms, uniGUITypes, uniGUIAbstractClasses,

  uniGUIClasses, uniGUIRegClasses, uniGUIForm, uniGUIBaseClasses, uniSweetAlert,

  uniButton, uniImageList, uniEdit, uniCheckBox, uniMultiItem, uniComboBox;

type

  TMainForm = class(TUniForm)

    UniComboBox1: TUniComboBox;

    UniCheckBox1: TUniCheckBox;

    UniCheckBox2: TUniCheckBox;

    UniEdit1: TUniEdit;

    UniEdit2: TUniEdit;

    UniCheckBox3: TUniCheckBox;

    UniCheckBox4: TUniCheckBox;

    UniEdit3: TUniEdit;

    UniButton1: TUniButton;

    UniButton2: TUniButton;

    UniSweetAlert1: TUniSweetAlert;

    UniNativeImageList1: TUniNativeImageList;

    UniCheckBox5: TUniCheckBox;

    UniButton3: TUniButton;

    UniEdit4: TUniEdit;

    procedure UniButton1Click(Sender: TObject);

    procedure UniButton2Click(Sender: TObject);

    procedure UniButton3Click(Sender: TObject);

    procedure UniSweetAlert1Confirm(Sender: TObject);

    procedure UniSweetAlert1PreConfirm(Sender: TObject; var Result: Boolean;

      var ErrorString: string);

    procedure UniSweetAlert1Dismiss(Sender: TObject;

      const Reason: TDismissType);

  private

    procedure ConfigSweetAlert(const ShowLoader: Boolean = False);//添加SweetAlert属性配置函数

    { Private declarations }

  public

    { Public declarations }

  end;

function MainForm: TMainForm;

implementation

{$R *.dfm}

uses

  uniGUIVars, MainModule, uniGUIApplication;

function MainForm: TMainForm;

begin

  Result := TMainForm(UniMainModule.GetFormInstance(TMainForm));

end;

1、UniSweetAlert属性配置

procedure TMainForm.ConfigSweetAlert(const ShowLoader: Boolean = False);

begin

  with UniSweetAlert1 do

  begin

    AlertType := TAlertType(UniComboBox1.ItemIndex);//设置提示类型

    AllowEscapeKey := UniCheckBox1.Checked;//是否允许按ESC

    AllowOutsideClick := UniCheckBox2.Checked;//是否允许外部点击

    CancelButtonText := UniEdit1.Text;//取消按钮的中文内容

    ConfirmButtonText := UniEdit2.Text;//确认按钮的中文内容

    ShowCancelButton := UniCheckBox3.Checked;//是否显示取消按钮

    ShowCloseButton := UniCheckBox4.Checked;//是否显示关闭按钮

    ShowLoaderOnConfirm := ShowLoader;//是否确认前等待

    Title := UniEdit3.Text;//提示信息

    if UniCheckBox5.Checked then

    begin

      InputType := ItText;

      InputValue := UniEdit4.Text;

    end

    else

      InputType := ItNone;

  end;

end;

2、“一般交互提示”按钮事件

procedure TMainForm.UniButton1Click(Sender: TObject);

begin

  ConfigSweetAlert;

  UniSweetAlert1.Show;//显示提示

end;

2、“判断执行结果”按钮事件

procedure TMainForm.UniButton2Click(Sender: TObject);

begin

  ConfigSweetAlert;

  if UniSweetAlert1.Execute then//根据执行结果进行提示

    ShowMessageN('执行结果:成功! ' + UniSweetAlert1.InputResult);

end;

3、“预处理后执行”按钮事件

procedure TMainForm.UniButton3Click(Sender: TObject);

begin

  ConfigSweetAlert(True);

  UniSweetAlert1.Show;

end;

4、UniSweetAlert“确认”按钮事件

procedure TMainForm.UniSweetAlert1Confirm(Sender: TObject);

begin

  if UniCheckBox5.Checked then

    begin

      ShowMessageN('确认:你输入了 ' + UniSweetAlert1.InputResult);

    end

  else

    begin

      ShowMessageN('确认');

    end;

end;

5、UniSweetAlert“取消”按钮事件

procedure TMainForm.UniSweetAlert1Dismiss(Sender: TObject;

  const Reason: TDismissType);

begin

  case Reason of

    dtOverlay:   ShowMessageN('驳回原因:覆盖');

    dtCancel: ShowMessageN('驳回原因:取消');

    dtClose:  ShowMessageN('驳回原因:关闭');

    dtESC:  ShowMessageN('驳回原因:按了ESC');

    dtTimer:  ShowMessageN('驳回原因:超时');

  end;

end;

6、UniSweetAlert“预处理”按钮事件

procedure TMainForm.UniSweetAlert1PreConfirm(Sender: TObject;

  var Result: Boolean; var ErrorString: string);

begin

  Sleep(2000); // 模拟等待!

  Result := True;

  ShowMessageN('确认:你输入了 ' + UniSweetAlert1.InputResult);

end;

initialization

  RegisterAppFormClass(TMainForm);

end.

这篇关于uniGUI for Delphi UniSweetAlert控件详解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/499972

相关文章

Java使用ANTLR4对Lua脚本语法校验详解

《Java使用ANTLR4对Lua脚本语法校验详解》ANTLR是一个强大的解析器生成器,用于读取、处理、执行或翻译结构化文本或二进制文件,下面就跟随小编一起看看Java如何使用ANTLR4对Lua脚本... 目录什么是ANTLR?第一个例子ANTLR4 的工作流程Lua脚本语法校验准备一个Lua Gramm

Qt中QGroupBox控件的实现

《Qt中QGroupBox控件的实现》QGroupBox是Qt框架中一个非常有用的控件,它主要用于组织和管理一组相关的控件,本文主要介绍了Qt中QGroupBox控件的实现,具有一定的参考价值,感兴趣... 目录引言一、基本属性二、常用方法2.1 构造函数 2.2 设置标题2.3 设置复选框模式2.4 是否

一文详解如何在Python中从字符串中提取部分内容

《一文详解如何在Python中从字符串中提取部分内容》:本文主要介绍如何在Python中从字符串中提取部分内容的相关资料,包括使用正则表达式、Pyparsing库、AST(抽象语法树)、字符串操作... 目录前言解决方案方法一:使用正则表达式方法二:使用 Pyparsing方法三:使用 AST方法四:使用字

Qt中QUndoView控件的具体使用

《Qt中QUndoView控件的具体使用》QUndoView是Qt框架中用于可视化显示QUndoStack内容的控件,本文主要介绍了Qt中QUndoView控件的具体使用,具有一定的参考价值,感兴趣的... 目录引言一、QUndoView 的用途二、工作原理三、 如何与 QUnDOStack 配合使用四、自

Python列表去重的4种核心方法与实战指南详解

《Python列表去重的4种核心方法与实战指南详解》在Python开发中,处理列表数据时经常需要去除重复元素,本文将详细介绍4种最实用的列表去重方法,有需要的小伙伴可以根据自己的需要进行选择... 目录方法1:集合(set)去重法(最快速)方法2:顺序遍历法(保持顺序)方法3:副本删除法(原地修改)方法4:

python logging模块详解及其日志定时清理方式

《pythonlogging模块详解及其日志定时清理方式》:本文主要介绍pythonlogging模块详解及其日志定时清理方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录python logging模块及日志定时清理1.创建logger对象2.logging.basicCo

前端CSS Grid 布局示例详解

《前端CSSGrid布局示例详解》CSSGrid是一种二维布局系统,可以同时控制行和列,相比Flex(一维布局),更适合用在整体页面布局或复杂模块结构中,:本文主要介绍前端CSSGri... 目录css Grid 布局详解(通俗易懂版)一、概述二、基础概念三、创建 Grid 容器四、定义网格行和列五、设置行

Node.js 数据库 CRUD 项目示例详解(完美解决方案)

《Node.js数据库CRUD项目示例详解(完美解决方案)》:本文主要介绍Node.js数据库CRUD项目示例详解(完美解决方案),本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考... 目录项目结构1. 初始化项目2. 配置数据库连接 (config/db.js)3. 创建模型 (models/

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的