关于 html2canvas 生成的图片总是扭曲变形

今天突然发现了这个棘手的问题,在 html 本地预览的时候生成的图片和海报是 正常的没有问题,但是只要 一调用html2canvas  进行海报生成,出来的图片那真是惨不忍睹,不是纵向拉伸就是横向,刚开始我一直以为是源文件图片宽高不协调问题,最后发现是因为html2canvas 默认不识别

img的css属性 object-fit ,需要把node_modules 依赖包里面的 html2canvas.js 文件里面找到这一段,然后把里面的内容替换成我下面的代码段,

CanvasRenderer.prototype.renderReplacedElement = function (container, curves, image) {
	        //把图片里面的代码改成这个
			if (image && container.intrinsicWidth > 0 && container.intrinsicHeight > 0) {
			  var box = contentBox(container);
			  var path = calculatePaddingBoxPath(curves);
 
			  this.path(path);
			  this.ctx.save();
			  this.ctx.clip();
 
			  let newWidth;
			  let newHeight;
			  let newX = box.left;
			  let newY = box.top;
 
			  if(container.intrinsicWidth / box.width < container.intrinsicHeight / box.height) {
				newWidth = box.width;
				newHeight = container.intrinsicHeight * (box.width / container.intrinsicWidth);
				newY = box.top + (box.height - newHeight) / 2;
			  } else {
				newWidth = container.intrinsicWidth * (box.height / container.intrinsicHeight);
				newHeight = box.height;
				newX = box.left + (box.width - newWidth) / 2;
			  }
 
			  this.ctx.drawImage(image, 0, 0, container.intrinsicWidth, container.intrinsicHeight, newX, newY, newWidth, newHeight);
			  this.ctx.restore();
			}

这样保存以后在打包上传到线上  就OK了,附一张成功的图片

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值