24#include <geos/geom/Coordinate.h>
25#include <geos/geom/Geometry.h>
26#include <geos/geom/LineSegment.h>
27#include <geos/linearref/LinearLocation.h>
133 static std::size_t segmentEndVertexIndex(
const LinearLocation& loc);
136 std::size_t vertexIndex;
137 std::size_t componentIndex;
139 const std::size_t numLines;
147 void loadCurrentLine();
Coordinate is the lightweight class used to store coordinates.
Definition: Coordinate.h:58
Basic implementation of Geometry, constructed and destructed by GeometryFactory.
Definition: Geometry.h:186
Definition: LineString.h:66
An iterator over the components and coordinates of a linear geometry (LineString or MultiLineString).
Definition: LinearIterator.h:49
bool hasNext() const
Tests whether there are any vertices left to iterator over.
geom::Coordinate getSegmentEnd() const
Gets the second geom::Coordinate of the current segment. (the coordinate of the next vertex)....
std::size_t getVertexIndex() const
The vertex index of the vertex the iterator is currently at.
LinearIterator(const geom::Geometry *linear)
Creates an iterator initialized to the start of a linear Geometry.
geom::Coordinate getSegmentStart() const
Gets the first geom::Coordinate of the current segment. (the coordinate of the current vertex).
std::size_t getComponentIndex() const
The component index of the vertex the iterator is currently at.
bool isEndOfLine() const
Checks whether the iterator cursor is pointing to the endpoint of a component geom::LineString.
LinearIterator(const geom::Geometry *linear, const LinearLocation &start)
Creates an iterator starting at a LinearLocation on a linear geom::Geometry.
LinearIterator(const geom::Geometry *linear, std::size_t componentIndex, std::size_t vertexIndex)
Creates an iterator starting at a component and vertex in a linear geom::Geometry.
const geom::LineString * getLine() const
Gets the geom::LineString component the iterator is current at.
void next()
Moves the iterator ahead to the next vertex and (possibly) linear component.
Represents a location along a LineString or MultiLineString.
Definition: LinearLocation.h:43
Basic namespace for all GEOS functionalities.
Definition: geos.h:39