GEOS 3.6.2
CoordinateArraySequence.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#ifndef GEOS_GEOM_COORDINATEARRAYSEQUENCE_H
16#define GEOS_GEOM_COORDINATEARRAYSEQUENCE_H
17
18#include <geos/export.h>
19#include <vector>
20
21#include <geos/geom/CoordinateSequence.h>
22
23#include <geos/inline.h>
24
25// Forward declarations
26namespace geos {
27 namespace geom {
28 class Coordinate;
29 }
30}
31
32
33namespace geos {
34namespace geom { // geos.geom
35
37class GEOS_DLL CoordinateArraySequence : public CoordinateSequence {
38public:
39
40 CoordinateArraySequence(const CoordinateArraySequence &cl);
41
42 CoordinateArraySequence(const CoordinateSequence &cl);
43
44 CoordinateSequence *clone() const;
45
46 //const Coordinate& getCoordinate(int pos) const;
47 const Coordinate& getAt(std::size_t pos) const;
48
50 virtual void getAt(std::size_t i, Coordinate& c) const;
51
52 //int size() const;
53 size_t getSize() const;
54
55 // @deprecated
56 const std::vector<Coordinate>* toVector() const;
57
58 // See dox in CoordinateSequence.h
59 void toVector(std::vector<Coordinate>&) const;
60
63
65 CoordinateArraySequence(std::vector<Coordinate> *coords,
66 std::size_t dimension = 0);
67
69 CoordinateArraySequence(std::size_t n, std::size_t dimension = 0);
70
71 ~CoordinateArraySequence();
72
73 bool isEmpty() const { return empty(); }
74
75 bool empty() const { return vect->empty(); }
76
78 void clear() { vect->clear(); }
79
80 void add(const Coordinate& c);
81
82 virtual void add(const Coordinate& c, bool allowRepeated);
83
95 virtual void add(std::size_t i, const Coordinate& coord, bool allowRepeated);
96
97 void setAt(const Coordinate& c, std::size_t pos);
98
99 void deleteAt(std::size_t pos);
100
101 std::string toString() const;
102
103 void setPoints(const std::vector<Coordinate> &v);
104
105 double getOrdinate(std::size_t index,
106 size_t ordinateIndex) const;
107
108 void setOrdinate(std::size_t index, std::size_t ordinateIndex,
109 double value);
110
111 void expandEnvelope(Envelope &env) const;
112
113 std::size_t getDimension() const;
114
115 void apply_rw(const CoordinateFilter *filter);
116
117 void apply_ro(CoordinateFilter *filter) const;
118
119 virtual CoordinateSequence& removeRepeatedPoints();
120
121private:
122 std::vector<Coordinate> *vect;
123 mutable std::size_t dimension;
124};
125
128
129} // namespace geos.geom
130} // namespace geos
131
132#endif // ndef GEOS_GEOM_COORDINATEARRAYSEQUENCE_H
The default implementation of CoordinateSequence.
Definition CoordinateArraySequence.h:37
void toVector(std::vector< Coordinate > &) const
Pushes all Coordinates of this sequence onto the provided vector.
void setPoints(const std::vector< Coordinate > &v)
Substitute Coordinate list with a copy of the given vector.
virtual void getAt(std::size_t i, Coordinate &c) const
Copy Coordinate at position i to Coordinate c.
virtual void add(const Coordinate &c, bool allowRepeated)
Add a coordinate.
void setOrdinate(std::size_t index, std::size_t ordinateIndex, double value)
void clear()
Reset this CoordinateArraySequence to the empty state.
Definition CoordinateArraySequence.h:78
CoordinateArraySequence(std::vector< Coordinate > *coords, std::size_t dimension=0)
Construct sequence taking ownership of given Coordinate vector.
const std::vector< Coordinate > * toVector() const
Returns a read-only vector with the Coordinates in this collection.
CoordinateArraySequence(std::size_t n, std::size_t dimension=0)
Construct sequence allocating space for n coordinates.
void deleteAt(std::size_t pos)
Delete Coordinate at position pos (list will shrink).
CoordinateArraySequence()
Construct an empty sequence.
size_t getSize() const
Returns the number of Coordinates (actual or otherwise, as this implementation may not store its data...
void setAt(const Coordinate &c, std::size_t pos)
Get a reference to Coordinate at position pos.
virtual void add(std::size_t i, const Coordinate &coord, bool allowRepeated)
Inserts the specified coordinate at the specified position in this list.
bool isEmpty() const
Returns true it list contains no coordinates.
Definition CoordinateArraySequence.h:73
void add(const Coordinate &c)
Add a Coordinate to the list.
virtual CoordinateSequence & removeRepeatedPoints()
Remove consecutive equal Coordinates from the sequence.
void expandEnvelope(Envelope &env) const
std::string toString() const
Get a string rapresentation of CoordinateSequence.
CoordinateSequence * clone() const
Returns a deep copy of this collection.
const Coordinate & getAt(std::size_t pos) const
Returns a read-only reference to Coordinate at position i.
Definition CoordinateFilter.h:43
Coordinate is the lightweight class used to store coordinates.
Definition Coordinate.h:60
An Envelope defines a rectangulare region of the 2D coordinate plane.
Definition Envelope.h:53
Contains the Geometry interface hierarchy and supporting classes.
Definition IndexedNestedRingTester.h:26
CoordinateArraySequence DefaultCoordinateSequence
This is for backward API compatibility.
Definition CoordinateArraySequence.h:127
Provides classes for various kinds of spatial indexes.
Definition IndexedNestedRingTester.h:31
Basic namespace for all GEOS functionalities.
Definition IndexedNestedRingTester.h:25