手把手教你WEB套打程序开发

原链接地址:http://blog.sina.com.cn/s/blog_721e77e50100ng1o.html

WEB套打可选方案不多,理想的更少,利用免费控件Lodop+JavaScript实现精确套打,算是较为经典的选择。这种方案其实比较简单,利用一个htm文件就可以实现模板设计过程,几乎是“空手套”式的开发,但理解这几个步骤还是需要点时间,下面一步步详细演示说明:

第一步:建立一个空白的模板设计文件

把以下超文本代码复制到一个本地htm文件中:

本文模拟EMS特快专递单的程序开发,文件起名为printEMS.htm,权且称它为模板设计文件

第二步:用浏览器打开该文件

 在本地文件夹中双击该文件就可以打开,但在进入设计之前,你的机器需要安装Lodop,如果还没安装过,

请在如下地址下载安装文件(找那个install_lodop32.exe文件,Lodop是一个1M左右的小文件):

http://www.mtsoftware.cn/download.html

http://www.c-lodop.com/download.html

第三步:准备设计

 成功安装Lodop之后再次打开模板设计文件printEMS.htm,点击其中“模板设计”链接,就弹出如下空白的打印设计窗口:

 为了尽快定位模板中的数据位置,你需要做一张票据扫描图作为背景,当然没有扫描图也能完成,只是需要多摸索几次,费点时间而已。

 下面是我做的EMS扫描图,你把该图另存成一个jpg文件,以便我们一起完成后面的演示步骤。

第四步:装载背景图并调整图片大小

打印设计窗口,点下图所示的“装载背景图...”菜单,调入以上保存的EMS图片文件。

 装载背景图后,点上图所示的“调整背景图...”菜单,弹出下图“背景图调整”窗口,设定其中的图片宽度为209mm,高度113mm会自动变化。

 这个宽度值是我测量实际票据得来的。如果扫描图是按1:1比例获得的,那么调整背景图这一步就免了,当然要做点这点很难,所以最好还是在这里直接设置具体尺寸反倒简单。

第五步:添加数据内容,开始打印测试

 点下图所示“插入文本项”菜单,添加打印内容,内容项可以拖拉或精细调整,基本对准之后,点击“预览”按钮(注意旁边的“打印”按钮是收费功能,纸上会有水印,而“预览时的打印”按钮是完全免费的,我们用后者)。

 把内容打印到薄一点的白纸上,然后在阳光下与真实票据透亮对比,以最左最上的某个内容为基准,其它内容远近调整,如此反复测试直到所有内容相互位置都对准。

 这一步先做到内容之间的相互位置对准,等下一步处理整体位置。

第六步:整体对准

 由于打印机左边距或上边距不一定是零或票据边缘有误差,所以尽管第五步打印出来的内容相互之间位置是准确的,但打印到真实票据上仍会整体偏离一些,需要进行整体位置调整。

 点击下图红圈所示的“纸钉”按钮,“纸钉”弹起后,整个设计版面就可以上下左右调整了,然后按上一步的办法打印测试,直到整体对准成功。为了避免浪费票据,打印时仍可用薄白纸测试,注意此时透光对照时,纸张的左边沿和上边沿要与票据对齐,通过观察内容的位置来判断是否整体对准。

第七步:生成打印模板的程序代码

 套打测试成功后,点击第五步图中所示的“生成程序代码”菜单,出现下图结果,这些代码就是我们需要的模板程序代码,把他们复制出来,准备融合到你的页面程序中使用。

第八步:完成打印模板设计文件

想不想知道WEB套打有啥感觉?好,我们先做一个静态WEB页面爽一下:把第七步生成的程序代码,

插入替换第一步的空白设计文件CreatePrintPage函数内,变成如下内容:

把以上内容复制到另外一个htm文件printEMS_OK.htm中,双击打开它,点其中的打印预览,就可以实现简单的WEB套打了。

 以上八步基本完成了模板设计,并实现静态页面套打,但要把模板代码融合到实际的WEB程序中,还需要做些工作。

第九步:模板程序代码的使用

把以上CreatePrintPage函数进行简单改造,原函数如下:

function CreatePrintPage() {

 LODOP.PRINT_INITA(14,11,800,600,"套打EMS的模板");

 LODOP.ADD_PRINT_TEXT(95,95,75,20,"寄件人姓名");

 LODOP.ADD_PRINT_TEXT(123,148,194,20,"寄件人单位名称");

 LODOP.ADD_PRINT_TEXT(158,101,238,35,"寄件人的详细地址");

 LODOP.ADD_PRINT_TEXT(92,446,75,20,"收件人姓名");

 LODOP.ADD_PRINT_TEXT(122,496,208,20,"收件人单位名称");

 LODOP.ADD_PRINT_TEXT(160,460,244,35,"收件人详细地址");

 LODOP.ADD_PRINT_TEXT(289,47,178,22,"内件品名");

 LODOP.ADD_PRINT_TEXT(290,258,100,20,"内件数量");

 LODOP.ADD_PRINT_TEXT(92,245,100,20,"寄件人电话");

 LODOP.ADD_PRINT_TEXT(90,608,75,20,"收件人电话");

};

把其中的打印内容提出来做为变量参数,函数改成如下样式:

function CreatePrintPage(strPName,strJJRXM,strJJRDW,strJJRDZ,strSJRXM,strSJRDW,strSJRDZ,strNJPM,strNJSL,strJJRDH,strSJRDH) {

 LODOP.PRINT_INITA(14,11,800,600,strPName); //打印任务名

 LODOP.ADD_PRINT_TEXT(95,95,75,20,strJJRXM); //寄件人姓名

 LODOP.ADD_PRINT_TEXT(123,148,194,20,strJJRDW); //寄件人单位名称

 LODOP.ADD_PRINT_TEXT(158,101,238,35,strJJRDZ); //寄件人的详细地址

 LODOP.ADD_PRINT_TEXT(92,446,75,20,strSJRXM); //收件人姓名

 LODOP.ADD_PRINT_TEXT(122,496,208,20,strSJRDW); //收件人单位名称

 LODOP.ADD_PRINT_TEXT(160,460,244,35,strSJRDZ); //收件人详细地址

 LODOP.ADD_PRINT_TEXT(289,47,178,22,strNJPM); //内件品名

 LODOP.ADD_PRINT_TEXT(290,258,100,20,strNJSL); //内件数量

 LODOP.ADD_PRINT_TEXT(92,245,100,20,strJJRDH); //寄件人电话

 LODOP.ADD_PRINT_TEXT(90,608,75,20,strSJRDH); //收件人电话

};

这个改造后的JS函数还是很好理解的,无论写入js文件还是直接嵌在页面内都简单易用。

如果你改变了内容的字体、大小、粗斜体等格式,代码还会多一些,但总体来说比较简洁。

第十步:设置纸张高度,实现连续套打

多数套打业务的票据是连续纸,需要精确地分页,从而保证连续多页打印不偏移,

为此以上代码还要在PRINT_INITA之后加一行SET_PRINT_PAGESIZE语句:

function CreatePrintPage() {

 LODOP.PRINT_INITA(14,11,800,600,"套打EMS的模板");

 LODOP.SET_PRINT_PAGESIZE(1,"209mm","113mm","");

//设置纸张高度

 LODOP.ADD_PRINT_TEXT(95,95,75,20,"寄件人姓名");

 LODOP.ADD_PRINT_TEXT(123,148,194,20,"寄件人单位名称");

 LODOP.ADD_PRINT_TEXT(158,101,238,35,"寄件人的详细地址");

 LODOP.ADD_PRINT_TEXT(92,446,75,20,"收件人姓名");

 LODOP.ADD_PRINT_TEXT(122,496,208,20,"收件人单位名称");

 LODOP.ADD_PRINT_TEXT(160,460,244,35,"收件人详细地址");

 LODOP.ADD_PRINT_TEXT(289,47,178,22,"内件品名");

 LODOP.ADD_PRINT_TEXT(290,258,100,20,"内件数量");

 LODOP.ADD_PRINT_TEXT(92,245,100,20,"寄件人电话");

 LODOP.ADD_PRINT_TEXT(90,608,75,20,"收件人电话");

};

 其中209mm这个纸宽参数意义不大,主要是113mm这个高度参数,它决定了每页的走纸距离,对连续打印影响很大。这个值是我测量实际票据高度得来的,包含纸张之间的撕孔间隙。理想的测量方式,是若干页连起来一起测量取其平均高。

 加入纸高控制后的打印预览如下,你可以连续打印两页内容到同一张长一点的白纸上,测试对照一下看看。把以上加入SET_PRINT_PAGESIZE语句的代码复制进第三个htm文件printEMS_OKM.htm试试。假如从第二页开始,内容向下偏移,说明纸张高度设置比实际票据大,就减小113mm这个参数值,否则增大它,这个参数可以精确到0.1mm。

第十一步:让操作者自己调整位置

 以上十步实现的套打可以很精确,但都是以当前打印机为前提。如果你的打印程序要面对许多种类型的打印机,甚至一些未知的打印机类型,那么“打印维护”功能会很有用处。你可以根据情况在程序中把该功能授权给最终操作者或现场技术维护人员,让使用者自己来调整打印位置,以适应各种类型的打印机。

 打印维护的指令语句是PRINT_SETUP,进入包含该功能的在线文件PrintEMS_OKMSetup.htm,先在打印维护中调整一下打印内容或整体位置,点“应用”按钮。关闭浏览器后重新打开,进入“打印预览”,看看是否有关联变化。下图是打印维护界面,其中能看到“应用”按钮和“恢复整体缺省”按钮的位置。

以上拙笔语无伦次,请各位笑纳!!

本文参考如下资料:

http://www.c-lodop.com/LodopDemo.html

http://www.mtsoftware.cn/LodopDemo.html

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,142评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,298评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,068评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,081评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,099评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,071评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,990评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,832评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,274评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,488评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,649评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,378评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,979评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,625评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,643评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,545评论 2 352

推荐阅读更多精彩内容

  • Python 面向对象Python从设计之初就已经是一门面向对象的语言,正因为如此,在Python中创建一个类和对...
    顺毛阅读 4,213评论 4 16
  • ¥开启¥ 【iAPP实现进入界面执行逐一显】 〖2017-08-25 15:22:14〗 《//首先开一个线程,因...
    小菜c阅读 6,397评论 0 17
  • 一颗感恩的心 行动营就要结束了,回首这20多天,脑海浮现最多的是一个个鲜活的形象,连长的沉稳耐心,苏宝的温柔体贴,...
    疯叶枫了阅读 301评论 0 1
  • 过年啦!过年啦!祝:简书的新老朋友们!新年快乐!!!红包收到手软!!!数钱数到抽筋!!!
    鱼在天上飞阅读 131评论 0 0
  • 非暴力沟通指导我们转变谈话和聆听的方式。我们不再条件反射式的反应,而是去明了自己的观察感受和愿望,有意识地使用语言...
    star_t阅读 368评论 0 0