网站制作网站推广,中国建设网站轨道自检验收报告表,空调维修自己做网站,wordpress主题制作价格我们都知道在canvas 可以通过clip来实现剪裁功能#xff0c;其步骤一般是先设置要裁剪的区域#xff08;路径#xff09;#xff0c;然后通过ctx.clip()的实现裁剪#xff0c;裁剪之后#xff0c;后续的绘制只能在裁剪的区域显示效果#xff0c;比如如下一段代码#x… 我们都知道在canvas 可以通过clip来实现剪裁功能其步骤一般是先设置要裁剪的区域路径然后通过ctx.clip()的实现裁剪裁剪之后后续的绘制只能在裁剪的区域显示效果比如如下一段代码实现了一个圆形裁剪 ctx.beginPath();
ctx.arc(100,100,50,0,Math.PI*2);
ctx.clip();ctx.rect(0,0,200,200);
ctx.fillStylered;
ctx.fill(); 最终效果如下 有的时候我们希望能够实现反向裁剪比如上面例子中我们希望是圆圈外面是裁剪区域而不是圆圈内部是裁剪区域。这就是标题所说的反向裁剪。效果如下图所示如何实现反向裁剪呢笔者通过实践发现有以下几种思路。 使用合成模式globalCompositeOperation 通过设置globalCompositeOperation的值可以实现类似的反向裁剪的效果。大致思路是 首先绘制一个图形比如圆形该图形外部的区域将会是裁剪区域设置globalCompositeOperation的值为source-out然后绘制想要绘制的图形比如矩形示例代码如下 ctx.beginPath();ctx.arc(100, 100, 50, 0, Math.PI * 2);
ctx.fillStyle red;
ctx.fill();ctx.beginPath();
ctx.globalCompositeOperation source-out;
ctx.rect(0, 0, 200, 200);
ctx.fillStyle red;
ctx.fill(); 最终效果参考上面的图形“反向裁剪”。 使用clip clearRect方法 另外一种思路是使用clip clearRect方法大概的思路如下 首先绘制要绘制的图形比如矩形然后设置要反向裁剪的图形的路径比如圆形然后调用clip 再调用clearRect方法清除圆形区域的像素。示例代码如下 ctx.beginPath();ctx.rect(0, 0, 200, 200);ctx.fillStyle red;ctx.fill();ctx.beginPath();ctx.arc(100, 100, 50, 0, Math.PI * 2);ctx.clip();ctx.clearRect(0, 0, 200, 200); 最终效果参考上面的图形“反向裁剪”。 利用非零环绕原则 我们知道非零环绕原则可以通过调整路径的方向顺时针和逆时针来实现挖空的效果大致思路如下 首先构建一个大的区域路径顺时针方向比如矩形然后构建一个小的区域路径逆时针方向比如圆形调用clip裁剪然后绘制图形示例代码如下 ctx.beginPath();
ctx.rect(0, 0, 200, 200); //顺时针方向
ctx.arc(100, 100, 50, 0, Math.PI * 2, true); // 逆时针方向
ctx.clip();ctx.beginPath();
ctx.rect(0, 0, 200, 200);
ctx.fillStyle red;
ctx.fill(); arc方法的最后一个参数可以控制顺时针false和逆时针true而rect方法没有可以通过moveTolineTo自己构建逆时针的rect方法如下代码所示 function counterclockwiseRect(ctx, x, y, w, h) {ctx.moveTo(x, y);ctx.lineTo(x, y h);ctx.lineTo(x w, y h);ctx.lineTo(x w, y);ctx.lineTo(x, y);
} 最终效果参考上面的图形“反向裁剪”。 参考文档 https://stackoverflow.com/que...https://stackoverflow.com/que...http://caibaojian.com/canvas/...非零环绕原则 欢迎关注公众号“ITman彪叔”。彪叔拥有10多年开发经验现任公司系统架构师、技术总监、技术培训师、职业规划师。熟悉Java、JavaScript、Python语言熟悉数据库。熟悉java、nodejs应用系统架构大数据高并发、高可用、分布式架构。在计算机图形学、WebGL、前端可视化方面有深入研究。对程序员思维能力训练和培训、程序员职业规划有浓厚兴趣。