当前位置: 首页 > news >正文

【WinForm UI控件系列】模式输入对话框inputDialog(支持文本,整型、浮点型数字、单选框、多选框、下拉框、颜色)

InputDialog 是一个现代化的输入对话框控件,参考 Ant Design 设计规范,支持多种输入类型(文本型、数字型、单选型、复选型、颜色、密码)

一、示例

模式输入框(带遮罩层)、采用自定义输入框(水印、可清空等)





单选和复选框,采用本控件中的自定义控件

风格:默认,成功,警告,错误

新增下拉框



二、使用说明

InputDialog 输入对话框控件

控件优点

InputDialog 是一个现代化的输入对话框控件,参考 Ant Design 设计规范,支持多种输入类型:

  • 文本输入(使用 InputBox 控件,支持水印提示)
  • 密码输入
  • 数字输入
  • 下拉选择(使用 ComboBoxEx 控件)
  • 单选组输入(使用 RadioEx 控件)
  • 多选组输入(使用 CheckBoxEx 控件)
  • 颜色选择(使用 ColorPicker 控件)

主要特性:

  • 圆角边框设计
  • 遮罩层效果(可选)
  • 淡入动画
  • 主题适配
  • 可拖动标题栏
  • 支持多种输入类型

重要参数说明

静态方法参数

方法参数类型说明
ShowTextInputownerIWin32Window父窗口
captionstring对话框标题
promptstring提示文本(水印)
valueref string输入值
ShowNumberInputownerIWin32Window父窗口
captionstring对话框标题
promptstring提示文本(水印)
valueref decimal数字值
decimalPlacesint小数位数
ShowRadioGroupInputownerIWin32Window父窗口
captionstring对话框标题
promptstring提示文本
optionsList选项列表
selectedValueref string选中值
ShowCheckBoxGroupInputownerIWin32Window父窗口
captionstring对话框标题
promptstring提示文本
optionsList选项列表
selectedValuesref string[]选中值数组
ShowComboBoxInputownerIWin32Window父窗口
captionstring对话框标题
promptstring提示文本
optionsList选项列表
selectedValueref string选中值
ShowColorInputownerIWin32Window父窗口
captionstring对话框标题
promptstring提示文本
valueref Color颜色值

实例属性

属性类型默认值说明
Captionstring“”对话框标题
PromptTextstring“请输入”提示文本
InputTypeInputTypeInputType.Text输入类型
ThemeColorThemeColorTypeThemeColorType.Primary主题颜色类型
TextValuestring“”文本输入值
NumberValuedecimal0数字输入值
DecimalPlacesint0小数位数
OptionsListnew List()选项列表
ColorValueColor#1890ff颜色选择值
ShowOverlaybooltrue是否显示遮罩层
OverlayOpacityint100遮罩层透明度(0-255)

只读属性(返回结果)

属性类型说明
ResultTextstring返回文本值
ResultNumberdecimal返回数字值
ResultOptionsList返回选中选项值列表
ResultColorColor返回选择的颜色
ResultColorHexstring返回颜色的十六进制字符串(如 #1890FF)

InputOption 选项类

publicclassInputOption{publicstringValue{get;set;}// 选项值publicstringText{get;set;}// 显示文本publicboolSelected{get;set;}// 是否选中}

ThemeColorType 主题色类型

ThemeColorType颜色说明
Primary#1890ff品牌主色(蓝色)
Success#52c41a成功色(绿色)
Warning#faad14警告色(橙色)
Error#f5222d错误色(红色)

使用示例

1. 使用静态方法(简单场景)

// 文本输入stringname="";InputDialog.ShowTextInput(this,"输入名称","请输入您的姓名:",refname);// 密码输入stringpassword="";InputDialog.ShowPasswordInput(this,"输入密码","请输入密码:",refpassword);// 数字输入decimalprice=0;InputDialog.ShowNumberInput(this,"输入价格","请输入价格:",refprice,2);// 单选组varoptions=newList<InputOption>{newInputOption("A","选项A"){Selected=true},newInputOption("B","选项B"},newInputOption("C","选项C"}};stringselected="";InputDialog.ShowRadioGroupInput(this,"选择","请选择一项:",options,refselected);// 多选组string[]selectedValues=null;InputDialog.ShowCheckBoxGroupInput(this,"多选","请选择多项:",options,refselectedValues);// 下拉选择varcomboOptions=newList<InputOption>{newInputOption("1","选项一"),newInputOption("2","选项二"),newInputOption("3","选项三")};stringselected="";InputDialog.ShowComboBoxInput(this,"选择","请选择一项:",comboOptions,refselected);// 颜色选择ColorselectedColor=Color.FromArgb(24,144,255);InputDialog.ShowColorInput(this,"选择颜色","请选择主题色:",refselectedColor);

2. 使用扩展方法(支持遮罩层自定义)

首先添加 using 引用:

usingAntdUIEx.Extensions;

然后使用扩展方法:

// 文本输入 - 带遮罩层stringname="";this.ShowTextInputEx("输入名称","请输入您的姓名:",refname,showOverlay:true,overlayOpacity:100);// 文本输入 - 不带遮罩层this.ShowTextInputEx("输入名称","请输入您的姓名:",refname,showOverlay:false);// 密码输入stringpassword="";this.ShowPasswordInputEx("输入密码","请输入密码:",refpassword,showOverlay:true);// 数字输入decimalprice=0;this.ShowNumberInputEx("输入价格","请输入价格:",refprice,2,showOverlay:true,overlayOpacity:80);// 单选组stringselected="";this.ShowRadioGroupInputEx("选择","请选择一项:",options,refselected,showOverlay:true);// 多选组string[]selectedValues=null;this.ShowCheckBoxGroupInputEx("多选","请选择多项:",options,refselectedValues,showOverlay:true);// 下拉选择stringselected="";this.ShowComboBoxInputEx("选择","请选择一项:",comboOptions,refselected,showOverlay:true);

3. 使用实例方式(完整控制)

stringname="";using(vardialog=newInputDialog()){dialog.Caption="输入名称";dialog.PromptText="请输入您的姓名:";dialog.InputType=InputType.Text;dialog.TextValue=name;dialog.ShowOverlay=true;dialog.OverlayOpacity=100;if(dialog.ShowDialog(this)==DialogResult.OK){name=dialog.ResultText;MessageBox.Show("您输入的是:"+name);}}// 颜色选择using(vardialog=newInputDialog()){dialog.Caption="选择颜色";dialog.PromptText="请选择主题色:";dialog.InputType=InputType.Color;dialog.ColorValue=Color.FromArgb(24,144,255);dialog.ThemeColor=ThemeColorType.Primary;if(dialog.ShowDialog(this)==DialogResult.OK){Colorselected=dialog.ResultColor;//色值stringhex=dialog.ResultColorHex;// #1890FF//MessageBox.Show($"选择的颜色:{hex}");}}// 颜色快速示例Colorcolor=Color.Blue;//默认if(InputDialog.ShowColorInput(this,"选择颜色","请选择主题色",refcolor)==DialogResult.OK){groupBox4.HeaderColor=color;//色值应用}

4. 设置主题色

// 设置不同的主题色using(vardialog=newInputDialog()){dialog.Caption="警告提示";dialog.PromptText="请确认您的操作:";dialog.InputType=InputType.Text;dialog.ThemeColor=ThemeColorType.Warning;// 设置为警告色(橙色)dialog.ShowDialog(this);}// 使用成功色using(vardialog=newInputDialog()){dialog.Caption="操作成功";dialog.PromptText="请输入备注:";dialog.InputType=InputType.Text;dialog.ThemeColor=ThemeColorType.Success;// 设置为成功色(绿色)dialog.ShowDialog(this);}// 使用错误色using(vardialog=newInputDialog()){dialog.Caption="错误提示";dialog.PromptText="请重新输入:";dialog.InputType=InputType.Text;dialog.ThemeColor=ThemeColorType.Error;// 设置为错误色(红色)dialog.ShowDialog(this);}

扩展方法说明

InputDialogExtensions 扩展方法类提供了更便捷的调用方式,支持遮罩层参数自定义:

扩展方法对应功能额外参数
ShowTextInputEx文本输入showOverlay, overlayOpacity
ShowPasswordInputEx密码输入showOverlay, overlayOpacity
ShowNumberInputEx数字输入showOverlay, overlayOpacity, decimalPlaces
ShowRadioGroupInputEx单选组输入showOverlay, overlayOpacity
ShowCheckBoxGroupInputEx多选组输入showOverlay, overlayOpacity
ShowComboBoxInputEx下拉选择showOverlay, overlayOpacity

注意事项

  1. 遮罩层设置:静态方法使用默认遮罩层设置,如需自定义请使用扩展方法或实例方式
  2. 清除按钮:InputBox 的 AllowClear 属性设置为 true,但清除按钮仅在输入框有内容时显示
  3. 水印显示:提示文本作为 InputBox 的 Placeholder(水印)显示,输入框为空时可见
  4. 单选/多选:选项值使用 HashSet 去重,避免重复显示
  5. 返回值:通过 ref 参数返回用户输入的值,取消时原值不变

三、后记

更多功能和控件完善中,持续关注,如有需求或好的建议,请留言(xue5zhijing)

http://www.zskr.cn/news/1383971.html

相关文章:

  • Sweet32漏洞深度解析:3DES-CBC在TLS中的生日攻击与实战禁用指南
  • ShrinkBox后门攻击:如何让自动驾驶模型“看错”距离,威胁ML-ADAS安全
  • Chromebook常用配置 - yi
  • 基于AVR单片机的简易气象站设计与实现:从传感器选型到户外部署
  • 实战案例|打印组件在【仓库入库单】中的真实应用
  • 基于ESP32与热回收风机的智能通风系统:防结露与节能控制
  • Claude多方案对比评估深度复盘(企业级评估框架首次公开)
  • 为什么你的Petalinux装不上?盘点Ubuntu 18.04环境那些必须提前搞定的依赖库(附完整apt命令清单)
  • 从原理到实战:一文搞懂Linux traceroute和Windows tracert的异同与选型
  • http响应的 headers中拿到文件名
  • 革新机器人开发范式:WPR仿真平台如何赋能高效虚拟测试与算法验证
  • INT8量化下TVA注意力对齐精度保障方案
  • 免费抓包工具选型指南:Wireshark、Fiddler、mitmproxy、Charles实战对比
  • AI时代程序员变现指南:别只写代码,要让代码替你赚钱
  • 【Java EE】IP协议
  • RoBERTa-Med涨点改进 | 医疗NLP实战独家复现,问诊意图识别篇 引入医疗领域预训练权重,强化语义理解与意图区分、助力智能问诊、在线咨询、病历结构化有效涨点
  • LeetCode 每日一题 2026/5/18-2026/5/24
  • 观察taotoken在多模型间自动路由对api调用成功率的影响
  • 如何快速实现Windows游戏控制器虚拟化:ViGEmBus完整使用指南
  • 使用taotoken的token套餐为ubuntu服务器上的ai应用控制成本
  • Android Tethering/netd 集成架构深度分析
  • 从零理解 Redisson:Java 分布式工具箱的入门与实战
  • 探析数字孪生的核心特性与应用价值
  • 告别AWCC臃肿:AlienFX Tools终极轻量级控制方案深度评测
  • 谈美---朱光潜前20页
  • 脉冲神经网络加速器设计与边缘计算优化
  • OpenIPC开源固件:5分钟解锁网络摄像头的终极控制权
  • 告别全屏截图!用Playwright精准捕获页面元素,让你的测试报告更专业
  • 告别MQTT.fx!用STM32+ESP8266直连新版OneNET,手把手教你从零配置JSON数据上传
  • 独家专访杨元庆:详解联想集团千亿美金营收目标