我的应用程序的第一部分从文件系统中使用文件选择器加载图片,并将图像绘制到画布上。我拿起画布并将其转换为数据URL,并将其保存在数据库中。
var imgData = canvas.toDataURL("image/jpg");
factory.saveData(imgData); // execute some java code
这是问题所在。我无法重绘该图片,我的JavaScript:
var pic = new Image();
pic.onload = function() {
ctx.drawImage(pic, 0, 0); // ctx = canvas.getContext("2d")
};
// This data url is copy/pasted from database for simplicity
pic.src = "..........ElFTkSuQmCC";
调用了onload函数,但是我得到的是透明图像。
答案 0 :(得分:1)
可能与getDataFromDatabase()
是异步的事实有关,因此您要将一个Promise对象返回到pic.src
而不是数据URL。通过在then
上使用getDataFromDatabase
调用并在pic.src
上使用结果来解决此问题:
var pic = new Image();
var pic.onload = function() {
ctx.drawImage(pic, 0, 0);
};
getDataFromDatabase().then(dataUrl => {
pic.src = dataUrl;
});
这是实际操作的完整示例。我绘制到画布上,将画布数据作为base64数据URL存储到变量中,使用闭包将其保存到模拟数据库中,然后使用promise从模拟的异步函数调用中重新加载数据。
const canvas = document.getElementById('myCanvas');
const ctx = canvas.getContext('2d');
// Initialize canvas to a random image
const imageUrl = 'https://cdn.sstatic.net/Sites/stackoverflow/company/img/logos/so/so-logo.svg?v=a010291124bf';
const initialImage = new Image();
initialImage.src = imageUrl;
initialImage.onload = function() {
ctx.drawImage(initialImage, 0, 0);
}
// Convert canvas to base64 data url
const imageData = canvas.toDataURL('image/png');
const getDataFromDatabase = saveData(imageData);
// Clear the canvas
ctx.clearRect(0, 0, canvas.width, canvas.height);
// Redraw the image
const pic = new Image();
getDataFromDatabase().then(data => {
pic.src = data;
});
pic.onload = function() {
ctx.drawImage(pic, 0, 0);
}
function saveData(image) {
return function getDataFromDatabase() {
return new Promise(resolve => {
resolve(image);
});
}
}
<canvas id="myCanvas">
</canvas>
编辑:从何处获取图像数据并不重要。如果数据格式正确,则应绘制到画布上。这是一个与从硬编码数据url加载图像数据的方式相同的示例:
const imageData = '';
const canvas = document.getElementById('myCanvas');
const ctx = canvas.getContext('2d');
const image = new Image();
image.onload = function() {
ctx.drawImage(image, 0, 0);
}
image.src = imageData;
<canvas id="myCanvas">
</canvas>
我建议您使用base64图像解码器检查图像数据,以查看图像数据是否格式错误。如果您的数据网址有效,那么我建议您确保画布的宽度和高度等于或大于图片的宽度和高度,否则它将被隐藏(如果您提供的图片具有空白/填充)。