前提:后台返回是绘制医用心电波形报告的数据,前端通过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 =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文档中;

其实也可以通过jsPDF的方法去编辑报告单中的患者姓名等信息,同样canvas内容绘制逻辑也可以通过jsPDF的方法去实现,但是jsPDF对中文不支持需下载使用的 ttf字体文件到项目中,比较繁琐和不方便;缺点:虽实现大体需求,但是生成的波形图像还是有失真和锯齿现象,是canvas绘制中不可避免。

总结:

canvas的绘图严重依赖分辨率,如对svg操作比较熟悉的话,制图的保真问题比较看重,建议使用svg方法,svg是矢量图,不依赖于像素,无限放大也不会失真。如纯表单打印功能还比较容易实现连接打印机打印。

以上所述是小编给大家介绍的前端实现打印图像功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

html图片打印不出来 lodop_前端实现打印图像功能相关推荐

  1. react 前端实现打印发票/图片

    项目场景: 电商后台管理系统,有一个功能要在web端生成发票.发货单(图片),并支持打印.客户是澳洲人,只考虑Chrome即可. 解决方案: 由于原型中发票的样式有一丢丢复杂,所以我们采用后端提供数据 ...

  2. python静默打印pdf_前端静默打印实现 html pdf集合

    一.初步实现 前段时间,公司有个需求,要实现前端静默(点击按钮直接打印,不需要预览),本想着直接用window.print()来实现,让用户多点击一下按钮的事儿,无奈我们的产品: 最后只好继续要网上继 ...

  3. 前端条码打印方案(表格+中文+一维码+二维码)

    前言 条码打印不同于普通打印机,条码大小各不相同,需要针对不同标签贴纸开发不同的样式 1. 条码打印的两种方案: 后端ZPL指令打印 前端调用浏览器打印 2. 优缺点分析: 优点 缺点 后端ZPL指令 ...

  4. java返回图片base64_java将图片转为base64返回给前端

    本文实例为大家分享了java将图片转为base64返回给前端的具体代码,供大家参考,具体内容如下 一.controller端代码 @RequestMapping(value = "/capt ...

  5. 前端网页打印插件print.js

    在前端开发中,想打印当前网页的指定区域内容,或将网页导出为多页的PDF,可以借助print.js实现,该插件轻量.简单.手动引入.不依赖其他库.示范项目github:https://github.co ...

  6. android 蓝牙打印机(ESC/POS 热敏打印机),打印菜单小票和图片,对蓝牙配对和连接打印功能进行了封装,让你超快实现蓝牙打印功能

    BluetoothPrint 项目地址:liuGuiRong18/BluetoothPrint  简介:android 蓝牙打印机(ESC/POS 热敏打印机),打印菜单小票和图片,对蓝牙配对和连接打 ...

  7. php web裁剪图片上传,WEB前端实现裁剪上传图片功能

    最后的效果如下: 这里面有几个功能,第一个是支持拖拽,第二个压缩,第三个是裁剪编辑,第四个是上传和上传进度显示,下面依次介绍每个功能的实现: 1. 拖拽显示图片 拖拽读取的功能主要是要兼听html5的 ...

  8. java 上传图片转base64_java将图片转为base64返回给前端

    本文实例为大家分享了java将图片转为base64返回给前端的具体代码,供大家参考,具体内容如下 一.controller端代码 @RequestMapping(value = "/capt ...

  9. 数据库存储图片路径并显示到前端

    数据库存储图片路径并显示到前端 -为啥不直接存图片:因为图片本身太大了,虽然存取方便了程序员,但对数据库不友好.所以采取存取路径,再根据路径解析的方法. 一.数据库表设计: 从以上思想出发,需要存图片 ...

最新文章

  1. 深度剖析http协议(一)
  2. [转]COM线程模型-套间
  3. android 动态调用apk,通过反射动态加载未安装apk
  4. 在.NET Core类库中使用EF Core迁移数据库到SQL Server
  5. Laravel最佳实践--事件驱动编程
  6. plc的指针和c语言指针,关于STEP7 Pointer指针的问题
  7. java之try catch finally
  8. java模拟dos窗口
  9. konika电视一直显示android,康佳多屏互动电视端下载
  10. %几.几//C语言(闲的没事,记录下)
  11. 使用python Telegram 机器人推送消息
  12. Android:空气质量检测界面(布局嵌套),练手推荐。
  13. 酞菁绿,耐高温酞菁绿颜料, 酞菁有机颜料CAS: 1328-53-6
  14. 如何判断一个点在多边形内
  15. VMware系统启动假死,一直处于“繁忙”状态
  16. 物联网-电力监控平台(二)
  17. 全球与中国终末期肾病(ESRD)设备市场现状及未来发展趋势(2022)
  18. markdown插入本地图片小技巧
  19. 使用mpx开发外卖小程序完整教程(附源码)
  20. PAP认证和CHAP认证原理解析

热门文章

  1. java 计算百分比占比,占比和为100%
  2. QT+opencv实现简单的图像处理界面
  3. 集成电路————运算放大器芯片
  4. 计算机光盘检索,光盘检索
  5. 对打造执行力强的开发团队的思考和探索 -- 组建团队
  6. QQ光遇攻略机器人插件光萌插件『LightCute』来啦!内容自制,独家小精灵问答功能!!
  7. MT5 中文版财经日历,主标不可或缺
  8. [日推荐]『爱比趣』有意思的体育社区
  9. Carla——5个危险场景模式以及车辆的加减速
  10. 台湾中央大学认知神经科学研究所所长洪兰对于男女脑活动的比较