在较早期的报表套打的时候,我倾向于使用LODOP的ActiveX进行报表的打印或者套打,BS效果还是很不错的。之前利用它在Winform程序里面实现信封套打功能,详细参考《基于信封套打以及批量打印的实现过程》,虽然功能能够完美实现,不过由于还需要附带一个不是百分百整合一起的插件,还是有点另类的,虽然只是第一次使用的时候,需要安装一次插件即可。本篇随笔介绍一下如何旧瓶装新酒,使用FastReport报表工具来实现信封的套打及批量打印的功能。

1、信封套打及批量打印功能的回顾

首先我们要有一些特制的信封或者普通信封,这样才能基于这个基础上进行套打,把邮政编码、地址和联系人等信息打印上去。

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

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

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

2、使用FastReport报表工具来实现信封的套打及批量打印

首先我们模仿上面的工具界面来做一个新的Winform程序,这次使用DevExpress界面来做,得到界面如下所示。

功能和前面软件的基本一样,只是界面有所变化差异而已。

现在我们来聊聊如何FastReport报表工具来实现套打的处理,这样我们就可以使用它来进行信封的打印了。

首先,和前面随笔《使用FastReport报表工具生成报表PDF文档》/《使用FastReport报表工具生成标签打印文档》等文章介绍的一样,我们套打一样需要准备好一个报表模板,然后基于这个基础上进行套打处理。

套打的原理,就是预设一个图片和报表的大小,以及放置一些需要打印的内容,预设的图片一般不需要打印出来,这样其他内容打印在特定的纸张上就实现了证书、信封、发票、快递单等的打印了。

而使用FastReport报表工具,我们可以对报表模板里面的元素的位置、大小、样式等进行一定的调整,以适应我们具体的报表需要,基于这个模式我们先设计一个FastReport报表模板,如下所示。

以上模板的设置,主要就是注意定义好几个参数,并将参数和具体的展示控件进行绑定,并加入一个图片作为不打印的元素即可。

报表在运行时刻可以进行模板的调整,如下是报表的【打印设计】界面。

我们可以利用FastReport提供的报表设计工具进行元素位置、大小、样式等方面的调整。这样就可以给客户很大的灵活性进行处理。

报表打印的操作如下代码所示。

  1. /// <summary>
  2. /// 报表打印测试
  3. /// </summary>
  4. private void btnPrintTest_Click(object sender, EventArgs e)
  5. {
  6. if(this.txtAddress.Text.Length == )
  7. {
  8. MessageDxUtil.ShowTips("请输入地址");
  9. this.txtAddress.Focus();
  10. return;
  11. }
  12. else if (this.txtReceiver.Text.Length == )
  13. {
  14. MessageDxUtil.ShowTips("请输入收件人");
  15. this.txtReceiver.Focus();
  16. return;
  17. }
  18.  
  19. FrmReportPreview dlg = new FrmReportPreview();
  20. var report = dlg.Report;
  21.  
  22. //加载报表
  23. var reportFile = Path.Combine(baseDir, "Report/信封报表.frx");
  24. report.Load(reportFile);
  25.  
  26. //绑定数据源
  27. //定义参数和数据格式
  28. var dict = new Dictionary<string, object>();
  29.  
  30. var zipCode = txtPostCode.Text.Trim().PadRight(, ' ').ToCharArray();
  31. dict.Add("C1", zipCode[]);
  32. dict.Add("C2", zipCode[]);
  33. dict.Add("C3", zipCode[]);
  34. dict.Add("C4", zipCode[]);
  35. dict.Add("C5", zipCode[]);
  36. dict.Add("C6", zipCode[]);
  37. dict.Add("Address", this.txtAddress.Text.Trim());
  38.  
  39. var Recipient = this.txtReceiver.Text.Trim();
  40. if(!Recipient.EndsWith("收"))
  41. {
  42. Recipient += "收";
  43. }
  44. dict.Add("Recipient", Recipient);
  45.  
  46. //刷新数据源
  47. foreach (string key in dict.Keys)
  48. {
  49. report.SetParameterValue(key, dict[key]);
  50. }
  51.  
  52. dlg.ShowDialog();
  53. }

以上打印处理的时候,会调用打印预览界面展示数据,如下界面所示。

报表打印设计处理,和打印测试差不多,也需要绑定数据,方便预览,代码如下所示。

  1. /// <summary>
  2. /// 报表打印设计
  3. /// </summary>
  4. private void btnPrintDesign_Click(object sender, EventArgs e)
  5. {
  6. FrmReportDesign dlg = new FrmReportDesign();
  7. var report = dlg.Report;
  8.  
  9. //加载报表文件
  10. var reportFile = Path.Combine(baseDir, "Report/信封报表.frx");
  11. report.Load(reportFile);
  12.  
  13. //绑定数据源
  14. //定义参数和数据格式
  15. var dict = new Dictionary<string, object>();
  16.  
  17. var zipCode = txtPostCode.Text.Trim().PadRight(, ' ').ToCharArray();
  18. dict.Add("C1", zipCode[]);
  19. dict.Add("C2", zipCode[]);
  20. dict.Add("C3", zipCode[]);
  21. dict.Add("C4", zipCode[]);
  22. dict.Add("C5", zipCode[]);
  23. dict.Add("C6", zipCode[]);
  24. dict.Add("Address", this.txtAddress.Text.Trim());
  25.  
  26. var Recipient = this.txtReceiver.Text.Trim();
  27. if (!Recipient.EndsWith("收"))
  28. {
  29. Recipient += "收";
  30. }
  31. dict.Add("Recipient", Recipient);
  32.  
  33. //刷新数据源
  34. foreach (string key in dict.Keys)
  35. {
  36. report.SetParameterValue(key, dict[key]);
  37. }
  38.  
  39. dlg.ShowDialog();
  40. }

信封打印,我们不需要一个个确认打印对话框,指定那个PrintDialog为False即可。信封的批量打印代码如下所示。

  1. /// <summary>
  2. /// 信封批量打印操作
  3. /// </summary>
  4. private void btnBatchPrint_Click(object sender, EventArgs e)
  5. {
  6. if(dtImport == null || dtImport.Rows.Count == )
  7. {
  8. MessageDxUtil.ShowTips("没有打印数据");
  9. return;
  10. }
  11.  
  12. FastReport.Report report = new FastReport.Report();
  13. FastReport.Utils.Res.LocaleFolder = Path.Combine(baseDir, "L18N");
  14. var file = FastReport.Utils.Res.LocaleFolder + @"Chinese (Simplified).frl";
  15. FastReport.Utils.Res.LoadLocale(file);
  16.  
  17. //加载报表
  18. var reportFile = Path.Combine(baseDir, "Report/信封报表.frx");
  19. report.Load(reportFile);
  20.  
  21. SplashScreenHelper.Show(typeof(FrmWaitForm));
  22. SplashScreenHelper.SetCaption("正在打印...");
  23. int total = dtImport.Rows.Count;
  24. int i = ;
  25. foreach(DataRow dr in dtImport.Rows)
  26. {
  27. SplashScreenHelper.SetDescription(string.Format("正在打印...任务 {0} / {1}", i++, total));
  28.  
  29. //绑定数据源
  30. //定义参数和数据格式
  31. var dict = new Dictionary<string, object>();
  32.  
  33. var zipCode = dr["邮编"].ToString().Trim().PadRight(, ' ').ToCharArray();
  34. dict.Add("C1", zipCode[]);
  35. dict.Add("C2", zipCode[]);
  36. dict.Add("C3", zipCode[]);
  37. dict.Add("C4", zipCode[]);
  38. dict.Add("C5", zipCode[]);
  39. dict.Add("C6", zipCode[]);
  40. dict.Add("Address", dr["地址"].ToString().Trim());
  41.  
  42. var Recipient = dr["收件人"].ToString().Trim();
  43. if (!Recipient.EndsWith("收"))
  44. {
  45. Recipient += "收";
  46. }
  47. dict.Add("Recipient", Recipient);
  48.  
  49. //刷新数据源
  50. foreach (string key in dict.Keys)
  51. {
  52. report.SetParameterValue(key, dict[key]);
  53. }
  54.  
  55. report.PrintSettings.ShowDialog = false;
  56. report.Print();
  57.  
  58. Thread.Sleep();
  59. }
  60. SplashScreenHelper.SetCaption("打印完成!");
  61. SplashScreenHelper.SetDescription(string.Format("完成全部打印,共打印【{0}】份!", total));
  62. Thread.Sleep();
  63. SplashScreenHelper.Close();
  64. }

我们使用该批量模式测试打印几个信封,效果如下所示。

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

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

使用FastReport报表工具实现信封套打功能的更多相关文章

  1. 使用FastReport报表工具生成报表PDF文档

    在我们开发某个系统的时候,客户总会提出一些特定的报表需求,固定的报表格式符合他们的业务处理需要,也贴合他们的工作场景,因此我们尽可能做出符合他们实际需要的报表,这样我们的系统会得到更好的认同感.本篇随 ...

  2. 使用FastReport报表工具生成标签打印文档

    在我们实际开发报表的时候,我们需要按一定的业务规则组织好报表的模板设计,让报表尽可能的贴近实际的需求,在之前的随笔中<使用FastReport报表工具生成报表PDF文档>介绍了FastRe ...

  3. 使用FastReport报表工具生成图片格式文档

    之前我在随笔<使用FastReport报表工具生成报表PDF文档>介绍过使用FastReport.Net来根据报表模板进行生成PDF,以及随笔<使用FastReport报表工具生成标 ...

  4. Grid++Report报表工具C/S实战篇(五)

    一.课程介绍 本次分享课程属于<C#高级编程实战技能开发宝典课程系列>中的第五部分,阿笨后续会计划将实际项目中的一些比较实用的关于C#高级编程的技巧分享出来给大家进行学习,不断的收集.整理 ...

  5. 使用FastReport.net 报表在网页上实现打印功能

    这些年的工作当中,最早是在8年前接触到FastReport这个报表工具,从名字上来看,直译过来就是快速报表,正所谓天下武功,唯快不破,FastReport报表早些年确实是制作报表的不二之选,8年前的工 ...

  6. 报表工具ActiveReports开发实例——物联网智能供水云平台

    一.公司简介 山西汾西电子科技股份有限公司(以下简称:汾西电子)是经中国船舶重工集团批准,在原汾西重工电子科技公司基础上重组的专业从事智能电能表.水表.热量表及电动汽车充电设备研发生产的高科技公司. ...

  7. 报表工具为什么我推荐用Smartbi,数据分析师和初学者都能灵活运用

    在很多人入门数据分析师或者投身大数据行业的时候,肯定会接触到报表工具,很多人这时候就会去使用一些Excel插件的报表工具,但是很多报表工具都是需要下载一系列的软件,配置各种复杂的环境.尤其是一些数据分 ...

  8. 国内BI工具/报表工具厂商简介

    v\:* {behavior:url(#default#VML);} o\:* {behavior:url(#default#VML);} w\:* {behavior:url(#default#VM ...

  9. FastReport报表设计(仔细看)

    FastReport报表设计 2011-06-16 16:56:19|  分类: 系统开发|举报|字号 订阅     下载LOFTER我的照片书  |     目录 5.1 前言 5.2 基本概念及操 ...

随机推荐

  1. 数据库系统(六)---MySQL语句及存储过程

    一.DDL.DML.DCL常用语句 1.DDL(Data Definition Language)数据库定义语言 (1)数据库模式定义 #创建数据库 create database if exsite ...

  2. ElasticSearch 中文分词插件ik 的使用

    下载 IK 的版本要与 Elasticsearch 的版本一致,因此下载 7.1.0 版本. 安装 1.中文分词插件下载地址:https://github.com/medcl/elasticsearc ...

  3. C语言I博客作业04

    这个作业属于那个课程 C语言程序设计II 这个作业要求在哪里 https://edu.cnblogs.com/campus/zswxy/SE2019-1/homework/9773 我在这个课程的目标 ...

  4. 使用Typescript重构axios(二十三)——添加withCredentials属性

    0. 系列文章 1.使用Typescript重构axios(一)--写在最前面 2.使用Typescript重构axios(二)--项目起手,跑通流程 3.使用Typescript重构axios(三) ...

  5. P3521 [POI2011]ROT-Tree Rotations(线段树合并)

    一句话题意(不用我改了.....):给一棵n(1≤n≤200000个叶子的二叉树,可以交换每个点的左右子树,要求前序遍历叶子的逆序对最少. ......这题输入很神烦呐... 给你一棵二叉树的dfs序 ...

  6. windows下载安装swoole的方法

    windows下载安装swoole的方法先安装Cygwin 选择163镜像(速度非常快) add url http://mirrors.163.com/cygwin/ 然后安装gcc php pcre ...

  7. nsq (三) 消息传输的可靠性和持久化[二]diskqueue

    上一篇主要说了一下nsq是如何保证消息被消费端成功消费,大概提了一下消息的持久化,--mem-queue-size 设置为 0,所有的消息将会存储到磁盘. 总有人说nsq的持久化问题,消除疑虑的方法就 ...

  8. Vue学习笔记:Vue组件的核心概念(下)

    1.双向绑定和单向数据流: 本质上还是单向数据流 视图<——>数据 v-model:仅仅是一个简写,用更少代码去实现功能. 自定义事件 .sync 修饰符 2.虚拟DOM及KEY属性作用 ...

  9. Java自动生成数据

    最近在造数据库中的表数据,写了些数据生成类 可以随机生成姓名.性别,民族,出生日期,身份证号,手机号,邮箱,身高,文化程度,地址,单位,日期时间,编码等 package com.util.create ...

  10. 【前端VUE】【后端SSM】 记录一次多条件查询状态下加载极慢的解决思路和解决方案

    最近在开发一个Online Judge系统,其中有一个“挑战模式”模块,如图所示 由于是第一次使用ECharts做开发,所以完成整个模块的过程也是边写边学了,记录一下问题: 遇到的问题:在最开始进行测 ...