Java 如何通过坐标检查路线

Java 如何通过坐标检查路线,java,algorithm,polygon,Java,Algorithm,Polygon,我有一个问题:我有两个坐标(起点和终点位置)和一个多边形。我想检查这条路线是(1)从多边形的外部到内部,(2)从内部到外部,(3)仅内部,还是(4)仅外部 我非常感谢您的帮助。请参阅本页: 这个函数就是从这里开始的 它基于这样一个观察结果,即测试点位于多边形内,如果在y轴上投影时,其x值低于奇数个多边形边。适用于凸多边形和凹多边形 int pnpoly(int nvert, float *vertx, float *verty, float testx, float testy) { in

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

我非常感谢您的帮助。

请参阅本页:

这个函数就是从这里开始的

它基于这样一个观察结果,即测试点位于多边形内,如果在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;
}
int-pnpoly(int-nvert,float*vertx,float*verty,float-testx,float-testy)
{
int i,j,c=0;
对于(i=0,j=nvert-1;itesty)!=(verty[j]>testy))&&
(testx<(vertx[j]-vertx[i])*(testy-verty[i])/(verty[j]-verty[i])+vertx[i]))
c=!c;
}
返回c;
}

你真幸运!Java包含一个具有方法的
Polygon
类。用它

你可能有一个好朋友。你试过实现它吗?谷歌搜索多边形中的点算法。