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

DevExpress WinForms v24.2 - 新增日程组件、电子表格组件功能扩展

DevExpress WinForms拥有180+组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜任!

DevExpress WinForms控件v24.2日前已经全新发布,新版本中的日程组件、电子表格组件功能扩展功能,欢迎下载最新版体验!

DevExpress WinForms v24.2正式版下载

Scheduler(日程)
提醒表单 - 新增 'RemindersFormAction' 事件

v24.2附带了一个新的DevExpress WinForms Scheduler RemindersFormAction事件,当用户单击提醒表单上的Dismiss、Dismiss All或Snoozeanniushi按钮时(或者用户关闭表单时),就会触发该事件。

DevExpress WinForms v24.2产品图集

通过e.ActionType事件参数获取触发该事件的用户操作,例如您可以在用户执行特定操作时显示个性化通知,或者可以通过将e.Handled参数设置为true来取消默认操作(并根据需要执行自定义逻辑)。

资源树 - 自动填充列

一旦将Resources Tree组件添加到包含DevExpress Scheduler控件的表单中,Resources Tree组件就会根据底层数据存储中配置的资源映射自动生成列。这种增强减少了手动设置,并确保Resources Tree立即反映为调度定义的资源结构。

v24.2在Resources Tree的只能标记菜单中包含了 "Generate Columns" 命令,此命令允许您快速刷新列。它清除现有列,并根据资源映射重新填充它们。

为了增强运行时灵活性,我们还添加了一个PopulateColumns方法,此方法自动生成资源树列。PopulateColumns方法清除ResourcesTree.Columns集合、创建新列、将它们绑定到相应的数据字段,并向集合添加列。

使用HTML/CSS模板的可自定义Appointment窗口

现在可以使用HTML/CSS模板来定制约会显示,这个新功能使您可以完全控制显示的字段(例如,您可以显示额外的字段)和弹出框中的布局。

Spreadsheet(电子表格)
动态数组公式

DevExpress WinForms v24.2增强了公式计算引擎,并将动态数组集成到Winforms Spreadsheet UI控件中,与标准数组公式不同,标准数组公式为每个单元格返回一个值,而动态数组函数返回一个动态的值数组(这个值数组会自动溢出到相邻的单元格中)。

DevExpress WinForms v24.2产品图集

新功能包括:

  • 动态阵列计算和溢出范围支持。
  • 新的公式错误类型(#SPILL!)。
  • 隐式交叉运算符(@符号)返回单个公式值替代数组。

您现在可以导入具有动态数组公式的Excel文档,使用IWorkbook.Calculate方法重新计算这些公式,并将具有计算值的文档保存为Excel文件格式。DevExpress WinForms Spreadsheet控件可以使用单元格编辑器或公式栏插入/编辑动态数组公式,它还可以突出显示溢出的公式范围,并自动更新反映文档修改的公式值,打印和导出为PDF也可用。

此外您可以在代码中管理动态数组公式,v24.2附带了以下新API:

  • CellRange.DynamicArrayFormula - 获取或设置基于当前工作簿区域性的单元格区域的动态数组公式。
  • CellRange.DynamicArrayFormulaInvariant - 获取或设置基于不变区域性的单元格区域的动态数组公式。
  • CellRange.HasDynamicArrayFormula - 指示单元格区域是否包含动态数组公式。
  • Cell.IsTopLeftCellInDynamicArrayFormulaRange - 指示当前单元格是否为动态数组公式范围中的左上角单元格。
  • Cell.GetDynamicArrayFormulaRange() - 返回动态数组公式溢出的单元格范围。
  • Worksheet.DynamicArrayFormulas - 返回当前工作表的动态数组公式的集合。

下面的代码片段使用新的API访问、插入和清除动态数组公式:

C#

Worksheet worksheet = spreadsheetControl.ActiveWorksheet;
// Insert dynamic array formulas
worksheet["A1"].DynamicArrayFormulaInvariant = "={\"Red\",\"Green\",\"Orange\",\"Blue\"}";
worksheet.DynamicArrayFormulas.Add(worksheet["A2"], "=LEN(A1:D1)");// Clear dynamic array formulas
Cell cell = worksheet.Cells["B2"];
if (cell.HasDynamicArrayFormula) {
CellRange dymanicArrayRange = cell.GetDynamicArrayFormulaRange();
dymanicArrayRange.Clear();
}
worksheet.DynamicArrayFormulas.Remove(worksheet.Cells["A1"].GetDynamicArrayFormulaRange());

要抑制动态数组公式计算并恢复到以前的操作,将DocumentCapabilities.DynamicArrayFormulas属性设置为"DocumentCapability.Disabled"。在本例中,动态数组公式将作为标准数组公式计算。

在单元格中嵌入图像

DevExpress WinForms Spreadsheet控件支持将图像直接嵌入到工作表格中(Microsoft Excel的“Place in Cell”选项),您可以导入在工作表单元格中嵌入图像的文档,预览这些文档并将其保存为XLSX格式(不会丢失内容),打印和导出为PDF格式也可用。

DevExpress WinForms v24.2产品图集

v24.2还发布了用于在代码中管理单元嵌入图像的新API,嵌入的图像存储为单元格值。要确定单元格是否有嵌入图像,请使用CellValue.IsCellImage属性。使用CellValue.IsCellImage属性获取单元格图像值作为OfficeImage对象(允许您检查图像格式或获取图像字节)。若要在单元格中插入图像,请将其分配给CellRange.Value属性。

DevExpress Spreadsheet控件支持以下对象类型作为图像源:

  • Byte[]
  • System.IO.Stream
  • System.Drawing.Image
  • DevExpress.Drawing.DXImage
  • DevExpress.Office.Utils.OfficeImage

此外,新版本实现了指定图像Alt Text(有意义的描述)值的选项,以及将单元格图像标记为装饰性的功能,这些设置可以通过Cell.ImageInfo属性获得。下面的代码片段插入、删除和保存单元格图像(并修改可访问性设置):

C#

byte[] imageBytes = File.ReadAllBytes("image.png");
MemoryStream imageStream = new MemoryStream(imageBytes);
DXImage dximage = DXImage.FromStream(imageStream);// Insert cell images using a byte array, stream and DXImage object
worksheet.Cells["A1"].Value = imageBytes;
worksheet.Cells["A2"].Value = imageStream;
worksheet.Cells["A3"].Value = dximage;// Set image Alt Text values
worksheet.Cells["A1"].ImageInfo.AlternativeText = "Image AltText";
// Mark the cell image as decorative
if (worksheet.Cells["A2"].Value.IsCellImage)
worksheet.Cells["A2"].ImageInfo.Decorative = true;// Save the cell image to a new file
OfficeImage cellImage = worksheet.Cells["A1"].Value.ImageValue;
if (cellImage.RawFormat == OfficeImageFormat.Png)
{
byte[] cellImageBytes = cellImage.GetImageBytes(cellImage.RawFormat);
File.WriteAllBytes("saved_image.png", cellImageBytes);
}// Remove cell image
worksheet.Cells["A3"].ClearContents();
AI驱动的AltText对话框

新的AI支持的Alt Text对话框允许您为Excel文档中的形状对象设置可访问的描述,或将非信息文档图形标记为装饰性(此设置允许屏幕阅读器在扫描文档时忽略装饰性图形),您可以使用Alt Text对话框来利用AI为文档图像生成有意义的描述。

DevExpress WinForms v24.2产品图集

要启用此功能,需要注册一个AI服务,然后在WinForms应用程序中附加GenerateImageDescriptionBehavior操作:

C#

using DevExpress.AIIntegration.WinForms;//...
public SpreadsheetForm() {
InitializeComponent();
behaviorManager1.Attach<GenerateImageDescriptionBehavior>(spreadsheetControl1);
}

如果GenerateImageDescriptionBehavior没有为Spreadsheet控件注册,则Generate按钮将被禁用,只能为文档图像生成描述。当选择形状或图表对象时,Generate选项将被禁用。

新的内置对话框可以从形状的上下文菜单中获得。要激活Alt Text对话框,请选择文档形状、图像或图表,打开上下文菜单并选择"View Alt Text..." 上下文菜单项。

对齐和分布式垂直文本对齐

v24.2增加了对Spreadsheet单元格内的对齐和分布式垂直对齐类型的支持,具有这些对齐选项的Excel文件可以预览、打印和导出为PDF。

您可以使用Cell.Alignment.Vertical属性在代码中指定垂直对齐方式,下面的代码片段指定了代码中的对齐方式:

C#

var worksheet = spreadsheetControl.ActiveWorksheets;Cell cellA1 = worksheet.Cells["A1"];
cellA1.Value = "Centered and Justified";
cellA1.Alignment.Horizontal = SpreadsheetHorizontalAlignment.Center;
cellA1.Alignment.Vertical = SpreadsheetVerticalAlignment.Justify;

相关文章:

DevExpress WinForms v24.2 - 新增日程组件、电子表格组件功能扩展

DevExpress WinForms拥有180组件和UI库&#xff0c;能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序&#xff0c;无论是Office风格的界面&#xff0c;还是分析处理大批量的业务数据&#xff0c;它都能轻松胜…...

基于机器学习的心脏病预测模型构建与可解释性分析

一、引言 心脏病是威胁人类健康的重要疾病之一&#xff0c;早期预测和诊断对防治心脏病具有重要意义。本文利用公开的心脏病数据集&#xff0c;通过机器学习算法构建预测模型&#xff0c;并使用 SHAP 值进行模型可解释性分析&#xff0c;旨在为心脏病的辅助诊断提供参考。 二、…...

VisDrone无人机视觉挑战赛观察解析2025.6.5

VisDrone无人机视觉挑战赛观察解析 历史沿革与发展进程 VisDrone无人机视觉挑战赛由天津大学联合国内外多所高校及科研机构发起,自2018年起依托ECCV、ICCV等顶级计算机视觉会议连续举办,已成为全球无人机视觉领域最具影响力的学术竞赛之一。赛事以推动无人机平台视觉算法创…...

Monorepo架构: Lerna、NX、Turbo等对比与应用分析

概述 对于大型的 Monorepo 项目来说&#xff0c;Nx 绝对算是神器&#xff0c;在包管理和版本控制部分有优势对于大型 Monorepo 项目&#xff0c;Nx 是非常实用的工具&#xff0c;在包管理、版本控制以及构建、测试优化等方面都有一定作用下面我们来对比一下这几种工具 NPM 包…...

redis进入后台操作、查看key、删除key

cmd进入 redis后台 避免报错NOAUTH Authentication required 第一步 ./redis-cli -h 127.0.0.1 -p 6379第二步 AUTH YourPassword通过key删除redis缓存 进了后台之后输入 keys * 删除key del key1...

谷粒商城-分布式微服务项目-高级篇[三]

十五、商城业务-支付 15.1 支付宝支付 15.1.1 进入“蚂蚁金服开放平台” 支付宝开放 平台地址&#xff1a; 支付宝开放平台 15.1.2 下载支付宝官方 demo&#xff0c;进行配置和测试 开发者文档&#xff1a;支付宝开放平台文档中心 电脑网站支付文档&#xff1a;小程序文…...

实现购物车微信小程序

实现一个微信小程序购物车页面&#xff0c;包含以下功能&#xff1a; 需求说明&#xff1a; 商品列表&#xff1a;显示商品名称、价格、数量加减按钮&#xff0c;支持修改商品数量&#xff08;数量≥1&#xff09;。 全选 / 反选功能&#xff1a;顶部 “全选” 复选框&#…...

26考研 | 王道 | 计算机组成原理 | 四、指令系统

26考研 | 王道 | 计算机组成原理 | 四、指令系统 文章目录 26考研 | 王道 | 计算机组成原理 | 四、指令系统1.指令系统0.指令集体系结构1. 指令格式1.按地址码数目不同来分2.指令-按指令长度分类3.指令-按操作码长度分类4.指令-按操作类型分类 2. 扩展操作码指令格式 2.指令的寻…...

互联网大厂Java求职面试:AI与大模型技术在企业知识库中的深度应用

互联网大厂Java求职面试&#xff1a;AI与大模型技术在企业知识库中的深度应用 第一轮&#xff1a;场景引入与基础架构设计 面试官&#xff08;技术总监&#xff09;&#xff1a; “郑薪苦&#xff0c;我们先从一个实际场景开始吧。假设我们要为企业知识库设计一个深度融合AI大…...

在 Windows 系统安装 Git

前往官网下载Git - Downloads 目录 一、下载安装包 二、安装 Git 三、安装完成 四、验证安装 五、问题解决 解决步骤 一、下载安装包 点击页面右侧 “Download for Windows” 按钮。 点击页面最上方 “Click here to download” &#xff0c;下载 Git for Windows/x64 …...

JavaSec-SSTI - 模板引擎注入

简介 SSTI(Server Side Template Injection)&#xff1a;模板引擎是一种通过将模板中的占位符替换为实际数据来动态生成内容的工具&#xff0c;如HTML页面、邮件等。它简化了视图层的设计&#xff0c;但如果未对用户输入进行有效校验&#xff0c;可能导致安全风险如任意代码执行…...

基于InternLM的情感调节大师FunGPT

基于书生系列大模型&#xff0c;社区用户不断创造出令人耳目一新的项目&#xff0c;从灵感萌发到落地实践&#xff0c;每一个都充满智慧与价值。“与书生共创”将陆续推出一系列文章&#xff0c;分享这些项目背后的故事与经验。欢迎订阅并积极投稿&#xff0c;一起分享经验与成…...

【性能调优系列】深入解析火焰图:从基础阅读到性能优化实战

博客目录 一、火焰图基础&#xff1a;结构与阅读方法二、深入分析火焰图&#xff1a;关键观察点与性能瓶颈识别1. 识别最宽的函数块2. HTTP 请求处理分析3. 数据库操作分析4. 业务逻辑分析 三、性能优化实战&#xff1a;从火焰图到解决方案1. 线程池性能优化2. 数据库访问优化3…...

Docker 与容器技术的未来:从 OCI 标准到 eBPF 的演进

Docker 的出现无疑是云计算发展史上的一个里程碑。它以其直观的打包、分发和运行方式,极大地简化了应用程序的部署和管理,从而推动了微服务架构和 DevOps 文化的普及。然而,容器技术的未来并非仅仅局限于 Docker,它正朝着更深层次的标准化和更底层的操作系统内核创新方向演…...

PLC远程控制网关支持多塘口水环境数据边缘计算与远程安全传输的配置指南

一、项目背景 渔业养殖是关系到我国食物安全和海洋经济发展的重要产业&#xff0c;随着科技的不断进步&#xff0c;传统的养殖模式面临着诸多挑战&#xff0c;如养殖环境复杂、水质变化难以实时监测、设备运行状态不稳定等&#xff0c;这些问题不仅增加了养殖成本&#xff0c;还…...

3.3 HarmonyOS NEXT原子化服务开发:卡片设计、轻量部署与场景化编排实战

HarmonyOS NEXT原子化服务开发&#xff1a;卡片设计、轻量部署与场景化编排实战 在HarmonyOS NEXT的全场景生态中&#xff0c;原子化服务作为"设备即服务"理念的核心载体&#xff0c;通过免安装、跨设备流转的轻量化形态&#xff0c;重新定义了用户与服务的交互方式…...

C++11 中 final 和 override 从入门到精通

文章目录 一、引言二、final 关键字2.1 final 关键字的基本概念2.2 final 关键字的语法2.3 final 关键字的使用示例2.3.1 防止类被继承2.3.2 防止虚函数被重写 2.4 final 关键字的使用场景2.5 final 关键字的注意事项 三、override 关键字3.1 override 关键字的基本概念3.2 ove…...

跨多个微服务使用 Redis 共享数据时,如何管理数据一致性?

在跨多个微服务使用 Redis 共享数据时&#xff0c;管理数据一致性是一个复杂但至关重要的问题。Redis 本身提供的原子操作和一些数据结构可以提供帮助&#xff0c;但大部分一致性保障需要应用层面的设计和策略。 首先要明确一点&#xff1a;在分布式系统中&#xff0c;强一致性…...

Linux网络——socket网络通信udp

文章目录 UDP通信基础UDP的特点 Linux下UDP通信核心步骤创建UDP套接字绑定本地地址&#xff08;可选&#xff09;发送数据函数&#xff1a;sendto()函数原型参数详解典型使用示例 接收数据函数&#xff1a;recvfrom()函数原型参数详解返回值典型使用示例 关键设计原因无连接特性…...

大数据-275 Spark MLib - 基础介绍 机器学习算法 集成学习 随机森林 Bagging Boosting

点一下关注吧&#xff01;&#xff01;&#xff01;非常感谢&#xff01;&#xff01;持续更新&#xff01;&#xff01;&#xff01; 大模型篇章已经开始&#xff01; 目前已经更新到了第 22 篇&#xff1a;大语言模型 22 - MCP 自动操作 FigmaCursor 自动设计原型 Java篇开…...

大模型微调技术全景图:从全量更新到参数高效适配

在预训练大语言模型&#xff08;LLM&#xff09;展现出惊人能力之后&#xff0c;如何让这些“通才”模型蜕变为特定领域的“专家”&#xff1f;微调&#xff08;Fine-Tuning&#xff09;正是解锁这一潜力的核心技术。本文将深入解析主流微调技术&#xff0c;助你找到最适合任务…...

c++ chrono头文件含义

在C中&#xff0c;<chrono> 是一个标准库头文件&#xff0c;用于处理时间相关的操作&#xff0c;包括时间点、时间间隔和时钟。它提供了一套强大的时间处理功能&#xff0c;支持高精度的时间测量、时间间隔的计算以及时间点的表示。 1. <chrono> 的主要功能 <…...

git互联GitHub 使用教程

一、下载git Git 公司 右键 git config --global user.name "name" git config --global user.email "email" ssh-keygen -t rsa -C email &#xff1a;生成的ssh密钥需要到github 网站中保存ssh 二、GitHub新建repository 三、本地git互联GitHub 找…...

Python爬虫与Java爬虫深度对比:从原理到实战案例解析

在当今数据驱动的时代,网络爬虫技术已成为获取和分析网络数据的重要手段。作为两种最流行的爬虫开发语言,Python和Java各有其独特的优势和适用场景。本文将全面对比Python爬虫与Java爬虫的核心差异,并通过实际代码示例展示它们的具体实现方式,帮助开发者根据项目需求做出合…...

汇编语言综合程序设计:子程序、分支与循环深度解析

本文将通过一个完整的控制台计算器案例&#xff0c;深入探讨汇编语言中子程序、分支结构和循环结构的综合应用&#xff0c;展示模块化编程、输入输出处理和算法实现的核心技术。 一、模块化编程架构设计 1. 系统架构规划 Calculator System ├── main.asm (主程序)…...

SpringBoot+Mysql实现的停车场收费小程序系统+文档

&#x1f497;博主介绍&#x1f497;&#xff1a;✌在职Java研发工程师、专注于程序设计、源码分享、技术交流、专注于Java技术领域和毕业设计✌ 温馨提示&#xff1a;文末有 CSDN 平台官方提供的老师 Wechat / QQ 名片 :) Java精品实战案例《700套》 2025最新毕业设计选题推荐…...

面向对象进阶 | 深入探究 Java 静态成员与继承体系

个人主页 文章专栏 文章目录 个人主页文章专栏 一、static&#xff08;静态&#xff09;1.static 静态变量代码展示内存图 2.static 静态方法工具类&#xff1a;练习&#xff1a; 3.static注意事项4.重新认识main方法 二、继承1.继承概述2.继承的特点3.子类到底能继承父类中的…...

人脸识别技术成为时代需求,视频智能分析网关视频监控系统中AI算法的应用

一、应用背景&#xff1a;时代需求与技术革新的双重驱动​ 1&#xff09;传统安防系统的困境​&#xff1a;传统监控系统依赖人工逐帧筛查海量视频&#xff0c;在人流密集场所极易漏检&#xff0c;且缺乏实时锁定和主动预警能力&#xff0c;面对突发安全事件响应迟缓。​ 2&a…...

青岛国瑞数据采集网关软件平台:工业互联的智能基石——安全、高效、开放,驱动企业数字化转型

一、产品定位&#xff1a;工业数据的智能枢纽​​ 青岛国瑞数据采集网关软件平台&#xff0c;以“连接万物、赋能智能”为核心理念&#xff0c;专为工业场景打造&#xff0c;解决设备互联、数据互通、业务融合的核心痛点。无需深奥技术背景&#xff0c;通过极简配置&#xff0c…...

Git的由来与应用详解:从Linux内核到现代开发的革命性工具

1. Git的诞生背景与历史 1.1 Linux内核开发的困境 1991年,Linus Torvalds创建了开源的Linux操作系统。随着Linux的不断发展壮大,全球各地的志愿者纷纷参与到Linux内核的开发中。然而,在2002年之前,Linux内核的代码管理却处于一种原始状态——世界各地的开发者通过diff方式…...