GEOS 3.11.1
SegmentStringUtil.h
1/**********************************************************************
2 *
3 * GEOS - Geometry Engine Open Source
4 * http://geos.osgeo.org
5 *
6 * Copyright (C) 2006 Refractions Research Inc.
7 *
8 * This is free software; you can redistribute and/or modify it under
9 * the terms of the GNU Lesser General Public Licence as published
10 * by the Free Software Foundation.
11 * See the COPYING file for more information.
12 *
13 *
14 **********************************************************************
15 *
16 * Last port: noding/SegmentStringUtil.java rev. 1.2 (JTS-1.9)
17 *
18 **********************************************************************/
19
20#pragma once
21
22#include <geos/noding/NodedSegmentString.h>
23#include <geos/geom/LineString.h>
24#include <geos/geom/CoordinateSequence.h>
25#include <geos/geom/util/LinearComponentExtracter.h>
26
27namespace geos {
28namespace noding { // geos::noding
29
37public:
49 static void
51 SegmentString::ConstVect& segStr)
52 {
55
56 for(std::size_t i = 0, n = lines.size(); i < n; i++) {
57 geom::LineString* line = (geom::LineString*)(lines[i]);
58
59 // we take ownership of the coordinates here
60 // TODO: check if this can be optimized by getting
61 // the internal CS.
62 auto pts = line->getCoordinates();
63
64 segStr.push_back(new NodedSegmentString(pts.release(), g));
65 }
66 }
67
68};
69
70} // geos::noding
71} // geos
72
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition: Geometry.h:186
Definition: LineString.h:66
std::unique_ptr< CoordinateSequence > getCoordinates() const override
Returns this Geometry vertices. Caller takes ownership of the returned object.
std::vector< const LineString * > ConstVect
A vector of const LineString pointers.
Definition: LineString.h:73
static void getLines(const Geometry &geom, std::vector< const LineString * > &ret)
Represents a list of contiguous line segments, and supports noding the segments.
Definition: NodedSegmentString.h:59
Utility methods for processing SegmentStrings.
Definition: SegmentStringUtil.h:36
static void extractSegmentStrings(const geom::Geometry *g, SegmentString::ConstVect &segStr)
Extracts all linear components from a given Geometry to SegmentStrings.
Definition: SegmentStringUtil.h:50
Basic namespace for all GEOS functionalities.
Definition: geos.h:39