mirror of https://github.com/apache/lucene.git
LUCENE-8736: Fix Polygon.contains to approriately check longitude range, and pass correct line segment vertices in EdgeTree
This commit is contained in:
parent
bd8905150d
commit
faa78ad72c
|
@ -140,6 +140,8 @@ public abstract class EdgeTree {
|
||||||
double maxLon = StrictMath.max(StrictMath.max(ax, bx), cx);
|
double maxLon = StrictMath.max(StrictMath.max(ax, bx), cx);
|
||||||
if (maxLon < this.minLon || minLon > this.maxLon || maxLat < this.minLat || minLat > this.maxLat) {
|
if (maxLon < this.minLon || minLon > this.maxLon || maxLat < this.minLat || minLat > this.maxLat) {
|
||||||
return Relation.CELL_OUTSIDE_QUERY;
|
return Relation.CELL_OUTSIDE_QUERY;
|
||||||
|
} else if (bx == cx && by == cy) {
|
||||||
|
return componentRelateTriangle(bx, by, ax, ay, cx, cy);
|
||||||
}
|
}
|
||||||
return componentRelateTriangle(ax, ay, bx, by, cx, cy);
|
return componentRelateTriangle(ax, ay, bx, by, cx, cy);
|
||||||
}
|
}
|
||||||
|
|
|
@ -271,7 +271,9 @@ public final class Polygon2D extends EdgeTree {
|
||||||
if (isOnEdge.get() == false && lat <= edge.max) {
|
if (isOnEdge.get() == false && lat <= edge.max) {
|
||||||
if (lat == edge.lat1 && lat == edge.lat2 ||
|
if (lat == edge.lat1 && lat == edge.lat2 ||
|
||||||
(lat <= edge.lat1 && lat >= edge.lat2) != (lat >= edge.lat1 && lat <= edge.lat2)) {
|
(lat <= edge.lat1 && lat >= edge.lat2) != (lat >= edge.lat1 && lat <= edge.lat2)) {
|
||||||
if (GeoUtils.orient(edge.lon1, edge.lat1, edge.lon2, edge.lat2, lon, lat) == 0) {
|
if ((lon == edge.lon1 && lon == edge.lon2) ||
|
||||||
|
((lon <= edge.lon1 && lon >= edge.lon2) != (lon >= edge.lon1 && lon <= edge.lon2) &&
|
||||||
|
GeoUtils.orient(edge.lon1, edge.lat1, edge.lon2, edge.lat2, lon, lat) == 0)) {
|
||||||
// if its on the boundary return true
|
// if its on the boundary return true
|
||||||
isOnEdge.set(true);
|
isOnEdge.set(true);
|
||||||
return true;
|
return true;
|
||||||
|
|
|
@ -698,7 +698,9 @@ public class GeoTestUtil {
|
||||||
for (i = 0, j = 1; j < nvert; ++i, ++j) {
|
for (i = 0, j = 1; j < nvert; ++i, ++j) {
|
||||||
if (testy == verty[j] && testy == verty[i] ||
|
if (testy == verty[j] && testy == verty[i] ||
|
||||||
((testy <= verty[j] && testy >= verty[i]) != (testy >= verty[j] && testy <= verty[i]))) {
|
((testy <= verty[j] && testy >= verty[i]) != (testy >= verty[j] && testy <= verty[i]))) {
|
||||||
if (GeoUtils.orient(vertx[i], verty[i], vertx[j], verty[j], testx, testy) == 0) {
|
if ((testx == vertx[j] && testx == vertx[i]) ||
|
||||||
|
((testx <= vertx[j] && testx >= vertx[i]) != (testx >= vertx[j] && testx <= vertx[i]) &&
|
||||||
|
GeoUtils.orient(vertx[i], verty[i], vertx[j], verty[j], testx, testy) == 0)) {
|
||||||
// return true if point is on boundary
|
// return true if point is on boundary
|
||||||
return true;
|
return true;
|
||||||
} else if ( ((verty[i] > testy) != (verty[j] > testy)) &&
|
} else if ( ((verty[i] > testy) != (verty[j] > testy)) &&
|
||||||
|
|
Loading…
Reference in New Issue