如何在打印/导出控件时设置纸张格式并将自定义信息添加到报告中

2024-06-12 14:04

本文主要是介绍如何在打印/导出控件时设置纸张格式并将自定义信息添加到报告中,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

用于WinForms的DevExpress报告控件允许您自定义纸张格式、方向,并将自定义信息添加到报告中。请注意,以下方法适用于实现可打印接口的控件(例如,XtraGrid、XtraPivotGrid、Xtra Scheduler、XtraTreeList、XtraCharts、Layout Control、XtraVerticalGrid等)。

启动VS2019并创建一个新的Windows窗体应用程序或打开一个现有的应用程序。然后,运行“工具箱”并将实现IPrintable接口的所需控件拖放到窗体上。
在这里插入图片描述

Customize Print Options at Runtime

运行时自定义打印选项
IPrintable界面允许您自定义打印设置,并使用PrintableComponentLink打印控件。以下代码演示如何创建PrintableComponentLink,并将控件分配给其PrintableComponentLinkBase。组件属性,调整其打印设置,然后打印控件。

using DevExpress.LookAndFeel;
using DevExpress.XtraEditors;
using DevExpress.XtraPrinting;
using DevExpress.XtraPrinting.Links;
using DevExpress.XtraPrintingLinks;
//...public partial class Form1 : XtraForm {
//...private void gridControl1_Load(object sender, EventArgs e) {PreviewPrintableComponent(gridControl1, gridControl1.LookAndFeel);}void PreviewPrintableComponent(IPrintable component, UserLookAndFeel lookAndFeel) {// Create a link that will print a control.PrintableComponentLink link = new PrintableComponentLink() {PrintingSystemBase = new PrintingSystemBase(),Component = component,Landscape = true,PaperKind = PaperKind.A5,Margins = new Margins(20,20,20,20)};// Show the report.link.ShowRibbonPreview(lookAndFeel);}
}

Add Custom Information to a Report at Runtime

在运行时向报表添加自定义信息
创建报表页眉或页脚以向报表中添加自定义信息。订阅CreateReportHeader事件以添加报告头,如下所示。

using DevExpress.LookAndFeel;
using DevExpress.XtraEditors;
using DevExpress.XtraPrinting;
using DevExpress.XtraPrinting.Links;
using DevExpress.XtraPrintingLinks;
//...public partial class Form1 : XtraForm {
//...       void PreviewPrintableComponent(IPrintable component, UserLookAndFeel lookAndFeel) {// Create a link that will print a control.//...// Subscribe to the CreateReportHeaderArea event used to generate the report header.link.CreateReportHeaderArea += link_CreateReportHeaderArea;// Show the report.link.ShowRibbonPreview(lookAndFeel);}
}

如下方式处理CreateReportHeader事件。

using System.Drawing;
using DevExpress.XtraPrinting;private void link_CreateReportHeaderArea(object sender, 
CreateAreaEventArgs e) {string reportHeader = "Categories Report";e.Graph.StringFormat = new BrickStringFormat(StringAlignment.Center);e.Graph.Font = new Font("Tahoma", 14, FontStyle.Bold);RectangleF rec = new RectangleF(0, 0, e.Graph.ClientPageSize.Width, 50);e.Graph.DrawString(reportHeader, Color.Black, rec, BorderSide.None);
}

下图显示了包含指定打印选项和其他自定义信息的结果报告。
在这里插入图片描述

Export a Report to the Specified Format at Runtime

在运行时将报告导出为指定格式
除了“ Print Preview”窗口中提供的导出功能外,您还可以通过PrintableComponentLink对象导出报告。

PrintableComponentLink link = new PrintableComponentLink();
link.ExportToPdf(@"c:\gridcontrol.pdf"); 

这篇关于如何在打印/导出控件时设置纸张格式并将自定义信息添加到报告中的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

linux hostname设置全过程

《linuxhostname设置全过程》:本文主要介绍linuxhostname设置全过程,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录查询hostname设置步骤其它相关点hostid/etc/hostsEDChina编程A工具license破解注意事项总结以RHE

Python设置Cookie永不超时的详细指南

《Python设置Cookie永不超时的详细指南》Cookie是一种存储在用户浏览器中的小型数据片段,用于记录用户的登录状态、偏好设置等信息,下面小编就来和大家详细讲讲Python如何设置Cookie... 目录一、Cookie的作用与重要性二、Cookie过期的原因三、实现Cookie永不超时的方法(一)

Mysql常见的SQL语句格式及实用技巧

《Mysql常见的SQL语句格式及实用技巧》本文系统梳理MySQL常见SQL语句格式,涵盖数据库与表的创建、删除、修改、查询操作,以及记录增删改查和多表关联等高级查询,同时提供索引优化、事务处理、临时... 目录一、常用语法汇总二、示例1.数据库操作2.表操作3.记录操作 4.高级查询三、实用技巧一、常用语

Java实现自定义table宽高的示例代码

《Java实现自定义table宽高的示例代码》在桌面应用、管理系统乃至报表工具中,表格(JTable)作为最常用的数据展示组件,不仅承载对数据的增删改查,还需要配合布局与视觉需求,而JavaSwing... 目录一、项目背景详细介绍二、项目需求详细介绍三、相关技术详细介绍四、实现思路详细介绍五、完整实现代码

一文详解Java Stream的sorted自定义排序

《一文详解JavaStream的sorted自定义排序》Javastream中的sorted方法是用于对流中的元素进行排序的方法,它可以接受一个comparator参数,用于指定排序规则,sorte... 目录一、sorted 操作的基础原理二、自定义排序的实现方式1. Comparator 接口的 Lam

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Qt 设置软件版本信息的实现

《Qt设置软件版本信息的实现》本文介绍了Qt项目中设置版本信息的三种常用方法,包括.pro文件和version.rc配置、CMakeLists.txt与version.h.in结合,具有一定的参考... 目录在运行程序期间设置版本信息可以参考VS在 QT 中设置软件版本信息的几种方法方法一:通过 .pro

Python打印对象所有属性和值的方法小结

《Python打印对象所有属性和值的方法小结》在Python开发过程中,调试代码时经常需要查看对象的当前状态,也就是对象的所有属性和对应的值,然而,Python并没有像PHP的print_r那样直接提... 目录python中打印对象所有属性和值的方法实现步骤1. 使用vars()和pprint()2. 使

PostgreSQL 默认隔离级别的设置

《PostgreSQL默认隔离级别的设置》PostgreSQL的默认事务隔离级别是读已提交,这是其事务处理系统的基础行为模式,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一 默认隔离级别概述1.1 默认设置1.2 各版本一致性二 读已提交的特性2.1 行为特征2.2

一文详解MySQL如何设置自动备份任务

《一文详解MySQL如何设置自动备份任务》设置自动备份任务可以确保你的数据库定期备份,防止数据丢失,下面我们就来详细介绍一下如何使用Bash脚本和Cron任务在Linux系统上设置MySQL数据库的自... 目录1. 编写备份脚本1.1 创建并编辑备份脚本1.2 给予脚本执行权限2. 设置 Cron 任务2