XML打印功能及更新说明
bsp
XML打印功能及更新说明
XML打印功能包含XML设计器与XML打印二部分,设计器设计好模板后,可以使用DHCOPPrint.CAB或LODOP来打印模板,以下介绍二种打印功能
使用LODOP打印XML
引用插件(二选一)
iMedical系统的CSP中引入,在IE/Chrome下使用LODOP打印时请使用以下类方法引用相关
d ##class(web.DHCXMLPConfig).LODOPInit() // IE下引用LODOP,Chrome下引用CLODOP
或
// 2020-09-18 增加参数NeedCLodop,默认"0"
d ##class(web.DHCXMLPConfig).LODOPInit("1") // 强制使用CLodop,可用效解决打印img导致iMedical超时问题
iMedical系统的组件中引入,使用隐藏的CUSTOM元素,在Custom Expression中写入以上相应的语句即可。
JS脚本代码示例
DHCP_GetXMLConfig("encryptItemId","xmlFlagName"); //xmlFlagName为XML模板, 用于加载XML内容
var LODOP = getLodop();
/*
@description 使用LODOP打印XML
@param {LODOP} LODOP 控件对象
@param {String} inpara 元素对应的打印值
@param {String} inlist 列表对应的打印值
@param {Array} jsonArr [可选] 动态追加打印内容
@param {String} reportNote [可选] 打印任务名称,可区别本次打印任务
@param {Object} options [可选] 打印配置信息
*/
DHC_PrintByLodop(LODOP,inpara,inlist,jsonArr,reportNote,{printListByText:true});
入参详细内容
@param {LODOP} LODOP 控件对象
@param {String} inpara 元素对应的打印值
name_$c(2)_zhangsha^
patno_$c(2)_000009^
img1_$c(2)_data:image/png;base64,iVAAA...AA^
img2_$c(2)_http://172.0.0.1/imedical/web/images/xx/xx.gif^
img3_$c(2)_c:\\xx.gif
@param {String} inlist 列表对应的打印值
DrugName1^Price1^DrugUnit1^Qty1^PaySum1_$c(2)
_DrugName2^Price2^DrugUnit2^Qty2^PaySum2_$c(2)
_DrugName3^Price3^DrugUnit3^Qty3^PaySum3
@param {Array} jsonArr [可选] 动态追加打印内容
[{type:"invoice",PrtDevice:"pdfprinter"},{type:"line",sx:1,sy:1,ex:100,ey:100},{type:"text",name:"patno",value:"0009",x:10,y:10,isqrcode:true,lineHeigth:5}]
@param {String} reportNote [可选] 打印任务名称,可区别本次打印任务
@param {Object} options [可选] 打印配置信息
printListByText:truetrue按label打印列表。false按html-table方式打印。默认false,一般应使用true
LetterSpacing:0控制字符间空隙。0正常空隙,-2紧凑或其它数值。默认0
preview:00打印,1预览。默认0
tableBorder:0默认是0, 数字表示线宽。替换listHtmlTableBorder
tdnowrap:truetrue时列宽固定800mm。false时为二列间宽度,内容可自动换行
pdfDownload:false得到打印后的PDF文件并下载下来
onCreatePDFBase64:undefined值为函数时,会把把PDF文件转成base64字符串,以入参方式传给函数
PrtDevice:undefined强制设置打印机名称
columnTitle:undefined用于每页重打。如:"ColTitle1^ColTitle2^ColTitle3^ColTitle4"
pageShowColunmTitle:false是否每页显示表头。默认不显示
pageTableStartPostion:"ONEPAGE"第一页启始位置一样。为数字时表示启始位置yrow值单位mm。默认ONEPAGE
rowContentFit: false默认false 行内容是否自动换行。替换listHtmlTableWordWrapFlag
rowHeightExpand: false默认false 是否推动表格后面元素位置
listAfterCallback:function默认null,当表格打印完成后,回调此函数 20230224
onPrintEnd打印完成时回调方法
PFlagXML模板代码,打印方法自动加载XML模板内容。一次打印多个模板的时候,必传此配置值,避免模板覆盖的风险 20250805
langCode现PFlag一起使用,指定XML模板对应的语言代码。如果未定义对应语种模板时,使用原模板打印。如:EN 20250805
推荐使用CLODOP打印
使用CAB打印XML
引入插件(二选一)
iMedical系统的CSP中引入,在IE下使用DHCOPPrint.CAB打印请使用以下类方法引用控件
d ##class(web.DHCBillPrint).InvBillPrintCLSID()
iMedical系统的组件中引入,使用隐藏的CUSTOM元素,在Custom Expression中写入以上相应的语句即可。
JS脚本代码示例
DHCP_GetXMLConfig("encryptItemId","xmlFlagName"); //xmlFlagName为XML模板, 用于加载XML内容
var PObj = document.getElementById("ClsBillPrint");
/*
@description 使用LODOP打印XML
@param {HTMLObject} PObj 控件对象
@param {String} inpara 元素对应的打印值。和lodop的差区在不能支持img-base64打印
@param {String} inlist 列表对应的打印值
@param {Array} jsonArr [可选] 动态追加打印内容
@param {Float} invHeight [可选] 票据的高度。CAB中判断打印换页是:发现元素位置top超过height就会换页打印,如果发现一个元素超过一页后,后面所有元素都会分页打印。通过invHeight可以解决。2018-09-20 增加invHeight 分页处理。默认空
*/
DHCP_XMLPrint(PObj, inpara, inlist, jsonArr,invHeight);
更新日志
2025-08-05
打印支持国际化
1) XML设计界面选中模板,点击 [多语种模板] 进行其它语种维护
2) 使用DHC_PrintByLodop方法打印,通过langCode控制语种
```js
// 第6入参 增加配置项langCode
DHC_PrintByLodop(getLodop(),itmInfo,listInfo,arr,”打印处方(英文)”,{
PFlag:”DHCXMLPrintTest”,
langCode:”EN”
});
2024-03-07
打印得到base64方法,增加配置项encoderOptions实现压缩文件
// 第6入参为增加配置项encoderOptions,encoderOptions是0到1间的一个小数,表示压缩比例
DHC_PrintByLodop(getLodop(),itmInfo,listInfo,ajson,"xmlname",
{printListByText:true,tdnowrap:false,encoderOptions:0.2,onCreatePDFBase64:function(pdfbase64){
console.log(pdfbase64);
}
});
2023-02-24
DHC_PrintByLodop打印方法增加listAfterCallback回调方法, 在打印列表结束后调用
// 回调方法入参
listAfterCallback({
PrinterObj:LODOP, /*当前打印对象*/
tableTop: parseInt(tableTop), /*表格的top位置*/
tableLeft: parseInt(tableLeft), /*表格的left位置*/
rowHeight:rowHeight, /*每一行的行高多少*/
y: parseInt(tableTop) + ((currPageRowNo + 1) * rowHeight), /*行的起始y位置*/
x: tableLeft, /*行的起始x位置*/
currPageRowNo: currPageRowNo, /**当前行号*/
pageRows:xmlPageRows, /*一页打印多少行数据*/
backSlashWidth:xmlBackSlashWidth /*表格反斜线宽度*/
});
使用示例
var otherCfg = {};
otherCfg.printListByText = true;
/*打印列表结束回调。翻页时只有最后一张会进入此方法一次*/
otherCfg.listAfterCallback = function(cfg){
if (cfg.currPageRowNo!=pageRows){ // 数据不满行时才打印反斜线
// ADD_PRINT_LINE(起点y,起点x,结束点y,结束点x,0=实线,2=线宽)
cfg.PrinterObj.ADD_PRINT_LINE(cfg.y + "mm", "80mm", (parseInt(cfg.y)+10)+"mm", "60mm", 0, 2);
}
};
DHC_PrintByLodop(getLodop(),itmInfo,listInfo,exPrintJson,"打印任务名", otherCfg);
2021-11-25
增加获得打印PDF文件后的base64内容功能
// 通过虚拟打印机打印pdf,然后再获得pdf文件的base64内容
// 第5入参{String}类型, 为打印机任务名。如果虚拟打印机设置文档名与任务名一致时,也为pdf文件名
// 第6入参为{Obejct}类型,
// PrtDevice: {String} 强制使用包含Zan名称的第一台打印机打印,优先级高于XML模板中打印机配置
// onCreatePDFBase64: {function} 为得到base64内容的回调方法
DHC_PrintByLodop(getLodop(),itmInfo,listInfo,ajson,"pdf1234",
{printListByText:true,tdnowrap:false,PrtDevice:"Zan",onCreatePDFBase64:function(pdfbase64){
console.log(pdfbase64);
}
});
2021-05-23
修复点击列表中图片/条码/二维码后,再点击非列表元素会导致有些输入框不能输入 :bug:
2021-05-20
增加页脚打印配置,打印到界面的底部中间位置,格式如:第#页/共&页
2021-04-19
【列表项】可以定义成图片,条形码,二维码及其相关配置 :sparkler:
2021-01-26
XML设计器支持文本/图片/二维码/条形码/线条配置是否重复打印 :sparkler:
2020-11-17
XML设计器支持二维码版本定义功能,解决二维码大小不一问题
2020-09-18
提供强制引用CLodop打印功能,解决某些IE使用LODOP打印后,系统超时问题
// 强制初始化为CLodop
d ##class(web.DHCXMLPConfig).LODOPInit("1")
或使用JS引用
2020-09-10
LODOP打印方法
2019-09-06
版本1,0,0,83
控件打印支持指定纸张名字。如指定A5纸打印,即可配置invoice节点中属性PrtPage="A5"
2019-07-24
版本1,0,0,82
修复txtdata节点中printvalue,defaultvalue,fontsize,fontbold,fontname属性不存在时,打印不异常问题
2019-07-09
版本1,0,0,81
为txtdata增加width与height属性,如果内容超出时自动换行打印,不配置默认自由长度打印。
图片没定义宽高默认图片大小
二维码与条形码没定义宽高默认30mm
服务器图片打印不再缓存图片,每次都取服务器图片
增加多处错误提示
2018-10-11
xml设计器增加即打即停配置. LandscapeOrientation属性值增加Z值,表示即打即停,且纸张设置选为手动设置纸张大小,height表示底边留白高度。此属性只支持lodop打印
xml设计器增加条码打印. txtdatapara增加属性barcodetype,此属性只支持lodop打印
实现DHC_PrintBYLodop方法,打印xml及数据
2017-11-30
版本1,0,0,65
基于QRmaker.ocx控件打印二维码,提升扫码率
2017-06-12
版本1,0,0,64
在ListData节点增加BackSlashWidth属性,定义list输出结束后打印反斜线宽度。用于处方结束处
2017-06-08
版本1,0,0,63
在PICdatapara节点上增加width与height属性,可实现图片缩放功能
2017-04-06
版本1,0,0,56
支持服务器图片打印,会自动把服务器图片下到本地C:\imedical\xmlprint\cache\目录下。打印方法为ToPrintHDLP。
只有ToPrintHDLP方法支持打印服务器图片,其它方法只能打印本地图片
xml打印基于vb开发,支持图片格式为gif,jpg,jpeg,icon,cur,不支持png
打印服务器图片时,路径及图片名称中不要包含汉字,可能导致某些图片不能下载成功
2017-2-10
xml设计器中可与类方法关联
xml设计器中可与query关联
2016-10-26
提交第二版xml设计器
说明
注意所有属性不能省略,老的xml打印没有保护
CAB打印基于vb开发,支持图片格式为gif,jpg,jpeg,icon,cur,不支持png
PrtPaperSet=HAND 表示纸张大小手工设置,纸张大小走height与width数值
PrtPaperSet=WIN 表示纸张大小走PrtPage配置的纸张大小
PrtDevice打印机名配置
LandscapeOrientation打印方向,Y横向打印,X纵向打印