var arr = [ {locations:[[0,0],[200,200],[0,400]],color:"red"}, {locations:[[0,0],[400,0],[2_js canvas保存图片">
当前位置:   article > 正文

js将canvas保存成图片并下载_js canvas保存图片

js canvas保存图片

js将canvas保存成图片并下载

<canvas id="canvas" width="400" height="400"></canvas>
<div>
    <button id="save">保存</button>
</div>
  • 1
  • 2
  • 3
  • 4
var arr = [
    {locations:[[0,0],[200,200],[0,400]],color:"red"},
    {locations:[[0,0],[400,0],[200,200]],color:"orange"},
    {locations:[[0,400],[100,300],[200,400]],color:"yellow"},
    {locations:[[100,300],[200,200],[300,300],[200,400]],color:"green"},
    {locations:[[300,100],[200,200],[300,300]],color:"blue"},
    {locations:[[300,100],[400,0],[400,200],[300,300]],color:"indigo"},
    {locations:[[200,400],[400,400],[400,200]],color:"purple"}
];
var oCanvas = document.getElementById("canvas");
var ctx = oCanvas.getContext("2d");
for(let i=0;i<arr.length;i++){
    draw(arr[i],ctx);
}
 
function draw(item,ctx){
    ctx.beginPath();
    ctx.moveTo(item.locations[0][0],item.locations[0][1]);
    for(let i = 0;i<item.locations.length;i++){
        let x = item.locations[i][0];
        let y = item.locations[i][1];
        ctx.lineTo(x,y);
        console.log(1234567)
    }
    ctx.closePath();
     
    ctx.fillStyle = item.color;
    ctx.fill();
     
    ctx.strokeStyle = "#000";
    ctx.lineWidth = 2;
    ctx.stroke();
}
var imgId = document.getElementById("imgId");
document.getElementById("save").onclick = function (){
    downLoad(saveAsPNG(canvas));
}
 
// 保存成png格式的图片
function saveAsPNG(canvas) {
    return canvas.toDataURL("image/png");
}
 
// 保存成jpg格式的图片
function saveAsJPG(canvas) {
    return canvas.toDataURL("image/jpeg");
}
 
// 保存成bmp格式的图片  目前浏览器支持性不好
function saveAsBMP(canvas) {
    return canvas.toDataURL("image/bmp");
}
 
/**
 * @author web得胜
 * @param {String} url 需要下载的文件地址
 * */
function downLoad(url){
    var oA = document.createElement("a");
    oA.download = '';// 设置下载的文件名,默认是'下载'
    oA.href = url;
    document.body.appendChild(oA);
    oA.click();
    oA.remove(); // 下载之后把创建的元素删除
}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38
  • 39
  • 40
  • 41
  • 42
  • 43
  • 44
  • 45
  • 46
  • 47
  • 48
  • 49
  • 50
  • 51
  • 52
  • 53
  • 54
  • 55
  • 56
  • 57
  • 58
  • 59
  • 60
  • 61
  • 62
  • 63
  • 64
  • 65

文中图片是个七巧板,如下:
在这里插入图片描述

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/229338
推荐阅读
相关标签
  

闽ICP备14008679号