[英]Can't draw image to canvas in javascript
我試圖在將輸入圖像保存到數據庫之前將水印圖像放在輸入圖像上。 我正在使用 canvas 來執行此操作,然后將 canvas 轉換回 blob,但是當我引用項目本地文件目錄中的水印圖像以繪制到 canvas 時,我得到了一個“可能未導出的畫布”。 控制台中的錯誤。
// Read input file
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = () => {
// Create canvas & calculate Stamp size and position
const canvas = document.createElement("canvas");
canvas.width = canvasSize.width;
canvas.height = canvasSize.height;
var calcW = canvasSize.width/2;
var calcH = calcW/2.16;
var calcX = (canvasSize.width - calcW)/2;
var calcY = (canvasSize.height - calcH)/2;
// Load input image into canvas
const img = document.createElement("img");
img.src = reader.result;
img.onload = () => {
const ctx = canvas.getContext("2d");
ctx.drawImage(img, 0, 0);
//Load & draw the Stamp image
const mark = new Image();
mark.src = 'assets/img/compliant.png'; // <<TAINTED ASSET?
mark.onload = () => {
ctx.drawImage(mark, calcX,calcY,calcW,calcH);
// Convert to blob and get URL
canvas.toBlob((canvasBlob) => {
const newImg = document.createElement("img"),
url = URL.createObjectURL(canvasBlob);
newImg.onload = function () {
//Destroy objecturl after image loading
URL.revokeObjectURL(url);
};
// Show stamped image
newImg.src = url;
window.open(url);
});
};
};
};
});
你必須使用 img.crossOrigin='anonymous'; 在您要操作的每個圖像上(繪制 canvas,轉換為數組緩沖區……這是為了防止您操作潛在的私有用戶數據) https://developer.mozilla.org/en-US/docs/Web/HTML /元素/視頻#attr-crossorigin
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.