17#include <geos/noding/BasicSegmentString.h>
45class GEOS_DLL CoverageRing :
public noding::BasicSegmentString {
50 bool m_isInteriorOnRight;
51 std::vector<bool> m_isInvalid;
52 std::vector<bool> m_isMatched;
54 std::size_t findInvalidStart(std::size_t index);
56 std::size_t findInvalidEnd(std::size_t index);
58 std::size_t nextMarkIndex(std::size_t index);
69 std::unique_ptr<LineString> createLine(
70 std::size_t startIndex,
74 std::unique_ptr<CoordinateSequence> extractSection(
75 std::size_t startIndex, std::size_t endIndex);
77 std::unique_ptr<CoordinateSequence> extractSectionWrap(
78 std::size_t startIndex, std::size_t endIndex);
84 CoverageRing(
const LinearRing* ring,
bool isShell);
86 geom::Envelope getEnvelope(std::size_t start, std::size_t end);
95 static bool isKnown(std::vector<CoverageRing*>& rings);
103 bool isInteriorOnRight()
const;
110 void markInvalid(std::size_t index);
117 void markMatched(std::size_t index);
125 bool isKnown()
const;
133 bool isInvalid(std::size_t i)
const;
140 bool isInvalid()
const;
147 bool hasInvalid()
const;
155 bool isKnown(std::size_t i)
const;
183 std::size_t prev(std::size_t index)
const;
191 std::size_t next(std::size_t index)
const;
193 void createInvalidLines(
195 std::vector<std::unique_ptr<LineString>>& lines);
The internal representation of a list of coordinates inside a Geometry.
Definition CoordinateSequence.h:56
Coordinate is the lightweight class used to store coordinates.
Definition Coordinate.h:217
Supplies a set of utility methods for building Geometry objects from CoordinateSequence or other Geom...
Definition GeometryFactory.h:70
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition Geometry.h:197
Definition LineString.h:66
Models an OGC SFS LinearRing. A LinearRing is a LineString which is both closed and simple.
Definition LinearRing.h:54
Represents a linear polygon, which may include holes.
Definition Polygon.h:61
Basic namespace for all GEOS functionalities.
Definition geos.h:39