使用FastReport报表工具实现信封套打功能
在较早期的报表套打的时候,我倾向于使用LODOP的ActiveX进行报表的打印或者套打,BS效果还是很不错的。之前利用它在Winform程序里面实现信封套打功能,详细参考《基于信封套打以及批量打印的实现过程》,虽然功能能够完美实现,不过由于还需要附带一个不是百分百整合一起的插件,还是有点另类的,虽然只是第一次使用的时候,需要安装一次插件即可。本篇随笔介绍一下如何旧瓶装新酒,使用FastReport报表工具来实现信封的套打及批量打印的功能。
1、信封套打及批量打印功能的回顾
首先我们要有一些特制的信封或者普通信封,这样才能基于这个基础上进行套打,把邮政编码、地址和联系人等信息打印上去。

然后你需要有一个打印设备,我这里采用了一个佳能的喷墨打印机(当然其他的也没问题)。

其次我们开发一个工具来快速实现数据的导入和批量打印,如下界面所示。

最后当然能够满足要求的打印大量的信封出来,减少我们人工干预的麻烦了。

2、使用FastReport报表工具来实现信封的套打及批量打印
首先我们模仿上面的工具界面来做一个新的Winform程序,这次使用DevExpress界面来做,得到界面如下所示。

功能和前面软件的基本一样,只是界面有所变化差异而已。
现在我们来聊聊如何FastReport报表工具来实现套打的处理,这样我们就可以使用它来进行信封的打印了。
首先,和前面随笔《使用FastReport报表工具生成报表PDF文档》/《使用FastReport报表工具生成标签打印文档》等文章介绍的一样,我们套打一样需要准备好一个报表模板,然后基于这个基础上进行套打处理。
套打的原理,就是预设一个图片和报表的大小,以及放置一些需要打印的内容,预设的图片一般不需要打印出来,这样其他内容打印在特定的纸张上就实现了证书、信封、发票、快递单等的打印了。
而使用FastReport报表工具,我们可以对报表模板里面的元素的位置、大小、样式等进行一定的调整,以适应我们具体的报表需要,基于这个模式我们先设计一个FastReport报表模板,如下所示。

以上模板的设置,主要就是注意定义好几个参数,并将参数和具体的展示控件进行绑定,并加入一个图片作为不打印的元素即可。
报表在运行时刻可以进行模板的调整,如下是报表的【打印设计】界面。

我们可以利用FastReport提供的报表设计工具进行元素位置、大小、样式等方面的调整。这样就可以给客户很大的灵活性进行处理。
报表打印的操作如下代码所示。
/// <summary>
/// 报表打印测试
/// </summary>
private void btnPrintTest_Click(object sender, EventArgs e)
{
if(this.txtAddress.Text.Length == )
{
MessageDxUtil.ShowTips("请输入地址");
this.txtAddress.Focus();
return;
}
else if (this.txtReceiver.Text.Length == )
{
MessageDxUtil.ShowTips("请输入收件人");
this.txtReceiver.Focus();
return;
} FrmReportPreview dlg = new FrmReportPreview();
var report = dlg.Report; //加载报表
var reportFile = Path.Combine(baseDir, "Report/信封报表.frx");
report.Load(reportFile); //绑定数据源
//定义参数和数据格式
var dict = new Dictionary<string, object>(); var zipCode = txtPostCode.Text.Trim().PadRight(, ' ').ToCharArray();
dict.Add("C1", zipCode[]);
dict.Add("C2", zipCode[]);
dict.Add("C3", zipCode[]);
dict.Add("C4", zipCode[]);
dict.Add("C5", zipCode[]);
dict.Add("C6", zipCode[]);
dict.Add("Address", this.txtAddress.Text.Trim()); var Recipient = this.txtReceiver.Text.Trim();
if(!Recipient.EndsWith("收"))
{
Recipient += "收";
}
dict.Add("Recipient", Recipient); //刷新数据源
foreach (string key in dict.Keys)
{
report.SetParameterValue(key, dict[key]);
} dlg.ShowDialog();
}
以上打印处理的时候,会调用打印预览界面展示数据,如下界面所示。

报表打印设计处理,和打印测试差不多,也需要绑定数据,方便预览,代码如下所示。
/// <summary>
/// 报表打印设计
/// </summary>
private void btnPrintDesign_Click(object sender, EventArgs e)
{
FrmReportDesign dlg = new FrmReportDesign();
var report = dlg.Report; //加载报表文件
var reportFile = Path.Combine(baseDir, "Report/信封报表.frx");
report.Load(reportFile); //绑定数据源
//定义参数和数据格式
var dict = new Dictionary<string, object>(); var zipCode = txtPostCode.Text.Trim().PadRight(, ' ').ToCharArray();
dict.Add("C1", zipCode[]);
dict.Add("C2", zipCode[]);
dict.Add("C3", zipCode[]);
dict.Add("C4", zipCode[]);
dict.Add("C5", zipCode[]);
dict.Add("C6", zipCode[]);
dict.Add("Address", this.txtAddress.Text.Trim()); var Recipient = this.txtReceiver.Text.Trim();
if (!Recipient.EndsWith("收"))
{
Recipient += "收";
}
dict.Add("Recipient", Recipient); //刷新数据源
foreach (string key in dict.Keys)
{
report.SetParameterValue(key, dict[key]);
} dlg.ShowDialog();
}
信封打印,我们不需要一个个确认打印对话框,指定那个PrintDialog为False即可。信封的批量打印代码如下所示。
/// <summary>
/// 信封批量打印操作
/// </summary>
private void btnBatchPrint_Click(object sender, EventArgs e)
{
if(dtImport == null || dtImport.Rows.Count == )
{
MessageDxUtil.ShowTips("没有打印数据");
return;
} FastReport.Report report = new FastReport.Report();
FastReport.Utils.Res.LocaleFolder = Path.Combine(baseDir, "L18N");
var file = FastReport.Utils.Res.LocaleFolder + @"Chinese (Simplified).frl";
FastReport.Utils.Res.LoadLocale(file); //加载报表
var reportFile = Path.Combine(baseDir, "Report/信封报表.frx");
report.Load(reportFile); SplashScreenHelper.Show(typeof(FrmWaitForm));
SplashScreenHelper.SetCaption("正在打印...");
int total = dtImport.Rows.Count;
int i = ;
foreach(DataRow dr in dtImport.Rows)
{
SplashScreenHelper.SetDescription(string.Format("正在打印...任务 {0} / {1}", i++, total)); //绑定数据源
//定义参数和数据格式
var dict = new Dictionary<string, object>(); var zipCode = dr["邮编"].ToString().Trim().PadRight(, ' ').ToCharArray();
dict.Add("C1", zipCode[]);
dict.Add("C2", zipCode[]);
dict.Add("C3", zipCode[]);
dict.Add("C4", zipCode[]);
dict.Add("C5", zipCode[]);
dict.Add("C6", zipCode[]);
dict.Add("Address", dr["地址"].ToString().Trim()); var Recipient = dr["收件人"].ToString().Trim();
if (!Recipient.EndsWith("收"))
{
Recipient += "收";
}
dict.Add("Recipient", Recipient); //刷新数据源
foreach (string key in dict.Keys)
{
report.SetParameterValue(key, dict[key]);
} report.PrintSettings.ShowDialog = false;
report.Print(); Thread.Sleep();
}
SplashScreenHelper.SetCaption("打印完成!");
SplashScreenHelper.SetDescription(string.Format("完成全部打印,共打印【{0}】份!", total));
Thread.Sleep();
SplashScreenHelper.Close();
}
我们使用该批量模式测试打印几个信封,效果如下所示。

如果导入数据很多,那么一样和前面的软件打印效果一样,中间不需要人工接入,喝茶等着完成即可。

这个就是整合了FastReport报表工具实现信封套打功能的软件,这样整合后,软件体验性就更加完美了。

使用FastReport报表工具实现信封套打功能的更多相关文章
- 使用FastReport报表工具生成报表PDF文档
在我们开发某个系统的时候,客户总会提出一些特定的报表需求,固定的报表格式符合他们的业务处理需要,也贴合他们的工作场景,因此我们尽可能做出符合他们实际需要的报表,这样我们的系统会得到更好的认同感.本篇随 ...
- 使用FastReport报表工具生成标签打印文档
在我们实际开发报表的时候,我们需要按一定的业务规则组织好报表的模板设计,让报表尽可能的贴近实际的需求,在之前的随笔中<使用FastReport报表工具生成报表PDF文档>介绍了FastRe ...
- 使用FastReport报表工具生成图片格式文档
之前我在随笔<使用FastReport报表工具生成报表PDF文档>介绍过使用FastReport.Net来根据报表模板进行生成PDF,以及随笔<使用FastReport报表工具生成标 ...
- Grid++Report报表工具C/S实战篇(五)
一.课程介绍 本次分享课程属于<C#高级编程实战技能开发宝典课程系列>中的第五部分,阿笨后续会计划将实际项目中的一些比较实用的关于C#高级编程的技巧分享出来给大家进行学习,不断的收集.整理 ...
- 使用FastReport.net 报表在网页上实现打印功能
这些年的工作当中,最早是在8年前接触到FastReport这个报表工具,从名字上来看,直译过来就是快速报表,正所谓天下武功,唯快不破,FastReport报表早些年确实是制作报表的不二之选,8年前的工 ...
- 报表工具ActiveReports开发实例——物联网智能供水云平台
一.公司简介 山西汾西电子科技股份有限公司(以下简称:汾西电子)是经中国船舶重工集团批准,在原汾西重工电子科技公司基础上重组的专业从事智能电能表.水表.热量表及电动汽车充电设备研发生产的高科技公司. ...
- 报表工具为什么我推荐用Smartbi,数据分析师和初学者都能灵活运用
在很多人入门数据分析师或者投身大数据行业的时候,肯定会接触到报表工具,很多人这时候就会去使用一些Excel插件的报表工具,但是很多报表工具都是需要下载一系列的软件,配置各种复杂的环境.尤其是一些数据分 ...
- 国内BI工具/报表工具厂商简介
v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VM ...
- FastReport报表设计(仔细看)
FastReport报表设计 2011-06-16 16:56:19| 分类: 系统开发|举报|字号 订阅 下载LOFTER我的照片书 | 目录 5.1 前言 5.2 基本概念及操 ...
随机推荐
- requests+lxml+xpath爬取电影天堂
1.导入相应的包 import requests from lxml import etree 2.原始ur url="https://www.dytt8.net/html/gndy/dyz ...
- SpringBoot配置文件之Yml语法
一 使用 YAML 而不是 Properties YAML是 JSON 的超集,因此,它是用于指定分层配置数据的便捷格式.只要 class 路径上有SnakeYAML library,SpringAp ...
- 【MySQL】MySQL服务启动失解决方法
写在前面的话:前段时间,为了更加流畅愉快的玩PUBG,我在任务管理器中,关闭了mysqld服务.后来我在使用MySQL数据库服务的时候,发现去到MySQL安装目录下双击运行mysqld.exe(数据库 ...
- vue学习笔记-遗留问题记录
Node.js是什么?对node.js的理解 官网解释:Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行时. 这是一种通过JavaScript语言开发web服务端的东 ...
- 中小学生试卷自动生成程序--jialin大佬代码分析
结对编程代码评价 有幸和小jialin结对编程.拿到jialin的代码后. 我先是尝试用idea运行.结果报了如下错误. 无法加载主类,再尝试用eclipse运行. 好的,可以运行,那为什么用idea ...
- ArcGIS Engine连接ArcSDE SQL Server(获得所有SDE图层)
ArcSDE是ESRI公司推出的基于SDE技术的空间数据库解决方案,它是在现有的关系或对象关系型数据库管理系统的基础上进行应用扩展,可以将空间数据和非空间数据存储在目前绝大多数商用DBMS中,享受商用 ...
- iOS和macOS上的Message-ID和Mail.app深度链接
如何在iOS上通过电子邮件进行无缝的“无密码”身份验证. Apple平台上的邮件和日历集成 在macOS和iOS上查看电子邮件时,邮件会在[检测到的日期和时间]下划线 .您可以与他们互动以创建新的日历 ...
- Mybatis:配置解析
配置解析 mybatis-config.xml(Mybatis核心配置文件)深深影响了Mybatis行为的设置和属性信息. 能配置的的内容 当然,并不是所有都是我们经常使用到的,下面选择经常使用的配 ...
- [Pandas]利用Pandas处理excel数据
Python 处理excel的第三包有很多,比如XlsxWriter.xlrd&xlwt.OpenPyXL.Microsoft Excel API等,最后综合考虑选用了Pandas. Pand ...
- js中关于执行的顺序及变量存放方式的一点记录
Markdown在线编辑器 - www.MdEditor.com 1 首先关于数据类型,有基本数据类型,和引用数据类型 基本数据类型有:number,string,boolean等:引用数据类型一般指 ...