html5 canvas toDataURL 返回空白图像
html5 canvas toDataURL returns blank image
我使用以下代码绘制画布并使用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
实现所示,调用它只是启动加载过程;当所有图像都加载完毕时,即将来的某个时间,将调用回调。
目前,您得到的是空白图像,因为图像尚未加载,因此尚未调用回调,因此画布仍为空。
简而言之,依赖于已加载图像的所有内容(例如,您的预期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 返回空白图像
- 如何在提交空白表单时隐藏图像
- 使用.toDataUrl()将Chart.js画布图表转换为图像会导致空白图像
- 我正在尝试将 HTML 画布转换为 HTML 图像,但得到一个空白图像
- 使用 jsPDF 导出 Google 图表,在 Chrome 上工作,但在 Firefox 上不工作(文档中的空白图像)
- 图像的响应式空白图像叠加
- 使用 localStorage 存储和检索 PNG 时出现空白图像
- 排除 JQuery 轮播中的空白图像
- Canvas toDataURL() 给出空白图像
- 加载空白图像的速度比多个if语句快
- Canvas to DataURL()返回空白图像
- iPad上的HTML2Canvas空白图像和笔记本电脑上的非常低质量的图像
- 上传画布图像数据会导致空白图像
- Blob图像返回空白图像
- 获得空白图像与画布绘制大约一半的时间
- js幻灯片开始的空白图像- Ruby on Rails
- 为什么这个脚本以一个空白图像开始?
- 在服务器端保存画布图像时,从base64数据字符串生成空白图像
- OpenLibrary.org 返回空白图像,如何检测和替换它们