今天突然发现了这个棘手的问题,在 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了,附一张成功的图片