不相交多边形中的点

Posted

技术标签:

【中文标题】不相交多边形中的点【英文标题】:Point in Disjoint Polygon 【发布时间】:2015-02-13 06:59:54 【问题描述】:

我想检查给定点是否位于多边形内。 我已经使用光线投射研究了多边形方法中的点,但我不确定在给定多边形不相交的情况下它将如何工作。例如,如果多边形的中心有一个“洞”。这种情况下如何使用这个功能?

【问题讨论】:

这不是多边形孔。要使用 pip 光线投射,您需要将此孔近似为多边形孔。 【参考方案1】:

我已经回答了一个类似的问题here,尽管我不清楚我是否太了解 OP 的问题。嗯,又来了- 让我们举一个非常普遍的案例。 带孔和交叉点的多边形

光线投射(多边形中的点)算法射出一条光线,计算与 POLYGON 边的交点(奇数交点 = 内部,偶数 = 外部)。 因此,无论您是从不相交的梯形孔还是三角形孔(内边缘?)内部开始,或者即使多边形的一部分完全分离和/或自相交,它都能准确地给出正确的结果。 但是,您以什么顺序输入多边形的顶点,以便正确评估所有点? 虽然这是特定于代码的,但如果您使用的是计算与多边形边的每个交点的实现,那么这种方法将起作用 - - 将主多边形分解为多边形组件。例如 - 梯形孔是一个多边形组件。 - 从 (0,0) 顶点开始(与 (0,0) 实际位于多边形的位置无关),然后是第一个组件的顶点,在最后一个顶点之后重复其第一个顶点。 - 包括另一个 (0,0) 顶点。 - 包括下一个组件,在最后一个顶点之后重复它的第一个顶点。 - 对每个组件重复上述两个步骤。 - 以最终 (0,0) 顶点结束。 示例 - 让我们把右边的照片,带孔的外壳,应用上面的方法。在数学上等效于 2 个分量(多边形+孔)的奇异连续多边形的顶点是 - (外)-------(内孔) 0,1,2,3,4,5,1,0,1,2,3,4,1,0

要了解它的工作原理,请尝试在便笺本上绘制这个数学上等效的多边形。- 1. 标记所有顶点,但不要加入它们。 2. 也分别标记重复的顶点。通过将它们标记为靠近原始点而不是在它们上来做到这一点。 (在距离 e 处,其中 e->0(趋向/接近))(帮助可视化) 3. 现在以正确的顺序连接所有顶点(如上例所示) 您会注意到这形成了一个连续的多边形,并且仅在 e=0 限制处变得不相交。 您现在可以毫无问题地将这个数学上等效的多边形发送到您的光线投射函数(甚至可能是绕组数函数?)。

【讨论】:

以上是关于不相交多边形中的点的主要内容,如果未能解决你的问题,请参考以下文章

创建穿过所有给定点的非相交多边形

boost 多边形相交 API 的工作方式与应有的方式相反

多边形相交的简单算法

LightOj1285 - Drawing Simple Polygon(连接多边形各点)

Sympy中迭代相交的线段......有更好的方法吗?

如何对谷歌地图多边形中的点进行排序以使线不交叉?