js将canvas保存成图片并下载

<canvas id="canvas" width="400" height="400"></canvas>
<div>
	<button id="save">保存</button>
</div>

  

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(); // 下载之后把创建的元素删除
}

 文中图片是个七巧板,如下:

 

  

转载于:https://www.cnblogs.com/zhaodesheng/p/9848496.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值