码迷,mamicode.com
首页 > 其他好文 > 详细

Canvas中的非零环绕

时间:2018-11-26 13:36:18      阅读:159      评论:0      收藏:0      [点我收藏+]

标签:图片   png   分享   逆时针   计数器   fill   线段   方法   原理   

先上图

技术分享图片

当要填充图形时,必须区分开哪些部分是覆盖的,哪些是空的,根据绘制的方向可以判断出来

非零环绕规则:对于路径中指定范围区域,从该区域内部画一条足够长的线段,使此线段的完全落在路径范围之外。

非零环绕规则计数器:
然后,将计数器初始化为0,每当这个线段与路径上的直线或曲线相交时,就改变计数器的值,如果是与路径顺时针相交时,那么计数器就加1, 如果是与路径逆时针相交时,那么计数器就减1.
如果计数器始终不为0,那么此区域就在路径范围里面,在调用fill()方法时,浏览器就会对其进行填充。如果最终值是0,那么此区域就不在路径范围内,浏览器就不会对其进行填充。

如图
线段1:根据非零环绕规则,这条直线只经过路径一次且路径是逆时针方向,那么计数器为-1;

根据浏览器对计数器的计算原理得出,当调用fill()方法时浏览器会填充此区域。

 

线段2:根据非零环绕规则,这条直线经过路径二次且路径都是逆时针方向,那么计数器为-2;

根据浏览器对计数器的计算原理得出,当调用fill()方法时浏览器会填充此区域。

 

线段3:根据非零环绕规则,这条直线经过路径二次;第一次经过的路径是逆时针方向,计数器则为-1;

第二次经过的路径是顺时针方向,计数器为1;原因计数器的最终值为0-1+1 = 0;

所以根据浏览器对计数器的计算原理得出,当调用fill()方法时浏览器不会填充此区域。

 

Canvas中的非零环绕

标签:图片   png   分享   逆时针   计数器   fill   线段   方法   原理   

原文地址:https://www.cnblogs.com/youthBlog/p/10019537.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!