我想知道如何将画布的背景图像设置为.png文件。我不想在画布背面添加图像并使画布透明。
我希望用户能够在背景为.png图像的情况下实际绘制该画布,以便稍后可以使用用户制作的图形将其提取为.png。
答案 0 :(得分:36)
如this example所示,您可以通过CSS将背景应用于canvas
元素,并且此背景不会被视为图像的一部分,例如通过toDataURL()
获取内容时。
以下是Stack Overflow后代的示例内容:
<!DOCTYPE HTML>
<html><head>
<meta charset="utf-8">
<title>Canvas Background through CSS</title>
<style type="text/css" media="screen">
canvas, img { display:block; margin:1em auto; border:1px solid black; }
canvas { background:url(lotsalasers.jpg) }
</style>
</head><body>
<canvas width="800" height="300"></canvas>
<img>
<script type="text/javascript" charset="utf-8">
var can = document.getElementsByTagName('canvas')[0];
var ctx = can.getContext('2d');
ctx.strokeStyle = '#f00';
ctx.lineWidth = 6;
ctx.lineJoin = 'round';
ctx.strokeRect(140,60,40,40);
var img = document.getElementsByTagName('img')[0];
img.src = can.toDataURL();
</script>
</body></html>
答案 1 :(得分:15)
您可以在css中提供背景图片:
#canvas { background:url(example.jpg) }
它会显示画布背景图像
答案 2 :(得分:4)
您可以在画布上绘制图像,让用户在其上绘制。
drawImage()
功能可以帮助您,请参阅https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Canvas_tutorial/Using_images
答案 3 :(得分:0)
您可以使用此插件,但出于打印目的,我添加了一些代码
<button onclick="window.print();">Print</button>
以及保存图片<button onclick="savePhoto();">Save Picture</button>
function savePhoto() {
var canvas = document.getElementById("canvas");
var img = canvas.toDataURL("image/png");
window.location = img;}
结帐此插件 http://www.williammalone.com/articles/create-html5-canvas-javascript-drawing-app