24 #ifndef GEOS_SIMPLIFY_TAGGEDLINESTRINGSIMPLIFIER_H
25 #define GEOS_SIMPLIFY_TAGGEDLINESTRINGSIMPLIFIER_H
27 #include <geos/export.h>
34 #pragma warning(disable: 4251) // warning C4251: needs to have dll-interface to be used by clients of class
40 class LineIntersector;
43 class CoordinateSequence;
47 class TaggedLineSegment;
48 class TaggedLineString;
49 class LineSegmentIndex;
68 LineSegmentIndex* outputIndex);
78 void setDistanceTolerance(
double d);
92 LineSegmentIndex* inputIndex;
95 LineSegmentIndex* outputIndex;
97 std::unique_ptr<algorithm::LineIntersector> li;
104 double distanceTolerance;
106 void simplifySection(std::size_t i, std::size_t j,
109 static std::size_t findFurthestPoint(
111 std::size_t i, std::size_t j,
112 double& maxDistance);
115 const std::vector<std::size_t>& sectionIndex,
119 const std::vector<std::size_t>& sectionIndex,
127 std::unique_ptr<TaggedLineSegment> flatten(
128 std::size_t start, std::size_t end);
138 static bool isInLineSection(
140 const std::vector<std::size_t>& sectionIndex,
160 distanceTolerance = d;
170 #endif // GEOS_SIMPLIFY_TAGGEDLINESTRINGSIMPLIFIER_H