前提:后台返回是 绘制 医用心 电 波形报告的数据,前端通过canvas在网页上绘制再进行打印并 生成PDF 文档!
一.&nbs p; 尝试LODOP打印插件
之前前端表单打印功能有使用过LODOP打印插件,需安装相应的LODOP的打印软件,lodop的使用方法2种。第一种方式是通过收集前端标签内容元素成对象 VAR ht ML str= $(" # ECGReport"). html() ; 通过 LODOP.ADD_ PR INT_HTM(20,60, 400, 900,htmlstr); 的lodop方法导入到 自带 编辑的打印软件中进行打印,当然字体大小,颜色, 加粗 等都可以设置;第二种是自定义内容,模板样式已确定,可通过方法将打印内容 一块 块放入到打印区域中, LODOP.ADD_PRINT_HTM(20,60, 400, 900,'生成报告标题'); 并 调节 左 右边 距;但是使用第一种方式收集 标签元素 内容时候,发现不能收集到canvas里面的 图层 样式和内容,并果断 放弃 ,如果网页无canvas绘制内容,可使用;
优点:可自定义打印内容和样式,打印百分比也可以编辑;缺点:需下载安装打印lodop打印软件,页面canvas的内容无法提取到打印区域;
二. 尝试前端window.print()
优点:代码编写方便,如配合 谷歌 浏览器提供的打印功能,操作很方便;
缺点:如整页有部分是打印内容,打印区域不方便控制,有一定失真;
三.尝试html2canvas + jsP DF .js
html2canvas(document.querySelector('#modelContents'), { allowT ai nt: true, taint test : false, scale: '1', dpi: '300', background: '#fff'} ) .then(function(canvas) { //元素id为 export Content let ctx =canvas.getContext("2d"); var img Data = canvas.toDataURL('image/png') var img = new Image() var contentWidth = canvas.width; var contentH ei ght = canvas.height; img.src = imgData; $("#ECGReport").ap PE nd(img); img.width =1000; img.height = 740; //a4纸的 尺寸 [595.28,841.89],html页面生成的canvas 在P df中图片的 宽 高 var imgWidth = 595.28; var imgHeight = 555.28/contentWidth * contentHeight; //根据图片的尺寸设置pdf的规格,要在图片加载成功时执行,之所以要*0.5是因为比例问题 img.onload = function () { //此处需要注意,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是矢量图,不依赖于像素,无限放大也不会失真。如纯表单打印功能还比较容易实现 连接打印机 打印。
以上所述是小编给大家介绍的前端实现打印图像功能, 希望对大家有所帮助 ,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
如果你 觉得 本文对你有帮助,欢迎 转载 ,烦请注明出处,谢谢!
总结
以上是 为你收集整理的 前端实现打印图像功能 全部内容,希望文章能够帮你解决 前端实现打印图像功能 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。