是否可以捕获或打印html画布中显示的图像或pdf?
我希望通过画布生成图像,并能够从该图像生成png。
是否可以捕获或打印html画布中显示的图像或pdf?
我希望通过画布生成图像,并能够从该图像生成png。
当前回答
如果你想让画布消失,你可以使用这个片段
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<canvas id=canvas width=200 height=200></canvas>
<iframe id='img' width=200 height=200></iframe>
<script>
window.onload = function() {
var canvas = document.getElementById("canvas");
var context = canvas.getContext("2d");
context.fillStyle = "green";
context.fillRect(50, 50, 100, 100);
document.getElementById('img').src = canvas.toDataURL("image/jpeg");
console.log(canvas.toDataURL("image/jpeg"));
}
</script>
</body>
</html>
其他回答
我会使用“wkhtmltopdf”。它工作得很好。它使用webkit引擎(在Chrome、Safari等中使用),并且非常容易使用:
wkhtmltopdf stackoverflow.com/questions/923885/ this_question.pdf
就是这样!
试试看
在某些版本的Chrome上,您可以:
使用绘制图像函数ctx.drawImage(image1,0,0,w,h);在画布上单击鼠标右键
最初的答案是针对一个类似的问题。已修订如下:
const canvas = document.getElementById('mycanvas')
const img = canvas.toDataURL('image/png')
使用IMG中的值,您可以将其写入新图像,如下所示:
document.getElementById('existing-image-id').src = img
or
document.write('<img src="'+img+'"/>');
您可以使用jspdf将画布捕获为图像或pdf,如下所示:
var imgData = canvas.toDataURL('image/png');
var doc = new jsPDF('p', 'mm');
doc.addImage(imgData, 'PNG', 10, 10);
doc.save('sample-file.pdf');
更多信息:https://github.com/MrRio/jsPDF
我想我会把这个问题的范围扩大一点,在这个问题上提供一些有用的花絮。
为了将画布作为图像,您应该执行以下操作:
var canvas = document.getElementById("mycanvas");
var image = canvas.toDataURL("image/png");
您可以使用此选项将图像写入页面:
document.write('<img src="'+image+'"/>');
其中“image/png”是mime类型(png是唯一必须支持的类型)。如果您想要一个受支持类型的数组,可以按照以下方式进行操作:
var imageMimes = ['image/png', 'image/bmp', 'image/gif', 'image/jpeg', 'image/tiff']; //Extend as necessary
var acceptedMimes = new Array();
for(i = 0; i < imageMimes.length; i++) {
if(canvas.toDataURL(imageMimes[i]).search(imageMimes[i])>=0) {
acceptedMimes[acceptedMimes.length] = imageMimes[i];
}
}
您只需要在每个页面上运行一次,它在页面的生命周期中永远不会改变。
如果希望让用户在保存文件时下载文件,可以执行以下操作:
var canvas = document.getElementById("mycanvas");
var image = canvas.toDataURL("image/png").replace("image/png", "image/octet-stream"); //Convert image to 'octet-stream' (Just a download, really)
window.location.href = image;
如果您将其用于不同的mime类型,请确保更改image/png的两个实例,但不要更改image/octet流。还值得一提的是,如果在渲染画布时使用任何跨域资源,则在尝试使用toDataUrl方法时会遇到安全错误。