前提:后台返回是绘制医用心电波形报告的数据,前端经过canvas在网页上绘制再进行打印并生成PDF文档!html
一. 尝试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绘制内容,可以使用;canvas
优势:可自定义打印内容和样式,打印百分比也能够编辑;缺点:需下载安装打印lodop打印软件,页面canvas的内容没法提取到打印区域;后端
二. 尝试前端window.print()浏览器
优势:代码编写方便,如配合谷歌浏览器提供的打印功能,操做很方便;bash
缺点:如整页有部分是打印内容,打印区域不方便控制,有必定失真;app
三.尝试html2canvas + jsPDF.js编辑器
html2canvas(document.querySelector('#modelContents'), {
allowTaint: true, taintTest: false, scale: '1', dpi: '300', background: '#fff'}
) .then(function(canvas) {
//元素id为exportContent
let ctx =canvas.getContext("2d");
var imgData = canvas.toDataURL('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;
//根据图片的尺寸设置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文档中;svg
其实也能够经过jsPDF的方法去编辑报告单中的患者姓名等信息,一样canvas内容绘制逻辑也能够经过jsPDF的方法去实现,可是jsPDF对中文不支持需下载使用的 ttf字体文件到项目中,比较繁琐和不方便;缺点:虽实现大致需求,可是生成的波形图像仍是有失真和锯齿现象,是canvas绘制中不可避免。字体
总结:canvas的绘图严重依赖分辨率,如对svg操做比较熟悉的话,制图的保真问题比较看重,建议使用svg方法,svg是矢量图,不依赖于像素,无限放大也不会失真。如纯表单打印功能还比较容易实现链接打印机打印。