点评:将HTML5 Canvas的内容保存为图片主要思想是借助Canvas自己的API - toDataURL()来实现,具体实现如下,感兴趣的朋友可以参考下哈,希望对你有所帮助
主要思想是借助Canvas自己的API - toDataURL()来实现,整个实现
wBHHTML5中文学习网 - HTML5先行者学习网HTML + JavaScript的代码很简单。
wBHHTML5中文学习网 - HTML5先行者学习网 wBHHTML5中文学习网 - HTML5先行者学习网
<html> wBHHTML5中文学习网 - HTML5先行者学习网
<meta http-equiv="X-UA-Compatible" content="chrome=1"> wBHHTML5中文学习网 - HTML5先行者学习网
<head> wBHHTML5中文学习网 - HTML5先行者学习网
<script> wBHHTML5中文学习网 - HTML5先行者学习网
window.onload = function() { wBHHTML5中文学习网 - HTML5先行者学习网
draw(); wBHHTML5中文学习网 - HTML5先行者学习网
var saveButton = document.getElementById("saveImageBtn"); wBHHTML5中文学习网 - HTML5先行者学习网
bindButtonEvent(saveButton, "click", saveImageInfo); wBHHTML5中文学习网 - HTML5先行者学习网
var dlButton = document.getElementById("downloadImageBtn"); wBHHTML5中文学习网 - HTML5先行者学习网
bindButtonEvent(dlButton, "click", saveAsLocalImage); wBHHTML5中文学习网 - HTML5先行者学习网
}; wBHHTML5中文学习网 - HTML5先行者学习网
function draw(){ wBHHTML5中文学习网 - HTML5先行者学习网
var canvas = document.getElementById("thecanvas"); wBHHTML5中文学习网 - HTML5先行者学习网
var ctx = canvas.getContext("2d"); wBHHTML5中文学习网 - HTML5先行者学习网
ctx.fillStyle = "rgba(125, 46, 138, 0.5)"; wBHHTML5中文学习网 - HTML5先行者学习网
ctx.fillRect(25,25,100,100); wBHHTML5中文学习网 - HTML5先行者学习网
ctx.fillStyle = "rgba( 0, 146, 38, 0.5)"; wBHHTML5中文学习网 - HTML5先行者学习网
ctx.fillRect(58, 74, 125, 100); wBHHTML5中文学习网 - HTML5先行者学习网
ctx.fillStyle = "rgba( 0, 0, 0, 1)"; // black color wBHHTML5中文学习网 - HTML5先行者学习网
ctx.fillText("Gloomyfish - Demo", 50, 50); wBHHTML5中文学习网 - HTML5先行者学习网
} wBHHTML5中文学习网 - HTML5先行者学习网
function bindButtonEvent(element, type, handler) wBHHTML5中文学习网 - HTML5先行者学习网
{ wBHHTML5中文学习网 - HTML5先行者学习网
if(element.addEventListener) { wBHHTML5中文学习网 - HTML5先行者学习网
element.addEventListener(type, handler, false); wBHHTML5中文学习网 - HTML5先行者学习网
} else { wBHHTML5中文学习网 - HTML5先行者学习网
element.attachEvent('on'+type, handler); wBHHTML5中文学习网 - HTML5先行者学习网
} wBHHTML5中文学习网 - HTML5先行者学习网
} wBHHTML5中文学习网 - HTML5先行者学习网
function saveImageInfo () wBHHTML5中文学习网 - HTML5先行者学习网
{ wBHHTML5中文学习网 - HTML5先行者学习网
var mycanvas = document.getElementById("thecanvas"); wBHHTML5中文学习网 - HTML5先行者学习网
var image = mycanvas.toDataURL("image/png"); wBHHTML5中文学习网 - HTML5先行者学习网
var w=window.open('about:blank','image from canvas'); wBHHTML5中文学习网 - HTML5先行者学习网
w.document.write("<img src='"+image+"' alt='from canvas'/>"); wBHHTML5中文学习网 - HTML5先行者学习网
} wBHHTML5中文学习网 - HTML5先行者学习网
function saveAsLocalImage () { wBHHTML5中文学习网 - HTML5先行者学习网
var myCanvas = document.getElementById("thecanvas"); wBHHTML5中文学习网 - HTML5先行者学习网
// here is the most important part because if you dont replace you will get a DOM 18 exception. wBHHTML5中文学习网 - HTML5先行者学习网
// var image = myCanvas.toDataURL("image/png").replace("image/png", "image/octet-stream;Content-Disposition: attachment;filename=foobar.png"); wBHHTML5中文学习网 - HTML5先行者学习网
var image = myCanvas.toDataURL("image/png").replace("image/png", "image/octet-stream"); wBHHTML5中文学习网 - HTML5先行者学习网
window.location.href=image; // it will save locally wBHHTML5中文学习网 - HTML5先行者学习网
} wBHHTML5中文学习网 - HTML5先行者学习网
</script> wBHHTML5中文学习网 - HTML5先行者学习网
</head> wBHHTML5中文学习网 - HTML5先行者学习网
<body bgcolor="#E6E6FA"> wBHHTML5中文学习网 - HTML5先行者学习网
<div> wBHHTML5中文学习网 - HTML5先行者学习网
<canvas width=200 height=200 id="thecanvas"></canvas> wBHHTML5中文学习网 - HTML5先行者学习网
<button id="saveImageBtn">Save Image</button> wBHHTML5中文学习网 - HTML5先行者学习网
<button id="downloadImageBtn">Download Image</button> wBHHTML5中文学习网 - HTML5先行者学习网
</div> wBHHTML5中文学习网 - HTML5先行者学习网
</body> wBHHTML5中文学习网 - HTML5先行者学习网
</html> wBHHTML5中文学习网 - HTML5先行者学习网
wBHHTML5中文学习网 - HTML5先行者学习网运行效果如下:
wBHHTML5中文学习网 - HTML5先行者学习网
wBHHTML5中文学习网 - HTML5先行者学习网