gpt4 book ai didi

javascript - pdfmake base64 图片回调

转载 作者:行者123 更新时间:2023-11-30 19:15:44 25 4
gpt4 key购买 nike

我必须使用 pdfmake 在我的 laravel 应用程序中构建 pdf 预览。我是一个 javascript 菜鸟,疯狂地为 b 中的图像生成 dataURI。希望你能帮帮我。如何将生成的 base64 放入我的文档定义中?

    function convertImageToDataURL(src, callback, outputFormat) {
// Create an Image object
var img = new Image();
// Add CORS approval to prevent a tainted canvas
img.crossOrigin = 'Anonymous';
img.onload = function() {
var canvas = document.createElement('CANVAS');
var ctx = canvas.getContext('2d');
var dataURL;
canvas.height = this.naturalHeight;
canvas.width = this.naturalWidth;
ctx.drawImage(this, 0, 0);
dataURL = canvas.toDataURL(outputFormat);
callback(dataURL);

// Mark the canvas to be ready for garbage
// collection
canvas = null;
};

img.src = src;
// make sure the load event fires for cached images too
if (img.complete || img.complete === undefined) {
// Flush cache
img.src = '';
// Try again
img.src = src;
}
}

convertImageToDataURL(
'{{asset('storage/'.$report->author->enterprises->first()->logo_image)}}',
function(dataUrl) {
// console.log('RESULT:', dataUrl);
// Put dataUrl into DocDefinition here!?!?
// return dataUrl is undefined
}
);`

最佳答案

好的。正如我所说:我是一个 javascript 菜鸟。所以我将脚本更改为这个:

function convertImageToDataURL(imgSrc) {
img = new Image();
img.src = imgSrc;
img.crossOrigin = "Anonymous";

var canvas = document.createElement("canvas");
canvas.width = img.naturalWidth;
canvas.height = img.naturalHeight;
var ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0);
var dataURL = canvas.toDataURL("image/jpg");

canvas = null;
return dataURL;
}

它可能不漂亮也不优雅,但它适合我。

关于javascript - pdfmake base64 图片回调,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58028552/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com