我遇到了一个问题:我有两个坐标(起点和终点位置)和一个多边形。我想检查这条路线是(1)从多边形的外部到内部,(2)从内到外,(3)仅在内部,或(4)仅在外部。
我真的很感激任何帮助。
答案 0 :(得分:1)
你很幸运! Java包含Polygon
类,其方法为contains(double x, double y)
。使用它!
答案 1 :(得分: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;
}