QGIS API Documentation 4.1.0-Master (60fea48833c)
Loading...
Searching...
No Matches
qgsabstractgeometry.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsabstractgeometry.h
3 -------------------------------------------------------------------
4Date : 04 Sept 2014
5Copyright : (C) 2014 by Marco Hugentobler
6email : marco.hugentobler at sourcepole dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#ifndef QGSABSTRACTGEOMETRYV2
17#define QGSABSTRACTGEOMETRYV2
18
19#include <array>
20#include <functional>
21#include <type_traits>
22
23#include "qgis.h"
24#include "qgis_core.h"
25#include "qgswkbptr.h"
26#include "qgswkbtypes.h"
27
28#include <QString>
29
30#ifndef SIP_RUN
31#include <nlohmann/json_fwd.hpp>
32using namespace nlohmann;
33#endif
34
35class QgsMapToPixel;
36class QgsCurve;
37class QgsMultiCurve;
38class QgsMultiPoint;
39
40struct QgsVertexId;
42class QPainter;
43class QDomDocument;
44class QDomElement;
47class QgsConstWkbPtr;
48class QPainterPath;
50class QgsFeedback;
52class QgsPoint;
53class QgsRectangle;
54class QgsBox3D;
55
56typedef QVector< QgsPoint > QgsPointSequence;
57#ifndef SIP_RUN
58typedef QVector< QgsPointSequence > QgsRingSequence;
59typedef QVector< QgsRingSequence > QgsCoordinateSequence;
60#else
61typedef QVector< QVector< QgsPoint > > QgsRingSequence;
62typedef QVector< QVector< QVector< QgsPoint > > > QgsCoordinateSequence;
63#endif
64
65
80class CORE_EXPORT QgsAbstractGeometry
81{
82 // clang-format off
83
84#ifdef SIP_RUN
86 if ( qgsgeometry_cast<QgsPoint *>( sipCpp ) != nullptr )
87 sipType = sipType_QgsPoint;
88 else if ( qgsgeometry_cast<QgsLineString *>( sipCpp ) != nullptr )
89 sipType = sipType_QgsLineString;
90 else if ( qgsgeometry_cast<QgsCircularString *>( sipCpp ) != nullptr )
91 sipType = sipType_QgsCircularString;
92 else if ( qgsgeometry_cast<QgsCompoundCurve *>( sipCpp ) != nullptr )
93 sipType = sipType_QgsCompoundCurve;
94 else if ( qgsgeometry_cast<QgsNurbsCurve *>( sipCpp ) != nullptr )
95 sipType = sipType_QgsNurbsCurve;
96 else if ( qgsgeometry_cast<QgsTriangle *>( sipCpp ) != nullptr )
97 sipType = sipType_QgsTriangle;
98 else if ( qgsgeometry_cast<QgsPolygon *>( sipCpp ) != nullptr )
99 sipType = sipType_QgsPolygon;
100 else if ( qgsgeometry_cast<QgsCurvePolygon *>( sipCpp ) != nullptr )
101 sipType = sipType_QgsCurvePolygon;
102 else if ( qgsgeometry_cast<QgsTriangulatedSurface *>( sipCpp ) != nullptr )
103 sipType = sipType_QgsTriangulatedSurface;
104 else if ( qgsgeometry_cast<QgsPolyhedralSurface *>( sipCpp ) != nullptr )
105 sipType = sipType_QgsPolyhedralSurface;
106 else if ( qgsgeometry_cast<QgsSurface *>( sipCpp ) != nullptr )
107 sipType = sipType_QgsSurface;
108 else if ( qgsgeometry_cast<QgsMultiPoint *>( sipCpp ) != nullptr )
109 sipType = sipType_QgsMultiPoint;
110 else if ( qgsgeometry_cast<QgsMultiLineString *>( sipCpp ) != nullptr )
111 sipType = sipType_QgsMultiLineString;
112 else if ( qgsgeometry_cast<QgsMultiPolygon *>( sipCpp ) != nullptr )
113 sipType = sipType_QgsMultiPolygon;
114 else if ( qgsgeometry_cast<QgsMultiSurface *>( sipCpp ) != nullptr )
115 sipType = sipType_QgsMultiSurface;
116 else if ( qgsgeometry_cast<QgsMultiCurve *>( sipCpp ) != nullptr )
117 sipType = sipType_QgsMultiCurve;
118 else if ( qgsgeometry_cast<QgsGeometryCollection *>( sipCpp ) != nullptr )
119 sipType = sipType_QgsGeometryCollection;
120 else
121 sipType = 0;
122 SIP_END
123#endif
124
125 Q_GADGET
126
127 public:
128
145 Q_ENUM( SegmentationToleranceType )
146
147
149 {
150
154 XY = 0,
155
160 };
162
163 // clang-format on
164
166 virtual ~QgsAbstractGeometry() = default;
168 QgsAbstractGeometry &operator=( const QgsAbstractGeometry &geom );
169
170 virtual bool operator==( const QgsAbstractGeometry &other ) const = 0;
171 virtual bool operator!=( const QgsAbstractGeometry &other ) const = 0;
172
183 virtual bool fuzzyEqual( const QgsAbstractGeometry &other, double epsilon = 1e-8 ) const = 0;
184
198 virtual bool fuzzyDistanceEqual( const QgsAbstractGeometry &other, double epsilon = 1e-8 ) const = 0;
199
204
210 virtual int compareTo( const QgsAbstractGeometry *other ) const;
211
215 virtual void clear() = 0;
216
220 virtual QgsRectangle boundingBox() const;
221
227 virtual QgsBox3D boundingBox3D() const = 0;
228
229 //mm-sql interface
230
235 virtual int dimension() const = 0;
236
242 virtual QString geometryType() const = 0;
243
244 // clang-format off
250 inline Qgis::WkbType wkbType() const SIP_HOLDGIL { return mWkbType; }
251 // clang-format on
252
258 QString wktTypeStr() const;
259
264 bool is3D() const SIP_HOLDGIL
265 {
266 return QgsWkbTypes::hasZ( mWkbType );
267 }
268
274 {
275 return QgsWkbTypes::hasM( mWkbType );
276 }
277
284
294 virtual void normalize() = 0;
295
296 //import
297
303 virtual bool fromWkb( QgsConstWkbPtr &wkb ) = 0;
304
309 virtual bool fromWkt( const QString &wkt ) = 0;
310
311 //export
312
322 Q_DECLARE_FLAGS( WkbFlags, WkbFlag )
323
324
332
343 virtual QByteArray asWkb( WkbFlags flags = QgsAbstractGeometry::WkbFlags() ) const = 0;
344
353 virtual QString asWkt( int precision = 17 ) const = 0;
354
366 virtual QDomElement asGml2( QDomDocument &doc, int precision = 17, const QString &ns = "gml", AxisOrder axisOrder = QgsAbstractGeometry::AxisOrder::XY ) const = 0;
367
379 virtual QDomElement asGml3( QDomDocument &doc, int precision = 17, const QString &ns = "gml", AxisOrder axisOrder = QgsAbstractGeometry::AxisOrder::XY ) const = 0;
380
390 QString asJson( int precision = 17 );
391
402 virtual json asJsonObject( int precision = 17 ) SIP_SKIP const;
403
408 virtual QString asKml( int precision = 17 ) const = 0;
409
410
411 //render pipeline
412
423 virtual void transform( const QgsCoordinateTransform &ct, Qgis::TransformDirection d = Qgis::TransformDirection::Forward, bool transformZ = false ) SIP_THROW( QgsCsException ) = 0;
424
431 virtual void transform( const QTransform &t, double zTranslate = 0.0, double zScale = 1.0,
432 double mTranslate = 0.0, double mScale = 1.0 ) = 0;
433
438 virtual void draw( QPainter &p ) const = 0;
439
448 virtual QPainterPath asQPainterPath() const = 0;
449
459 virtual int vertexNumberFromVertexId( QgsVertexId id ) const = 0;
460
468 virtual bool nextVertex( QgsVertexId &id, QgsPoint &vertex SIP_OUT ) const = 0;
469
473 virtual void adjacentVertices( QgsVertexId vertex, QgsVertexId &previousVertex SIP_OUT, QgsVertexId &nextVertex SIP_OUT ) const = 0;
474
480
484 virtual int nCoordinates() const;
485
489 virtual QgsPoint vertexAt( QgsVertexId id ) const = 0;
490
503 virtual double closestSegment( const QgsPoint &pt, QgsPoint &segmentPt SIP_OUT,
504 QgsVertexId &vertexAfter SIP_OUT,
505 int *leftOf SIP_OUT = nullptr, double epsilon = 4 * std::numeric_limits<double>::epsilon() ) const = 0;
506
507 //low-level editing
508
517 virtual bool insertVertex( QgsVertexId position, const QgsPoint &vertex ) = 0;
518
527 virtual bool moveVertex( QgsVertexId position, const QgsPoint &newPos ) = 0;
528
536 virtual bool deleteVertex( QgsVertexId position ) = 0;
537
550 virtual double length() const;
551
564 virtual double perimeter() const;
565
579 virtual double area() const;
580
591 virtual double area3D() const;
592
600 virtual double segmentLength( QgsVertexId startVertex ) const = 0;
601
603 virtual QgsPoint centroid() const;
604
608 virtual bool isEmpty() const;
609
613 virtual bool hasCurvedSegments() const;
614
623 virtual bool boundingBoxIntersects( const QgsRectangle &rectangle ) const SIP_HOLDGIL;
624
633 virtual bool boundingBoxIntersects( const QgsBox3D &box3d ) const SIP_HOLDGIL;
634
641 virtual QgsAbstractGeometry *segmentize( double tolerance = M_PI / 180., SegmentationToleranceType toleranceType = MaximumAngle ) const SIP_FACTORY;
642
650
673 virtual QgsAbstractGeometry *snappedToGrid( double hSpacing, double vSpacing, double dSpacing = 0, double mSpacing = 0, bool removeRedundantPoints = false ) const = 0 SIP_FACTORY;
674
687 virtual QgsAbstractGeometry *simplifyByDistance( double tolerance ) const = 0 SIP_FACTORY;
688
708 virtual bool removeDuplicateNodes( double epsilon = 4 * std::numeric_limits<double>::epsilon(), bool useZValues = false ) = 0;
709
717 virtual double vertexAngle( QgsVertexId vertex ) const = 0;
718
722 virtual int vertexCount( int part = 0, int ring = 0 ) const = 0;
723
727 virtual int ringCount( int part = 0 ) const = 0;
728
734 virtual int partCount() const = 0;
735
743 virtual bool addZValue( double zValue = 0 ) = 0;
744
752 virtual bool addMValue( double mValue = 0 ) = 0;
753
760 virtual bool dropZValue() = 0;
761
768 virtual bool dropMValue() = 0;
769
776 virtual void swapXy() = 0;
777
782 virtual bool convertTo( Qgis::WkbType type );
783
803
815 virtual bool isValid( QString &error SIP_OUT, Qgis::GeometryValidityFlags flags = Qgis::GeometryValidityFlags() ) const = 0;
816
830 virtual bool transform( QgsAbstractGeometryTransformer *transformer, QgsFeedback *feedback = nullptr ) = 0;
831
832#ifndef SIP_RUN
833
843 virtual void filterVertices( const std::function< bool( const QgsPoint & ) > &filter );
844
859 virtual void transformVertices( const std::function< QgsPoint( const QgsPoint & ) > &transform );
860
866 class CORE_EXPORT part_iterator
867 {
868 private:
869
870 int mIndex = 0;
871 QgsAbstractGeometry *mGeometry = nullptr;
872
873 public:
875 part_iterator() = default;
876
878 part_iterator( QgsAbstractGeometry *g, int index );
879
885
888
891
893 int partNumber() const;
894
895 bool operator==( part_iterator other ) const;
896 bool operator!=( part_iterator other ) const { return !( *this == other ); }
897 };
898
908 {
909 return part_iterator( this, 0 );
910 }
911
920 part_iterator parts_end();
921
929 QgsGeometryConstPartIterator parts() const;
930
936 class CORE_EXPORT const_part_iterator
937 {
938 private:
939
940 int mIndex = 0;
941 const QgsAbstractGeometry *mGeometry = nullptr;
942
943 public:
946
948 const_part_iterator( const QgsAbstractGeometry *g, int index );
949
955
958
960 const QgsAbstractGeometry *operator*() const;
961
963 int partNumber() const;
964
965 bool operator==( const_part_iterator other ) const;
966 bool operator!=( const_part_iterator other ) const { return !( *this == other ); }
967 };
968
977 {
978 return const_part_iterator( this, 0 );
979 }
980
988 const_part_iterator const_parts_end() const;
989
990
995 class CORE_EXPORT vertex_iterator
996 {
997 private:
998
1004 struct Level
1005 {
1006 const QgsAbstractGeometry *g = nullptr;
1007 int index = 0;
1008
1009 bool operator==( const Level &other ) const;
1010 };
1011
1012 std::array<Level, 3> levels;
1013 int depth = -1;
1014
1015 void digDown();
1016
1017 public:
1019 vertex_iterator() = default;
1020
1022 vertex_iterator( const QgsAbstractGeometry *g, int index );
1023
1029
1032
1034 QgsPoint operator*() const;
1035
1037 QgsVertexId vertexId() const;
1038
1039 bool operator==( const vertex_iterator &other ) const;
1040 bool operator!=( const vertex_iterator &other ) const { return !( *this == other ); }
1041 };
1042
1051 {
1052 return vertex_iterator( this, 0 );
1053 }
1054
1063 {
1064 return vertex_iterator( this, childCount() );
1065 }
1066#endif
1067
1102
1103
1126 QgsVertexIterator vertices() const;
1127
1134
1135 protected:
1136
1143 int sortIndex() const;
1144
1155 virtual int compareToSameClass( const QgsAbstractGeometry *other ) const = 0;
1156
1161 virtual bool hasChildGeometries() const;
1162
1167 virtual int childCount() const { return 0; }
1168
1173 virtual QgsAbstractGeometry *childGeometry( int index ) const { Q_UNUSED( index ) return nullptr; }
1174
1179 virtual QgsPoint childPoint( int index ) const;
1180
1181 protected:
1183
1187 void setZMTypeFromSubGeometry( const QgsAbstractGeometry *subggeom, Qgis::WkbType baseGeomType );
1188
1193 virtual QgsRectangle calculateBoundingBox() const;
1194
1201 virtual QgsBox3D calculateBoundingBox3D() const;
1202
1206 virtual void clearCache() const;
1207
1208 friend class TestQgsGeometry;
1209};
1210
1211
1212#ifndef SIP_RUN
1213
1214template <class T>
1216{
1217 return std::remove_pointer<T>::type::cast( geom );
1218}
1219
1220template <class T>
1222{
1223 return std::remove_pointer<T>::type::cast( geom );
1224}
1225
1226#endif
1227
1228// clazy:excludeall=qstring-allocations
1229
1234class CORE_EXPORT QgsVertexIterator
1235{
1236 public:
1237
1239
1242 : g( geometry )
1243 , i( g->vertices_begin() )
1244 , n( g->vertices_end() )
1245 {
1246 }
1247
1249 bool hasNext() const
1250 {
1251 return g && g->vertices_end() != i;
1252 }
1253
1255 QgsPoint next();
1256
1257#ifdef SIP_RUN
1258// clang-format off
1259 QgsVertexIterator *__iter__();
1260 % MethodCode
1261 sipRes = sipCpp;
1262 % End
1263
1264 SIP_PYOBJECT __next__() SIP_TYPEHINT( QgsPoint );
1265 % MethodCode
1266 if ( sipCpp->hasNext() )
1267 sipRes = sipConvertFromType( new QgsPoint( sipCpp->next() ), sipType_QgsPoint, Py_None );
1268 else
1269 PyErr_SetString( PyExc_StopIteration, "" );
1270 % End
1271// clang-format on
1272#endif
1273
1274 private:
1275 const QgsAbstractGeometry *g = nullptr;
1277
1278};
1279
1286{
1287 public:
1288
1290
1293 : g( geometry )
1294 , i( g->parts_begin() )
1295 , n( g->parts_end() )
1296 {
1297 }
1298
1301 {
1302 return g && g->parts_end() != i;
1303 }
1304
1306 QgsAbstractGeometry *next();
1307
1308#ifdef SIP_RUN
1309// clang-format off
1310 QgsGeometryPartIterator *__iter__();
1311 % MethodCode
1312 sipRes = sipCpp;
1313 % End
1314
1315 SIP_PYOBJECT __next__() SIP_TYPEHINT( QgsAbstractGeometry );
1316 % MethodCode
1317 if ( sipCpp->hasNext() )
1318 sipRes = sipConvertFromType( sipCpp->next(), sipType_QgsAbstractGeometry, NULL );
1319 else
1320 PyErr_SetString( PyExc_StopIteration, "" );
1321 % End
1322// clang-format on
1323#endif
1324
1325 private:
1326 QgsAbstractGeometry *g = nullptr;
1328
1329};
1330
1331
1338{
1339 public:
1340
1342
1345 : g( geometry )
1346 , i( g->const_parts_begin() )
1347 , n( g->const_parts_end() )
1348 {
1349 }
1350
1353 {
1354 return g && g->const_parts_end() != i;
1355 }
1356
1358 const QgsAbstractGeometry *next();
1359
1360#ifdef SIP_RUN
1361// clang-format off
1362 QgsGeometryConstPartIterator *__iter__();
1363 % MethodCode
1364 sipRes = sipCpp;
1365 % End
1366
1367 SIP_PYOBJECT __next__() SIP_TYPEHINT( QgsAbstractGeometry );
1368 % MethodCode
1369 if ( sipCpp->hasNext() )
1370 sipRes = sipConvertFromType( const_cast< QgsAbstractGeometry * >( sipCpp->next() ), sipType_QgsAbstractGeometry, NULL );
1371 else
1372 PyErr_SetString( PyExc_StopIteration, "" );
1373 % End
1374// clang-format on
1375#endif
1376
1377 private:
1378 const QgsAbstractGeometry *g = nullptr;
1380
1381};
1382
1384
1385#endif //QGSABSTRACTGEOMETRYV2
Provides global constants and enumerations for use throughout the application.
Definition qgis.h:62
WkbType
The WKB type describes the number of dimensions a geometry has.
Definition qgis.h:294
@ Unknown
Unknown.
Definition qgis.h:295
An abstract base class for classes which transform geometries by transforming input points to output ...
The part_iterator class provides an STL-style iterator for const references to geometry parts.
const_part_iterator & operator++()
The prefix ++ operator (++it) advances the iterator to the next part and returns an iterator to the n...
bool operator!=(const_part_iterator other) const
const_part_iterator()=default
Create invalid iterator.
int partNumber() const
Returns the part number of the current item.
The part_iterator class provides an STL-style iterator for geometry parts.
part_iterator & operator++()
The prefix ++ operator (++it) advances the iterator to the next part and returns an iterator to the n...
part_iterator()=default
Create invalid iterator.
bool operator!=(part_iterator other) const
int partNumber() const
Returns the part number of the current item.
The vertex_iterator class provides an STL-style iterator for vertices.
vertex_iterator()=default
Create invalid iterator.
bool operator!=(const vertex_iterator &other) const
vertex_iterator & operator++()
The prefix ++ operator (++it) advances the iterator to the next vertex and returns an iterator to the...
QgsVertexId vertexId() const
Returns vertex ID of the current item.
Abstract base class for all geometries.
virtual int ringCount(int part=0) const =0
Returns the number of rings of which this geometry is built.
virtual QgsAbstractGeometry * snappedToGrid(double hSpacing, double vSpacing, double dSpacing=0, double mSpacing=0, bool removeRedundantPoints=false) const =0
Makes a new geometry with all the points or vertices snapped to the closest point of the grid.
virtual bool addZValue(double zValue=0)=0
Adds a z-dimension to the geometry, initialized to a preset value.
virtual bool fromWkb(QgsConstWkbPtr &wkb)=0
Sets the geometry from a WKB string.
virtual bool moveVertex(QgsVertexId position, const QgsPoint &newPos)=0
Moves a vertex within the geometry.
SegmentationToleranceType
Segmentation tolerance as maximum angle or maximum difference between approximation and circle.
@ MaximumDifference
Maximum distance between an arbitrary point on the original curve and closest point on its approximat...
@ MaximumAngle
Maximum angle between generating radii (lines from arc center to output vertices).
virtual int vertexNumberFromVertexId(QgsVertexId id) const =0
Returns the vertex number corresponding to a vertex id.
virtual bool convertTo(Qgis::WkbType type)
Converts the geometry to a specified type.
virtual QgsAbstractGeometry * boundary() const =0
Returns the closure of the combinatorial boundary of the geometry (ie the topological boundary of the...
virtual double vertexAngle(QgsVertexId vertex) const =0
Returns approximate angle at a vertex.
virtual bool dropMValue()=0
Drops any measure values which exist in the geometry.
vertex_iterator vertices_end() const
Returns STL-style iterator pointing to the imaginary vertex after the last vertex of the geometry.
virtual QgsBox3D calculateBoundingBox3D() const
Calculates the minimal 3D bounding box for the geometry.
virtual void draw(QPainter &p) const =0
Draws the geometry using the specified QPainter.
virtual const QgsAbstractGeometry * simplifiedTypeRef() const
Returns a reference to the simplest lossless representation of this geometry, e.g.
virtual QgsAbstractGeometry * segmentize(double tolerance=M_PI/180., SegmentationToleranceType toleranceType=MaximumAngle) const
Returns a version of the geometry without curves.
virtual int vertexCount(int part=0, int ring=0) const =0
Returns the number of vertices of which this geometry is built.
bool isMeasure() const
Returns true if the geometry contains m values.
QFlags< WkbFlag > WkbFlags
virtual QgsAbstractGeometry * simplifyByDistance(double tolerance) const =0
Simplifies the geometry by applying the Douglas Peucker simplification by distance algorithm.
virtual QgsRectangle calculateBoundingBox() const
Default calculator for the minimal bounding box for the geometry.
virtual int childCount() const
Returns number of child geometries (for geometries with child geometries) or child points (for geomet...
virtual QgsRectangle boundingBox() const
Returns the minimal bounding box for the geometry.
virtual void transformVertices(const std::function< QgsPoint(const QgsPoint &) > &transform)
Transforms the vertices from the geometry in place, applying the transform function to every vertex.
virtual bool isValid(QString &error, Qgis::GeometryValidityFlags flags=Qgis::GeometryValidityFlags()) const =0
Checks validity of the geometry, and returns true if the geometry is valid.
bool is3D() const
Returns true if the geometry is 3D and contains a z-value.
AxisOrder
Axis order for GML generation.
@ XY
X comes before Y (or lon before lat).
@ YX
Y comes before X (or lat before lon).
virtual QgsBox3D boundingBox3D() const =0
Returns the 3D bounding box for the geometry.
virtual QString geometryType() const =0
Returns a unique string representing the geometry type.
int sortIndex() const
Returns the sort index for the geometry, used in the compareTo() method to compare geometries of diff...
virtual QgsAbstractGeometry * createEmptyWithSameType() const =0
Creates a new geometry with the same class and same WKB type as the original and transfers ownership.
virtual double perimeter() const
Returns the planar, 2-dimensional perimeter of the geometry.
virtual int nCoordinates() const
Returns the number of nodes contained in the geometry.
virtual QByteArray asWkb(WkbFlags flags=QgsAbstractGeometry::WkbFlags()) const =0
Returns a WKB representation of the geometry.
virtual double area3D() const
Returns the 3-dimensional surface area of the geometry.
virtual QgsPoint vertexAt(QgsVertexId id) const =0
Returns the point corresponding to a specified vertex id.
virtual QgsAbstractGeometry * toCurveType() const =0
Returns the geometry converted to the more generic curve type.
virtual void adjacentVertices(QgsVertexId vertex, QgsVertexId &previousVertex, QgsVertexId &nextVertex) const =0
Returns the vertices adjacent to a specified vertex within a geometry.
virtual QDomElement asGml2(QDomDocument &doc, int precision=17, const QString &ns="gml", AxisOrder axisOrder=QgsAbstractGeometry::AxisOrder::XY) const =0
Returns a GML2 representation of the geometry.
virtual void clearCache() const
Clears any cached parameters associated with the geometry, e.g., bounding boxes.
virtual bool addMValue(double mValue=0)=0
Adds a measure to the geometry, initialized to a preset value.
Qgis::WkbType wkbType() const
Returns the WKB type of the geometry.
virtual bool insertVertex(QgsVertexId position, const QgsPoint &vertex)=0
Inserts a vertex into the geometry.
virtual void swapXy()=0
Swaps the x and y coordinates from the geometry.
QString asJson(int precision=17)
Returns a GeoJSON representation of the geometry as a QString.
void setZMTypeFromSubGeometry(const QgsAbstractGeometry *subggeom, Qgis::WkbType baseGeomType)
Updates the geometry type based on whether sub geometries contain z or m values.
virtual double length() const
Returns the planar, 2-dimensional length of the geometry.
virtual QString asWkt(int precision=17) const =0
Returns a WKT representation of the geometry.
virtual bool fuzzyEqual(const QgsAbstractGeometry &other, double epsilon=1e-8) const =0
Performs fuzzy comparison between this geometry and other using an epsilon.
virtual bool isEmpty() const
Returns true if the geometry is empty.
virtual bool fuzzyDistanceEqual(const QgsAbstractGeometry &other, double epsilon=1e-8) const =0
Performs fuzzy distance comparison between this geometry and other using an epsilon.
virtual json asJsonObject(int precision=17) const
Returns a json object representation of the geometry.
virtual QDomElement asGml3(QDomDocument &doc, int precision=17, const QString &ns="gml", AxisOrder axisOrder=QgsAbstractGeometry::AxisOrder::XY) const =0
Returns a GML3 representation of the geometry.
virtual QgsCoordinateSequence coordinateSequence() const =0
Retrieves the sequence of geometries, rings and nodes.
virtual bool fromWkt(const QString &wkt)=0
Sets the geometry from a WKT string.
virtual int partCount() const =0
Returns count of parts contained in the geometry.
virtual bool hasChildGeometries() const
Returns whether the geometry has any child geometries (false for point / curve, true otherwise).
virtual QPainterPath asQPainterPath() const =0
Returns the geometry represented as a QPainterPath.
virtual void transform(const QgsCoordinateTransform &ct, Qgis::TransformDirection d=Qgis::TransformDirection::Forward, bool transformZ=false)=0
Transforms the geometry using a coordinate transform.
virtual bool boundingBoxIntersects(const QgsRectangle &rectangle) const
Returns true if the bounding box of this geometry intersects with a rectangle.
virtual void normalize()=0
Reorganizes the geometry into a normalized form (or "canonical" form).
vertex_iterator vertices_begin() const
Returns STL-style iterator pointing to the first vertex of the geometry.
virtual bool deleteVertex(QgsVertexId position)=0
Deletes a vertex within the geometry.
virtual bool hasCurvedSegments() const
Returns true if the geometry contains curved segments.
virtual void clear()=0
Clears the geometry, ie reset it to a null geometry.
virtual void filterVertices(const std::function< bool(const QgsPoint &) > &filter)
Filters the vertices from the geometry in place, removing any which do not return true for the filter...
virtual bool dropZValue()=0
Drops any z-dimensions which exist in the geometry.
@ FlagExportTrianglesAsPolygons
Triangles should be exported as polygon geometries.
@ FlagExportNanAsDoubleMin
Use -DOUBLE_MAX to represent NaN.
virtual QgsPoint centroid() const
Returns the centroid of the geometry.
virtual QgsAbstractGeometry * childGeometry(int index) const
Returns pointer to child geometry (for geometries with child geometries - i.e.
virtual int dimension() const =0
Returns the inherent dimension of the geometry.
virtual double segmentLength(QgsVertexId startVertex) const =0
Returns the length of the segment of the geometry which begins at startVertex.
virtual int compareTo(const QgsAbstractGeometry *other) const
Comparator for sorting of geometry.
virtual QString asKml(int precision=17) const =0
Returns a KML representation of the geometry.
virtual bool removeDuplicateNodes(double epsilon=4 *std::numeric_limits< double >::epsilon(), bool useZValues=false)=0
Removes duplicate nodes from the geometry, wherever removing the nodes does not result in a degenerat...
virtual int wkbSize(QgsAbstractGeometry::WkbFlags flags=QgsAbstractGeometry::WkbFlags()) const =0
Returns the length of the QByteArray returned by asWkb().
const_part_iterator const_parts_begin() const
Returns STL-style iterator pointing to the const first part of the geometry.
QgsAbstractGeometry()=default
virtual double area() const
Returns the planar, 2-dimensional area of the geometry.
virtual int compareToSameClass(const QgsAbstractGeometry *other) const =0
Compares to an other geometry of the same class, and returns a integer for sorting of the two geometr...
part_iterator parts_begin()
Returns STL-style iterator pointing to the first part of the geometry.
virtual bool nextVertex(QgsVertexId &id, QgsPoint &vertex) const =0
Returns next vertex id and coordinates.
virtual QgsAbstractGeometry * clone() const =0
Clones the geometry by performing a deep copy.
virtual double closestSegment(const QgsPoint &pt, QgsPoint &segmentPt, QgsVertexId &vertexAfter, int *leftOf=nullptr, double epsilon=4 *std::numeric_limits< double >::epsilon()) const =0
Searches for the closest segment of the geometry to a given point.
A 3-dimensional box composed of x, y, z coordinates.
Definition qgsbox3d.h:45
A const WKB pointer.
Definition qgswkbptr.h:211
Handles coordinate transforms between two coordinate systems.
Custom exception class for Coordinate Reference System related exceptions.
Abstract base class for curved geometry type.
Definition qgscurve.h:36
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
Java-style iterator for const traversal of parts of a geometry.
QgsGeometryConstPartIterator(const QgsAbstractGeometry *geometry)
Constructs iterator for the given geometry.
bool hasNext() const
Find out whether there are more parts.
Java-style iterator for traversal of parts of a geometry.
QgsGeometryPartIterator()=default
bool hasNext() const
Find out whether there are more parts.
QgsGeometryPartIterator(QgsAbstractGeometry *geometry)
Constructs iterator for the given geometry.
Perform transforms between map coordinates and device coordinates.
Multi curve geometry collection.
Multi point geometry collection.
Point geometry type, with support for z-dimension and m-values.
Definition qgspoint.h:53
A rectangle specified with double values.
Java-style iterator for traversal of vertices of a geometry.
bool hasNext() const
Find out whether there are more vertices.
QgsVertexIterator()=default
QgsVertexIterator(const QgsAbstractGeometry *geometry)
Constructs iterator for the given geometry.
static Q_INVOKABLE bool hasZ(Qgis::WkbType type)
Tests whether a WKB type contains the z-dimension.
static Q_INVOKABLE bool hasM(Qgis::WkbType type)
Tests whether a WKB type contains m values.
#define SIP_TYPEHINT(type)
Definition qgis_sip.h:239
#define SIP_CONVERT_TO_SUBCLASS_CODE(code)
Definition qgis_sip.h:198
#define SIP_ENUM_BASETYPE(type)
Definition qgis_sip.h:274
#define SIP_SKIP
Definition qgis_sip.h:133
#define SIP_OUT
Definition qgis_sip.h:57
#define SIP_HOLDGIL
Definition qgis_sip.h:178
#define SIP_FACTORY
Definition qgis_sip.h:83
#define SIP_THROW(name,...)
Definition qgis_sip.h:210
#define SIP_END
Definition qgis_sip.h:215
T qgsgeometry_cast(QgsAbstractGeometry *geom)
QVector< QgsRingSequence > QgsCoordinateSequence
QVector< QgsPointSequence > QgsRingSequence
QVector< QgsPoint > QgsPointSequence
bool operator==(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
QgsMargins operator*(const QgsMargins &margins, double factor)
Returns a QgsMargins object that is formed by multiplying each component of the given margins by fact...
Definition qgsmargins.h:245
Q_DECLARE_OPERATORS_FOR_FLAGS(QgsProjectionSelectionWidget::CrsOptions)
Utility class for identifying a unique vertex within a geometry.
Definition qgsvertexid.h:34