GEOS
3.8.0dev

Sews together a set of fully noded LineStrings. More...
#include <LineMerger.h>
Public Member Functions  
void  add (std::vector< geom::Geometry * > *geometries) 
Adds a collection of Geometries to be processed. May be called multiple times. More...  
void  add (const geom::Geometry *geometry) 
Adds a Geometry to be processed. May be called multiple times. More...  
std::vector< geom::LineString * > *  getMergedLineStrings () 
Returns the LineStrings built by the merging process. More...  
void  add (const geom::LineString *lineString) 
Sews together a set of fully noded LineStrings.
Sewing stops at nodes of degree 1 or 3 or more. The exception is an isolated loop, which only has degree2 nodes, in which case a node is simply chosen as a starting point. The direction of each merged LineString will be that of the majority of the LineStrings from which it was derived.
Any dimension of Geometry is handled. The constituent linework is extracted to form the edges. The edges must be correctly noded; that is, they must only meet at their endpoints.
The LineMerger will still run on incorrectly noded input but will not form polygons from incorrected noded edges.
void geos::operation::linemerge::LineMerger::add  (  std::vector< geom::Geometry * > *  geometries  ) 
Adds a collection of Geometries to be processed. May be called multiple times.
Any dimension of Geometry may be added; the constituent linework will be extracted.
void geos::operation::linemerge::LineMerger::add  (  const geom::Geometry *  geometry  ) 
Adds a Geometry to be processed. May be called multiple times.
Any dimension of Geometry may be added; the constituent linework will be extracted.
std::vector<geom::LineString*>* geos::operation::linemerge::LineMerger::getMergedLineStrings  (  ) 
Returns the LineStrings built by the merging process.
Ownership of vector and its elements to caller.