このコードは、キャンバスの画像ファイルに色合いを付けることがわかりました。この色合いのコンテキストで ctx.save と ctx.restore が何に使用されているのか疑問に思っていますか? なぜここで必要なのですか?
function recolor(color) {
ctx.save();
ctx.clearRect(0, 0, canvas.width, canvas.height);
ctx.drawImage(pic, 0, 0);
ctx.globalCompositeOperation = "source-in";
ctx.fillStyle = color;
ctx.rect(0, 0, canvas.width, canvas.height);
ctx.fill();
ctx.restore();
var img = new Image();
img.src = canvas.toDataURL();
return (img);
}