0

我有一个问题:我有两个坐标(起点和终点位置)和一个多边形。我想检查这条路线是(1)从多边形的外部到内部,(2)从内部到外部,(3)仅在内部,还是(4)仅在外部。

我真的很感激任何帮助。

4

2 回答 2

1

你很幸运!Java 包含一个Polygon具有方法的类contains(double x, double y)。用它!

于 2012-10-25T12:51:44.523 回答
0

请参阅此页面: http: //www.ecse.rpi.edu/Homepages/wrf/Research/Short_Notes/pnpoly.html

此功能是从那里获取的。

它基于观察到,如果在 y 轴上投影时,测试点的 x 值低于多边形边缘的奇数,则测试点位于多边形内。适用于凸多边形和凹多边形。

int pnpoly(int nvert, float *vertx, float *verty, float testx, float testy)
{
  int i, j, c = 0;
  for (i = 0, j = nvert-1; i < nvert; j = i++) {
    if ( ((verty[i]>testy) != (verty[j]>testy)) &&
     (testx < (vertx[j]-vertx[i]) * (testy-verty[i]) / (verty[j]-verty[i]) + vertx[i]) )
       c = !c;
  }
  return c;
}
于 2012-10-25T12:51:17.760 回答