18#include <geos/export.h>
20#include <geos/geom/Coordinate.h>
21#include <geos/operation/valid/PolygonIntersectionAnalyzer.h>
22#include <geos/operation/valid/PolygonRing.h>
23#include <geos/noding/BasicSegmentString.h>
38class GEOS_DLL PolygonTopologyAnalyzer {
39 using CoordinateXY = geos::geom::CoordinateXY;
48 bool isInvertedRingValid =
false;
49 PolygonIntersectionAnalyzer segInt;
50 std::vector<PolygonRing*> polyRings;
51 geom::CoordinateXY disconnectionPt;
56 std::deque<PolygonRing> polyRingStore;
57 std::deque<noding::BasicSegmentString> segStringStore;
59 PolygonRing* createPolygonRing(
const LinearRing* p_ring);
60 PolygonRing* createPolygonRing(
const LinearRing* p_ring,
int p_index, PolygonRing* p_shell);
62 static const CoordinateXY&
63 findNonEqualVertex(
const LinearRing* ring,
const CoordinateXY& p);
82 static bool isIncidentSegmentInRing(
const CoordinateXY* p0,
const CoordinateXY* p1,
83 const CoordinateSequence* ringPts);
85 static const CoordinateXY& findRingVertexPrev(
const CoordinateSequence* ringPts,
86 std::size_t index,
const CoordinateXY& node);
88 static const CoordinateXY& findRingVertexNext(
const CoordinateSequence* ringPts,
89 std::size_t index,
const CoordinateXY& node);
91 static std::size_t ringIndexPrev(
const CoordinateSequence* ringPts, std::size_t index);
93 static std::size_t ringIndexNext(
const CoordinateSequence* ringPts, std::size_t index);
101 static std::size_t intersectingSegIndex(
const CoordinateSequence* ringPts,
const CoordinateXY* pt);
103 std::vector<SegmentString*> createSegmentStrings(
const Geometry* geom,
bool isInvertedRingValid);
105 std::vector<PolygonRing*> getPolygonRings(
const std::vector<SegmentString*>& segStrings);
107 SegmentString* createSegString(
const LinearRing* ring,
const PolygonRing* polyRing);
110 PolygonTopologyAnalyzer(
const PolygonTopologyAnalyzer& other) =
delete;
111 PolygonTopologyAnalyzer& operator=(
const PolygonTopologyAnalyzer& rhs) =
delete;
116 PolygonTopologyAnalyzer(
const Geometry* geom,
bool p_isInvertedRingValid);
124 static CoordinateXY findSelfIntersection(
const LinearRing* ring);
145 isRingNested(
const LinearRing* test,
146 const LinearRing* target);
148 bool hasInvalidIntersection() {
149 return segInt.isInvalid();
152 int getInvalidCode() {
153 return segInt.getInvalidCode();
156 const CoordinateXY& getInvalidLocation() {
157 return segInt.getInvalidLocation();
168 bool isInteriorDisconnected();
170 const CoordinateXY& getDisconnectionLocation()
const
172 return disconnectionPt;
188 void checkInteriorDisconnectedByHoleCycle();
199 void checkInteriorDisconnectedBySelfTouch();
The internal representation of a list of coordinates inside a Geometry.
Definition CoordinateSequence.h:56
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition Geometry.h:196
Models an OGC SFS LinearRing. A LinearRing is a LineString which is both closed and simple.
Definition LinearRing.h:54
An interface for classes which represent a sequence of contiguous line segments.
Definition SegmentString.h:47
Basic namespace for all GEOS functionalities.
Definition geos.h:38