19#ifndef GEOS_NODING_MCINDEXNODER_H
20#define GEOS_NODING_MCINDEXNODER_H
22#include <geos/export.h>
24#include <geos/inline.h>
26#include <geos/index/chain/MonotoneChainOverlapAction.h>
27#include <geos/noding/SinglePassNoder.h>
28#include <geos/index/strtree/STRtree.h>
36#pragma warning(disable: 4251)
63class GEOS_DLL MCIndexNoder :
public SinglePassNoder {
66 std::vector<index::chain::MonotoneChain*> monoChains;
69 std::vector<SegmentString*>* nodedSegStrings;
73 void intersectChains();
81 SinglePassNoder(nSegInt),
83 nodedSegStrings(NULL),
96 void computeNodes(std::vector<SegmentString*>* inputSegmentStrings);
102 index::
chain::MonotoneChainOverlapAction(),
112 SegmentOverlapAction(
const SegmentOverlapAction& other);
113 SegmentOverlapAction& operator=(
const SegmentOverlapAction& rhs);
126# include <geos/noding/MCIndexNoder.inl>
Definition LineSegment.h:57
Abstract class defines basic insertion and query operations supported by classes implementing spatial...
Definition SpatialIndex.h:47
Definition MonotoneChainOverlapAction.h:44
Monotone Chains are a way of partitioning the segments of a linestring to allow for fast searching of...
Definition index/chain/MonotoneChain.h:86
A query-only R-tree created using the Sort-Tile-Recursive (STR) algorithm. For two-dimensional spatia...
Definition STRtree.h:65
std::vector< SegmentString * > * getNodedSubstrings() const
void computeNodes(std::vector< SegmentString * > *inputSegmentStrings)
std::vector< index::chain::MonotoneChain * > & getMonotoneChains()
Return a reference to this instance's std::vector of MonotoneChains.
Definition MCIndexNoder.h:90
Processes possible intersections detected by a Noder.
Definition noding/SegmentIntersector.h:47
An interface for classes which represent a sequence of contiguous line segments.
Definition SegmentString.h:46
Contains the Geometry interface hierarchy and supporting classes.
Definition IndexedNestedRingTester.h:26
Contains classes that implement Monotone Chains.
Definition MCPointInRing.h:41
Classes to compute nodings for arrangements of line segments and line segment sequences.
Definition PreparedLineString.h:27
Basic namespace for all GEOS functionalities.
Definition IndexedNestedRingTester.h:25