GEOS
3.9.1dev
|
The internal representation of a list of coordinates inside a Geometry. More...
#include <geos.h>
Public Types | |
enum | { X, Y, Z, M } |
Standard ordinate index values. More... | |
typedef std::unique_ptr< CoordinateSequence > | Ptr |
Public Member Functions | |
virtual | ~CoordinateSequence () |
virtual std::unique_ptr< CoordinateSequence > | clone () const =0 |
Returns a deep copy of this collection. More... | |
virtual const Coordinate & | getAt (std::size_t i) const =0 |
Returns a read-only reference to Coordinate at position i. More... | |
const Coordinate & | back () const |
Return last Coordinate in the sequence. More... | |
const Coordinate & | front () const |
Return first Coordinate in the sequence. More... | |
const Coordinate & | operator[] (std::size_t i) const |
virtual Envelope | getEnvelope () const |
virtual void | getAt (std::size_t i, Coordinate &c) const =0 |
Write Coordinate at position i to given Coordinate. More... | |
virtual std::size_t | getSize () const =0 |
Returns the number of Coordinates (actual or otherwise, as this implementation may not store its data in Coordinate objects). More... | |
size_t | size () const |
virtual void | toVector (std::vector< Coordinate > &coords) const =0 |
virtual bool | isEmpty () const =0 |
Returns true it list contains no coordinates. More... | |
virtual void | setAt (const Coordinate &c, std::size_t pos)=0 |
Copy Coordinate c to position pos. More... | |
std::string | toString () const |
Get a string representation of CoordinateSequence. More... | |
virtual void | setPoints (const std::vector< Coordinate > &v)=0 |
Substitute Coordinate list with a copy of the given vector. More... | |
bool | hasRepeatedPoints () const |
Returns true if contains any two consecutive points. More... | |
const Coordinate * | minCoordinate () const |
Returns lower-left Coordinate in list. More... | |
virtual std::size_t | getDimension () const =0 |
bool | hasZ () const |
virtual double | getOrdinate (std::size_t index, std::size_t ordinateIndex) const |
virtual double | getX (std::size_t index) const |
virtual double | getY (std::size_t index) const |
virtual void | setOrdinate (std::size_t index, std::size_t ordinateIndex, double value)=0 |
virtual void | expandEnvelope (Envelope &env) const |
virtual void | apply_rw (const CoordinateFilter *filter)=0 |
virtual void | apply_ro (CoordinateFilter *filter) const =0 |
template<class T > | |
void | applyCoordinateFilter (T &f) |
Apply a filter to each Coordinate of this sequence. The filter is expected to provide a .filter(Coordinate&) method. More... | |
Static Public Member Functions | |
static bool | hasRepeatedPoints (const CoordinateSequence *cl) |
Returns true if given CoordinateSequence contains any two consecutive Coordinate. More... | |
static CoordinateSequence * | atLeastNCoordinatesOrNothing (std::size_t n, CoordinateSequence *c) |
Returns either the given CoordinateSequence if its length is greater than the given amount, or an empty CoordinateSequence. More... | |
static size_t | indexOf (const Coordinate *coordinate, const CoordinateSequence *cl) |
static bool | equals (const CoordinateSequence *cl1, const CoordinateSequence *cl2) |
Returns true if the two arrays are identical, both null, or pointwise equal. More... | |
static void | scroll (CoordinateSequence *cl, const Coordinate *firstCoordinate) |
Scroll given CoordinateSequence so to start with given Coordinate. More... | |
static int | increasingDirection (const CoordinateSequence &pts) |
Determines which orientation of the Coordinate array is (overall) increasing. More... | |
static bool | isRing (const CoordinateSequence *pts) |
Tests whether an array of Coordinates forms a ring, by checking length and closure. Self-intersection is not checked. More... | |
static void | reverse (CoordinateSequence *cl) |
Reverse Coordinate order in given CoordinateSequence. More... | |
Protected Member Functions | |
CoordinateSequence () | |
CoordinateSequence (const CoordinateSequence &) | |
The internal representation of a list of coordinates inside a Geometry.
There are some cases in which you might want Geometries to store their points using something other than the GEOS Coordinate class. For example, you may want to experiment with another implementation, such as an array of Xs and an array of Ys. or you might want to use your own coordinate class, one that supports extra attributes like M-values.
You can do this by implementing the CoordinateSequence and CoordinateSequenceFactory interfaces. You would then create a GeometryFactory parameterized by your CoordinateSequenceFactory, and use this GeometryFactory to create new Geometries. All of these new Geometries will use your CoordinateSequence implementation.
Definition at line 58 of file CoordinateSequence.h.
typedef std::unique_ptr<CoordinateSequence> geos::geom::CoordinateSequence::Ptr |
Definition at line 68 of file CoordinateSequence.h.
anonymous enum |
Standard ordinate index values.
Enumerator | |
---|---|
X | |
Y | |
Z | |
M |
Definition at line 215 of file CoordinateSequence.h.
|
inlineprotected |
Definition at line 62 of file CoordinateSequence.h.
|
inlineprotected |
Definition at line 64 of file CoordinateSequence.h.
|
inlinevirtual |
Definition at line 71 of file CoordinateSequence.h.
|
pure virtual |
|
pure virtual |
|
inline |
Apply a filter to each Coordinate of this sequence. The filter is expected to provide a .filter(Coordinate&) method.
TODO: accept a Functor instead, will be more flexible. actually, define iterators on Geometry
Definition at line 298 of file CoordinateSequence.h.
References GEOS_DLL, geos::geom::operator!=(), geos::geom::operator<<(), and geos::geom::operator==().
|
static |
Returns either the given CoordinateSequence if its length is greater than the given amount, or an empty CoordinateSequence.
|
inline |
Return last Coordinate in the sequence.
Definition at line 88 of file CoordinateSequence.h.
Referenced by geos::operation::buffer::OffsetSegmentString::closeRing(), and geos::operation::buffer::OffsetSegmentString::isRedundant().
|
pure virtual |
Returns a deep copy of this collection.
Implemented in geos::geom::CoordinateArraySequence, geos::geom::FixedSizeCoordinateSequence< N >, and geos::geom::FixedSizeCoordinateSequence< 1 >.
|
static |
Returns true if the two arrays are identical, both null, or pointwise equal.
|
virtual |
Expands the given Envelope to include the coordinates in the sequence. Allows implementing classes to optimize access to coordinate values.
env | the envelope to expand |
Reimplemented in geos::geom::CoordinateArraySequence.
|
inline |
Return first Coordinate in the sequence.
Definition at line 95 of file CoordinateSequence.h.
Referenced by geos::operation::buffer::OffsetSegmentString::closeRing().
|
pure virtual |
Returns a read-only reference to Coordinate at position i.
Whether or not the Coordinate returned is the actual underlying Coordinate or merely a copy depends on the implementation.
Implemented in geos::geom::CoordinateArraySequence.
|
pure virtual |
Write Coordinate at position i to given Coordinate.
Implemented in geos::geom::CoordinateArraySequence.
|
pure virtual |
Returns the dimension (number of ordinates in each coordinate) for this sequence.
Implemented in geos::geom::CoordinateArraySequence, geos::geom::FixedSizeCoordinateSequence< N >, and geos::geom::FixedSizeCoordinateSequence< 1 >.
|
virtual |
|
virtual |
Returns the ordinate of a coordinate in this sequence. Ordinate indices 0 and 1 are assumed to be X and Y. Ordinates indices greater than 1 have user-defined semantics (for instance, they may contain other dimensions or measure values).
index | the coordinate index in the sequence |
ordinateIndex | the ordinate index in the coordinate (in range [0, dimension-1]) |
|
pure virtual |
Returns the number of Coordinates (actual or otherwise, as this implementation may not store its data in Coordinate objects).
Implemented in geos::geom::CoordinateArraySequence, geos::geom::FixedSizeCoordinateSequence< N >, and geos::geom::FixedSizeCoordinateSequence< 1 >.
|
inlinevirtual |
Returns ordinate X (0) of the specified coordinate.
index |
Definition at line 248 of file CoordinateSequence.h.
|
inlinevirtual |
Returns ordinate Y (1) of the specified coordinate.
index |
Definition at line 260 of file CoordinateSequence.h.
bool geos::geom::CoordinateSequence::hasRepeatedPoints | ( | ) | const |
Returns true if contains any two consecutive points.
|
static |
Returns true if given CoordinateSequence contains any two consecutive Coordinate.
|
inline |
Definition at line 225 of file CoordinateSequence.h.
|
static |
Determines which orientation of the Coordinate array is (overall) increasing.
In other words, determines which end of the array is "smaller" (using the standard ordering on Coordinate). Returns an integer indicating the increasing direction. If the sequence is a palindrome, it is defined to be oriented in a positive direction.
pts | the array of Coordinates to test |
1
if the array is smaller at the start or is a palindrome, -1
if smaller at the endNOTE: this method is found in CoordinateArrays class for JTS
|
static |
Return position of a Coordinate, or -1 if not found
FIXME: return std::size_t, using numeric_limits<std::size_t>::max as 'not found' value.
|
pure virtual |
Returns true
it list contains no coordinates.
Implemented in geos::geom::CoordinateArraySequence, geos::geom::FixedSizeCoordinateSequence< N >, and geos::geom::FixedSizeCoordinateSequence< 1 >.
|
static |
Tests whether an array of Coordinates forms a ring, by checking length and closure. Self-intersection is not checked.
pts | an array of Coordinates |
const Coordinate* geos::geom::CoordinateSequence::minCoordinate | ( | ) | const |
Returns lower-left Coordinate in list.
|
inline |
Definition at line 101 of file CoordinateSequence.h.
|
static |
Reverse Coordinate order in given CoordinateSequence.
|
static |
Scroll given CoordinateSequence so to start with given Coordinate.
|
pure virtual |
Copy Coordinate c to position pos.
Implemented in geos::geom::CoordinateArraySequence.
|
pure virtual |
Sets the value for a given ordinate of a coordinate in this sequence.
index | the coordinate index in the sequence |
ordinateIndex | the ordinate index in the coordinate (in range [0, dimension-1]) |
value | the new ordinate value |
Implemented in geos::geom::CoordinateArraySequence.
|
pure virtual |
Substitute Coordinate list with a copy of the given vector.
Implemented in geos::geom::CoordinateArraySequence, geos::geom::FixedSizeCoordinateSequence< N >, and geos::geom::FixedSizeCoordinateSequence< 1 >.
|
inline |
Definition at line 120 of file CoordinateSequence.h.
Referenced by geos::operation::buffer::OffsetSegmentString::addPts(), geos::operation::buffer::OffsetSegmentString::closeRing(), geos::operation::buffer::OffsetSegmentString::isRedundant(), and geos::operation::buffer::OffsetSegmentString::size().
std::string geos::geom::CoordinateSequence::toString | ( | ) | const |
Get a string representation of CoordinateSequence.
|
pure virtual |
Pushes all Coordinates of this sequence into the provided vector.
This method is a port of the toCoordinateArray() method of JTS.
Implemented in geos::geom::FixedSizeCoordinateSequence< N >, geos::geom::FixedSizeCoordinateSequence< 1 >, and geos::geom::CoordinateArraySequence.