提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2024-05-16 10:10:52.250|阅读 17 次
概述:本文主要介绍如何使用DevExpress组件中的Spreadsheet Document API、Spreadsheet控件从CRTX模板中导入图表设置,欢迎下载最新版组件体验!
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
DevExpress WPF 拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过DevExpress WPF控件来实现。
在v23.2版本周期中,DevExpress引入了一系列电子表格图表控件增强功能,在这篇文章中,我们将解释如何将现有的Excel图表模板(.crtx文件)应用于生成的图表对象。
DevExpress技术交流群10:532598169 欢迎一起进群讨论
CRTX是一种描述图表内容的特殊文件格式,它是一个XML文件包,用于存储颜色、轴、序列、网格线、类别、图例、文本和其他图表设置/选项。您可以将自定义图表布局保存为Microsoft Excel、Outlook、PowerPoint或Word中的图表模板文件(.crtx)。当您单击图表并为图表模板文件指定名称/位置时,选择Save as Template命令。保存后,您可以在不同的机器/应用程序之间共享模板,来应用您设计的图表外观。
DevExpress用新的方法扩展了Spreadsheet Document API,允许用户从图表模板文件中导入和应用图标设置。AddFromTemplate方法从模板创建图表,LoadTemplate方法将模板设置应用于现有的图表。这个新功能允许您使用图表(保存为模板)作为其他类似图表的基础,或者将预定义的图表样式应用于文档中的所有图表。
下面的示例创建了两个图表,并使用LoadTemplate和AddFromTemplate方法应用存储在模板中的设置。
// ... spreadsheetControl1.LoadDocument("Document.xlsx"); IWorkbook workbook = spreadsheetControl1.Document; workbook.Worksheets.ActiveWorksheet = workbook.Worksheets["Sheet2"]; // Create a chart, bind it to data, and locate in a Worksheet. DevExpress.Spreadsheet.Charts.Chart chartProductSales = spreadsheetControl1.ActiveWorksheet.Charts.Add(ChartType.ColumnClustered); chartProductSales.TopLeftCell = spreadsheetControl1.ActiveWorksheet.Cells["F1"]; chartProductSales.BottomRightCell = spreadsheetControl1.ActiveWorksheet.Cells["K12"]; chartProductSales.Series.Add(spreadsheetControl1.ActiveWorksheet["A1:A4"], spreadsheetControl1.ActiveWorksheet["B1:B4"]); // Specify title settings. chartProductSales.Title.SetValue("Sales by Products"); chartProductSales.Title.Font.Italic = true; // Create a chart, bind it to data, and locate in a Worksheet. DevExpress.Spreadsheet.Charts.Chart chartSalesbyRegion = spreadsheetControl1.ActiveWorksheet.Charts.Add(ChartType.ColumnClustered); chartSalesbyRegion.TopLeftCell = spreadsheetControl1.ActiveWorksheet.Cells["F14"]; chartSalesbyRegion.BottomRightCell = spreadsheetControl1.ActiveWorksheet.Cells["K26"]; chartSalesbyRegion.Series.Add(spreadsheetControl1.ActiveWorksheet["C1:C10"], spreadsheetControl1.ActiveWorksheet["D1:D10"]); // Specify title settings. chartSalesbyRegion.Title.SetValue("Sales by Region"); chartSalesbyRegion.Title.Font.Italic = true;
生成的图表将呈现如下:
调用LoadTemplate()方法将图表模板设置应用于生成的图表:
using (FileStream stream = new FileStream("Chart1.crtx", FileMode.Open)) { foreach (var chart in spreadsheetControl1.ActiveWorksheet.Charts) { stream.Position = 0; chart.LoadTemplate(stream); } }
输出如下所示:
要使用AddFromTemplate()实现相同的结果,请执行以下代码片段。在这种情况下,您不需要在应用模板中的设置之前创建图表对象:
// ... spreadsheetControl1.LoadDocument("Document.xlsx"); IWorkbook workbook = spreadsheetControl1.Document; workbook.Worksheets.ActiveWorksheet = workbook.Worksheets["Sheet2"]; using (FileStream stream = new FileStream("Chart1.crtx", FileMode.Open)){ stream.Position = 0; // Create a new chart object, bind it to data, and apply template setitngs. var chartProductSales = spreadsheetControl1.ActiveWorksheet.Charts.AddFromTemplate(stream, spreadsheetControl1.ActiveWorksheet["A1:B4"]); // Locate the chart in a Worksheet. spreadsheetControl1.ActiveWorksheet.Charts[0].TopLeftCell = spreadsheetControl1.ActiveWorksheet.Cells["F1"]; spreadsheetControl1.ActiveWorksheet.Charts[0].BottomRightCell = spreadsheetControl1.ActiveWorksheet.Cells["K12"]; // Specify title settings. spreadsheetControl1.ActiveWorksheet.Charts[0].Title.SetValue("Sales by Product"); spreadsheetControl1.ActiveWorksheet.Charts[0].Title.Font.Italic = true; stream.Position = 0; // Create a new chart object, bind it to data, and apply template setitngs. var chartSalesbyRegion = spreadsheetControl1.ActiveWorksheet.Charts.AddFromTemplate(stream, spreadsheetControl1.ActiveWorksheet["C1:D10"]); // Locate the chart in a Worksheet. spreadsheetControl1.ActiveWorksheet.Charts[1].TopLeftCell = spreadsheetControl1.ActiveWorksheet.Cells["F14"]; spreadsheetControl1.ActiveWorksheet.Charts[1].BottomRightCell = spreadsheetControl1.ActiveWorksheet.Cells["K26"]; // Specify title settings. spreadsheetControl1.ActiveWorksheet.Charts[1].Title.SetValue("Sales by Region"); spreadsheetControl1.ActiveWorksheet.Charts[1].Title.Font.Italic = true; }
新方法简化了图表生成过程——消除了每个图表对象的重复。
注意:新API附带了与图表类型和数据相关的限制,更多信息请参考方法描述:
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@cahobeh.cn
文章转载自:慧都网本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
行业领先的界面控件开发包,帮助企业构建卓越应用!
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
DevExpress WPF Subscription高效MVVM开发模式,WPF界面解决方案首选工具,帮助企业实现酷炫动效界面。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@cahobeh.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢