前端实现打印图像功能
前提:后台返回是绘制医⽤⼼电波形报告的数据,前端通过canvas在⽹页上绘制再进⾏打印并⽣成PDF⽂档!
⼀. 尝试LODOP打印插件
之前前端表单打印功能有使⽤过LODOP打印插件,需安装相应的LODOP的打印软件,lodop的使⽤⽅法2种。第⼀种⽅式是通过收集前端标签内容元素成对象 var htmlstr= $("#ECGReport").html(); 通过 LODOP.ADD_PRINT_HTM(20,60, 400, 900,htmlstr); 的lodop⽅法导⼊到⾃带编辑的打印软件中进⾏打印,当然字体⼤⼩,颜⾊,加粗等都可以设置;第⼆种是⾃定义内容,模板样式已确定,可通过⽅法将打印内容⼀块块放⼊到打印区域中, LODOP.ADD_PRINT_HTM(20,60, 400, 900,'⽣成报告标题'); 并调节左右边距;但是使⽤第⼀种⽅式收集标签元素内容时候,发现不能收集到canvas⾥⾯的图层样式和内容,并果断放弃,如果⽹页⽆canvas绘制内容,可使⽤;
优点:可⾃定义打印内容和样式,打印百分⽐也可以编辑;缺点:需下载安装打印lodop打印软件,页⾯canvas的内容⽆法提取到打印区域;
⼆. 尝试前端window.print()
优点:代码编写⽅便,如配合⾕歌浏览器提供的打印功能,操作很⽅便;
缺点:如整页有部分是打印内容,打印区域不⽅便控制,有⼀定失真;
三.尝试html2canvas + jsPDF.js
html2canvas(document.querySelector('#modelContents'), {
allowTaint: true, taintTest: false, scale: '1', dpi: '300', background: '#fff'}
) .then(function(canvas) {
//元素id为exportContent
let ctx =Context("2d");
var imgData = DataURL('image/png') var img = new Image()
var contentWidth = canvas.width; var contentHeight = canvas.height;
img.src = imgData;
$("#ECGReport").append(img);
img.width =1000; img.height = 740;
//a4纸的尺⼨[595.28,841.89],html页⾯⽣成的canvas在pdf中图⽚的宽⾼
var imgWidth = 595.28;
var imgHeight = 555.28/contentWidth * contentHeight;
svg矢量图下载//根据图⽚的尺⼨设置pdf的规格,要在图⽚加载成功时执⾏,之所以要*0.5是因为⽐例问题
//此处需要注意,pdf横置和竖置两个属性,需要根据宽⾼的⽐例来调整,不然会出现显⽰不完全的问题
var doc=''
if (this.width > this.height) {
doc = new jsPDF('l','px', [1000, 720])
} else {
doc = new jsPDF('p','pt', [4000, 2960])
}
doc.addImage(imgData, 'png', 30, 40, 500, 360,'NONE') //⽐例可根据需要调节
//根据下载保存成不同的⽂件名 doc.save('pdf_' + new Date().getTime() + '.pdf') };})
通过html2canvas的⽅法将canvas和表单内容提取出并转成图⽚,canvas内容不会丢失,为了防⽌图像内容失真严重,将原图内容放⼤倍数之后提取,放⼤倍数的计算可通过A4纸张的⼤⼩和打印机的分辨率300dpi等参数算出差不多为4倍,1920*1080的电脑屏幕dpi⼀般为72dpi,通过jsPDF的⽅法将图⽚导⼊到PDF⽂档中;
其实也可以通过jsPDF的⽅法去编辑报告单中的患者姓名等信息,同样canvas内容绘制逻辑也可以通过jsPDF的⽅法去实现,但是jsPDF对中⽂不⽀持需下载使⽤的 ttf字体⽂件到项⽬中,⽐较繁琐和不⽅便;缺点:虽实现⼤体需求,但是⽣成的波形图像还是有失真和锯齿现象,是canvas绘制中不可避免。
总结:
canvas的绘图严重依赖分辨率,如对svg操作⽐较熟悉的话,制图的保真问题⽐较看重,建议使⽤svg⽅法,svg是⽮量图,不依赖于像素,⽆限放⼤也不会失真。如纯表单打印功能还⽐较容易实现连接打印机打印。
以上所述是⼩编给⼤家介绍的前端实现打印图像功能,希望对⼤家有所帮助,如果⼤家有任何疑问请给我留⾔,⼩编会及时回复⼤家的。在此也⾮常感谢⼤家对⽹站的⽀持!
如果你觉得本⽂对你有帮助,欢迎转载,烦请注明出处,谢谢!
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论