mirror of https://github.com/apache/lucene.git
LUCENE-7244: Complain if the holes are outside the polygon.
This commit is contained in:
parent
874f6a146b
commit
38c0915572
|
@ -207,21 +207,6 @@ class GeoConcavePolygon extends GeoBasePolygon {
|
||||||
invertedEdges[i] = new SidedPlane(edges[i]);
|
invertedEdges[i] = new SidedPlane(edges[i]);
|
||||||
notableEdgePoints[i] = new GeoPoint[]{start, end};
|
notableEdgePoints[i] = new GeoPoint[]{start, end};
|
||||||
}
|
}
|
||||||
/* Disable since GeoPolygonFactory does this too.
|
|
||||||
// In order to naively confirm that the polygon is concave, I would need to
|
|
||||||
// check every edge, and verify that every point (other than the edge endpoints)
|
|
||||||
// is within the edge's sided plane. This is an order n^2 operation. That's still
|
|
||||||
// not wrong, though, because everything else about polygons has a similar cost.
|
|
||||||
for (int edgeIndex = 0; edgeIndex < edges.length; edgeIndex++) {
|
|
||||||
final SidedPlane edge = edges[edgeIndex];
|
|
||||||
for (int pointIndex = 0; pointIndex < points.size(); pointIndex++) {
|
|
||||||
if (pointIndex != edgeIndex && pointIndex != legalIndex(edgeIndex + 1)) {
|
|
||||||
if (edge.isWithin(points.get(pointIndex)))
|
|
||||||
throw new IllegalArgumentException("Polygon is not concave: Point " + points.get(pointIndex) + " Edge " + edge);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// For each edge, create a bounds object.
|
// For each edge, create a bounds object.
|
||||||
eitherBounds = new HashMap<>(edges.length);
|
eitherBounds = new HashMap<>(edges.length);
|
||||||
|
@ -241,6 +226,26 @@ class GeoConcavePolygon extends GeoBasePolygon {
|
||||||
|
|
||||||
// Pick an edge point arbitrarily
|
// Pick an edge point arbitrarily
|
||||||
edgePoints = new GeoPoint[]{points.get(0)};
|
edgePoints = new GeoPoint[]{points.get(0)};
|
||||||
|
|
||||||
|
if (isWithinHoles(points.get(0))) {
|
||||||
|
throw new IllegalArgumentException("Polygon edge intersects a polygon hole; not allowed");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Check if a point is within the provided holes.
|
||||||
|
*@param point point to check.
|
||||||
|
*@return true if the point is within any of the holes.
|
||||||
|
*/
|
||||||
|
protected boolean isWithinHoles(final GeoPoint point) {
|
||||||
|
if (holes != null) {
|
||||||
|
for (final GeoPolygon hole : holes) {
|
||||||
|
if (hole.isWithin(point)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Compute a legal point index from a possibly illegal one, that may have wrapped.
|
/** Compute a legal point index from a possibly illegal one, that may have wrapped.
|
||||||
|
|
|
@ -203,21 +203,6 @@ class GeoConvexPolygon extends GeoBasePolygon {
|
||||||
edges[i] = sp;
|
edges[i] = sp;
|
||||||
notableEdgePoints[i] = new GeoPoint[]{start, end};
|
notableEdgePoints[i] = new GeoPoint[]{start, end};
|
||||||
}
|
}
|
||||||
/* Disabled since GeoPolygonFactory does the checking too.
|
|
||||||
// In order to naively confirm that the polygon is convex, I would need to
|
|
||||||
// check every edge, and verify that every point (other than the edge endpoints)
|
|
||||||
// is within the edge's sided plane. This is an order n^2 operation. That's still
|
|
||||||
// not wrong, though, because everything else about polygons has a similar cost.
|
|
||||||
for (int edgeIndex = 0; edgeIndex < edges.length; edgeIndex++) {
|
|
||||||
final SidedPlane edge = edges[edgeIndex];
|
|
||||||
for (int pointIndex = 0; pointIndex < points.size(); pointIndex++) {
|
|
||||||
if (pointIndex != edgeIndex && pointIndex != legalIndex(edgeIndex + 1)) {
|
|
||||||
if (!edge.isWithin(points.get(pointIndex)))
|
|
||||||
throw new IllegalArgumentException("Polygon is not convex: Point " + points.get(pointIndex) + " Edge " + edge);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
*/
|
|
||||||
|
|
||||||
// For each edge, create a bounds object.
|
// For each edge, create a bounds object.
|
||||||
eitherBounds = new HashMap<>(edges.length);
|
eitherBounds = new HashMap<>(edges.length);
|
||||||
|
@ -236,6 +221,26 @@ class GeoConvexPolygon extends GeoBasePolygon {
|
||||||
|
|
||||||
// Pick an edge point arbitrarily
|
// Pick an edge point arbitrarily
|
||||||
edgePoints = new GeoPoint[]{points.get(0)};
|
edgePoints = new GeoPoint[]{points.get(0)};
|
||||||
|
|
||||||
|
if (isWithinHoles(points.get(0))) {
|
||||||
|
throw new IllegalArgumentException("Polygon edge intersects a polygon hole; not allowed");
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
/** Check if a point is within the provided holes.
|
||||||
|
*@param point point to check.
|
||||||
|
*@return true if the point is within any of the holes.
|
||||||
|
*/
|
||||||
|
protected boolean isWithinHoles(final GeoPoint point) {
|
||||||
|
if (holes != null) {
|
||||||
|
for (final GeoPolygon hole : holes) {
|
||||||
|
if (hole.isWithin(point)) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
/** Compute a legal point index from a possibly illegal one, that may have wrapped.
|
/** Compute a legal point index from a possibly illegal one, that may have wrapped.
|
||||||
|
|
Loading…
Reference in New Issue