我想从图片中剪下一些正方形。问题是用Createjs
屏蔽的drawRect
在Safari中不起作用。请在Safari中查看以下codepen
https://codepen.io/anon/pen/moXXRN
它适用于除Safari之外的所有浏览器
这个问题不是掩盖或EaselJS,而是Safari如何处理用负坐标绘制的缠绕矩形。看起来大多数浏览器都会将具有一个负维度的矩形视为反向绘制,但Safari不会。
超级simple canvas example有同样的问题:
var ctx = document.getElementById("canvas").getContext("2d");
ctx.beginPath();
ctx.rect(50,50,50,50);
ctx.rect(150, 150, 50, 50);
ctx.rect(300, 0, 350, -350);
ctx.fillStyle = "red";
ctx.fill();
在大多数浏览器中,这会绘制剪切区域。 Safari没有。
您使用自己的lineTo()
命令的解决方案是一个很好的解决方法。
管理使用lineTo
和moveTo
函数而不是drawRect
在Safari中使用它
EG
shape.graphics.moveTo( 50, 50 );
shape.graphics.lineTo( 100, 50 );
shape.graphics.lineTo( 100, 100 );
shape.graphics.lineTo( 50, 100 );
shape.graphics.lineTo( 50, 50 );
shape.graphics.moveTo( 300, 0 );
shape.graphics.lineTo( 0, 0 );
shape.graphics.lineTo( 0, 300 );
shape.graphics.lineTo( 300, 300 );
shape.graphics.lineTo( 300, 0 );