【问题标题】:HTML5 Canvas not clipping correctly?HTML5 Canvas 没有正确裁剪?
【发布时间】:2016-06-10 03:38:23
【问题描述】:

我想知道以下代码是否会产生适当的行为。我觉得左上角的正方形应该还是绿色的。也就是说,如果我剪切一个区域,十个恢复,然后在第二个区域进行绘制,则画布会在两个区域中进行绘制。为什么?

https://jsfiddle.net/s6t8k3w3/

var my_canvas = document.getElementById('canvas');
var ctx = my_canvas.getContext("2d");

//Make Clipping Path 1
ctx.save();
ctx.rect(20, 20, 100, 100);
ctx.clip();

//Fill Background with Green
ctx.fillStyle = 'rgba(0,255,0,1)';
ctx.fillRect(0, 0, my_canvas.width, my_canvas.height);
//Close Clipping Path 1
ctx.restore();

//Open Clipping Path 2
ctx.save();
ctx.rect(50, 50, 100, 100);
ctx.clip();

//Fill background with Blue
ctx.fillStyle = 'rgba(0,0,255,1)';
ctx.fillRect(0, 0, my_canvas.width, my_canvas.height);

//Draw Line
ctx.beginPath();
ctx.moveTo(0, 0);
ctx.lineTo(500, 500);
ctx.stroke();

//CloseClipping Path 2
ctx.restore();

【问题讨论】:

  • 在每组单独的路径命令之前使用ctx.beginPath,否则后续的stroke/fill 将重绘自上次 beginPath 以来的所有内容。

标签: javascript html html5-canvas clipping


【解决方案1】:

您实际上并没有使用第二个ctx.save() 打开第二个剪切路径;为此,您需要致电ctx.beginPath()

【讨论】:

  • 非常感谢你们俩。显然我必须更好地理解这个主题!显然,这行得通!
猜你喜欢
  • 2020-12-25
  • 2015-03-16
  • 1970-01-01
  • 2018-09-09
  • 2018-10-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多