报表工具实现单据套打

实际项目开发中,很多情况会涉及到单据的打印。即在一张印刷好的空白单据上,准确无误地打印上单据的内容。用传统的报表工具,我们通常会用尺子量每一个数据区域的位置,然后在屏幕上根据尺子量出的尺寸设计每一个格子的位置,反复调试。不过,这样制作一张单据打印的报表费时费力,而且一旦单据格式发生变化,报表制作人员又要重新制作报表。

接下来,小编给大家介绍一款可以轻松搞定套打问题的爆款神器 — 润乾报表 (别问小编为什么这么热心 – 任性!!!),此神器采用底图描绘的方案来解决套打时报表绘制的问题。具体操作如下:

首先,准备扫描空白单据。

注意:扫描仪单位为像素,保证其和标准纸张大小一样,扫描分辨率一般为 72dpi。得到空白单据图片如下图:

其中发票名称、表格线、表格中的各个标题都是空白发票已经印刷好的,报表需要填写生成的是空白部分。

接下来,开始制作报表

第一步,新建空白报表,并插入背景图(在菜单栏上选择“报表 – 报表属性 – 其他 – 背景图 – URL 或者表达式”,然后选择要作为背景图的单据扫描件 ,最后选择“ 确定”)。

然后,我们调整报表的行高列宽,使报表中要填入数据的单元格与扫描件空白区域对应,比如:C2 单元格对应“发票单位”,D5 单元格对应“日期”等,如图蓝色字体所示。本例中是直接填写的字符串,实际应用中也可以从相应的数据集中读取。

接下来,在”报表属性”中设置”打印背景图”并且”报表不分页”。如下图:

最后,保存报表就可以进行展现打印了。

好了,一个完美的单据报表就完成了。我们来回顾一下其中的关键操作:

  1. 空白单据引用

2. 打印背景图

3. 图表制作

最最后,温馨提示:

不同扫描仪的尺寸单位不同,扫描时如果没有选择扫描的像素,会导致扫描出来的图片大很多。

解决办法:扫描的时候设置像素单位,使得最后的图片与目标纸张大小一致,或者用画图软件根据打印机的分辨率将图片压缩成目标纸张大小。

像素换算方法为:像素点数 = 纸张宽度(毫米)* 25.4(换算成英寸)* 分辨率(常用打印机是 72dpi)


详情链接:http://c.raqsoft.com.cn/article/1533028271062?r=gxy
 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
一、应用场景与出发点 同一个系统中,为了解决不同的客户可能需要设计不同的单据打印模板,实现此方法可能是: 1、设计不同的自带RDLC报表文件,根据当前客户加载不同的报表并打印 2、GDI+绘图 和 打印组件 ,不同的客户创建不同的绘图XML格式的模板内容 3、其他第三方组件 主要对比一下前两种方法,第一种方法不好之处在于,不灵活,开发者必须地每个客户制订一个报表,不推荐采用。第二种方法,修改对应的模板内容就可以了, 模板内容可以是Xml文件,也可以是存放在数据库中的Xml格式字符串。推荐采用这种方法。然后这种方法的也有一个棘手问题 :如何让用户快速、方便地设计打印模板,本示例就是为了解决这个问题。 二、实现思路与原理 功能概要:设计一个界面,支持用户自由添加 要打印的项,文本,直线,图片 等,并且可以方便改变打印项的 字体、颜色、粗细、位置,设计时支持效果预览。 技术要点:GDI+绘图、拖动控件、XML解析、自定义控件 三、相关类介绍 绘图工具类:DrawHelper 实现 xml格式模板 与 打印项 之间进行互相转换,在目标画板中绘制 拖动工具类:WinHelper 实现控件的鼠标拖动,键盘移动 自定义控件:用于显示文字的文本框 TextBoxExt、用于显示直线的标签 LabelExt 主窗体代码:用于用户操作,添加,删除,编辑,打印项 详细介绍请参照我的博文:http://de.cel.blog.163.com/blog/static/51451236201472215450939/
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值