gpt4 book ai didi

javascript - html5 Canvas toDataURL 返回空白图像

转载 作者:搜寻专家 更新时间:2023-10-31 08:35:39 25 4
gpt4 key购买 nike

我正在使用以下代码绘制 Canvas 并使用 toDataUrl 将其保存为 png 图像。

<!DOCTYPE HTML>
<html>
<head>
<style>
body {
margin: 0px;
padding: 0px;
}
#myCanvas {
border: 1px solid #9C9898;
}
</style>
<script>
function loadImages(sources, callback) {
var images = {};
var loadedImages = 0;
var numImages = 0;
// get num of sources
for(var src in sources) {
numImages++;
}
for(var src in sources) {
images[src] = new Image();
images[src].onload = function() {
if(++loadedImages >= numImages) {
callback(images);
}
};
images[src].src = sources[src];
}
}

window.onload = function(images) {
var canvas = document.getElementById("myCanvas");
var context = canvas.getContext("2d");

var sources = {
darthVader: "http://a1.sphotos.ak.fbcdn.net/hphotos-ak-snc6/228564_449431448422343_1996991887_n.jpg",
yoda: "http://a4.sphotos.ak.fbcdn.net/hphotos-ak-snc7/427489_449423165089838_503188418_n.jpg"
};

loadImages(sources, function(images) {
context.drawImage(images.darthVader, 250, 30, 250, 250);
context.drawImage(images.yoda, 530, 30, 250, 250);
});


// save canvas image as data url (png format by default)
var dataURL = canvas.toDataURL();

// set canvasImg image src to dataURL
// so it can be saved as an image
document.getElementById("canvasImg").src = dataURL;
};


</script>
</head>
<body>
<canvas id="myCanvas" width="850" height="315"></canvas>
<img id="canvasImg" alt="Right click to save me!">
</body>
</html>

但是我的 png 图像显示为空白图像。我只看到一个空白的白色图像。我搜索了这个但没有找到任何东西。我正在使用 php 和 chrome 浏览器。这里有什么问题?

最佳答案

您首先调用 loadImages,然后在 loadImages 调用 之后立即获取数据 URL。但是,正如您的 loadImages 实现所示,调用它只会启动加载过程;当所有图像都已加载时调用回调,这是 future 的某个时间。

目前你得到的是一张空白图片,因为图片还没有加载,所以你的回调还没有被调用,因此你的 Canvas 仍然是空的。

简而言之,所有依赖于已加载图像的内容(例如您预期的 toDataURL 结果)都应该在这些图像实际加载时执行 - 因此在回调中。

loadImages(sources, function(images) {
context.drawImage(images.darthVader, 250, 30, 250, 250);
context.drawImage(images.yoda, 530, 30, 250, 250);

var dataURL = canvas.toDataURL();
document.getElementById("canvasImg").src = dataURL;
});

关于javascript - html5 Canvas toDataURL 返回空白图像,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12005049/

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