canvas 绘制图片下载

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8">
        <title></title>
        
    </head>
    <body>
        <canvas id="canvas" width="400" height="400"></canvas>
        <div>
            <button id="save">保存</button>
        </div>
        <script type="text/javascript">
            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(); // 下载之后把创建的元素删除
                // const content = res;
                // const blob = new Blob([content]);
                // if ('msSaveOrOpenBlob' in navigator) {
                //     window.navigator.msSaveOrOpenBlob(blob, fileName);
                //     return;
                // }
                // const elink = document.createElement("a");
                // elink.download = fileName;
                // elink.style.display = "none";
                // elink.href = URL.createObjectURL(blob);
                // document.body.appendChild(elink);
                // elink.click();
                // URL.revokeObjectURL(elink.href);
                // document.body.removeChild(elink);
            }
        </script>
    </body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值