我想在画布上显示多个globalCompositeOperation结果。我按照以下方式编写了代码 您的浏览器不支持HTML5
<canvas id = "tempCanvas" width = "400" height = "100" style = "display: none;">
</canvas>
<script>
var context = document.getElementById("canvas").getContext("2d");
var tempContext = document.getElementById("tempCanvas").getContext("2d");
var offset = 10;
var operationValues = new Array();
operationValues.push("source-atop");
operationValues.push("source-in");
operationValues.push("source-out");
operationValues.push("source-over");
for (var i = 0; i < operationValues.length; i++) {
tempContext.save();
tempContext.clearRect(0, 0, 400, 100);
//draw destination rectangle
tempContext.beginPath();
tempContext.rect(10, 10, 50, 50);
tempContext.fillStyle = 'red';
tempContext.fill();
tempContext.globalCompositeOperation = operationValues[i];
//draw source rectangle
tempContext.beginPath();
tempContext.rect(40, 40, 50, 50);
tempContext.fillStyle = 'green';
tempContext.fill();
/*
*the result will be incorrect
*if you remove tempContext.restore() function
*/
tempContext.restore();
context.drawImage(document.getElementById("tempCanvas"), 0, 0);
context.translate(100, 0);
}
</script>
为什么我们需要恢复tempContext?
为什么在没有恢复tempContext的情况下最后结果是正确的?
在http://jsfiddle.net/thepyaethuaung/pcNvA/3/