QGIS API Documentation 3.99.0-Master (2fe06baccd8)
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
83#ifdef SIP_RUN
85 if ( qgsgeometry_cast<QgsPoint *>( sipCpp ) != nullptr )
86 sipType = sipType_QgsPoint;
87 else if ( qgsgeometry_cast<QgsLineString *>( sipCpp ) != nullptr )
88 sipType = sipType_QgsLineString;
89 else if ( qgsgeometry_cast<QgsCircularString *>( sipCpp ) != nullptr )
90 sipType = sipType_QgsCircularString;
91 else if ( qgsgeometry_cast<QgsCompoundCurve *>( sipCpp ) != nullptr )
92 sipType = sipType_QgsCompoundCurve;
93 else if ( qgsgeometry_cast<QgsTriangle *>( sipCpp ) != nullptr )
94 sipType = sipType_QgsTriangle;
95 else if ( qgsgeometry_cast<QgsPolygon *>( sipCpp ) != nullptr )
96 sipType = sipType_QgsPolygon;
97 else if ( qgsgeometry_cast<QgsCurvePolygon *>( sipCpp ) != nullptr )
98 sipType = sipType_QgsCurvePolygon;
99 else if ( qgsgeometry_cast<QgsTriangulatedSurface *>( sipCpp ) != nullptr )
100 sipType = sipType_QgsTriangulatedSurface;
101 else if ( qgsgeometry_cast<QgsPolyhedralSurface *>( sipCpp ) != nullptr )
102 sipType = sipType_QgsPolyhedralSurface;
103 else if ( qgsgeometry_cast<QgsSurface *>( sipCpp ) != nullptr )
104 sipType = sipType_QgsSurface;
105 else if ( qgsgeometry_cast<QgsMultiPoint *>( sipCpp ) != nullptr )
106 sipType = sipType_QgsMultiPoint;
107 else if ( qgsgeometry_cast<QgsMultiLineString *>( sipCpp ) != nullptr )
108 sipType = sipType_QgsMultiLineString;
109 else if ( qgsgeometry_cast<QgsMultiPolygon *>( sipCpp ) != nullptr )
110 sipType = sipType_QgsMultiPolygon;
111 else if ( qgsgeometry_cast<QgsMultiSurface *>( sipCpp ) != nullptr )
112 sipType = sipType_QgsMultiSurface;
113 else if ( qgsgeometry_cast<QgsMultiCurve *>( sipCpp ) != nullptr )
114 sipType = sipType_QgsMultiCurve;
115 else if ( qgsgeometry_cast<QgsGeometryCollection *>( sipCpp ) != nullptr )
116 sipType = sipType_QgsGeometryCollection;
117 else
118 sipType = 0;
119 SIP_END
120#endif
121
122 Q_GADGET
123
124 public:
125
142 Q_ENUM( SegmentationToleranceType )
143
144
146 {
147
151 XY = 0,
152
157 };
159
161 virtual ~QgsAbstractGeometry() = default;
163 QgsAbstractGeometry &operator=( const QgsAbstractGeometry &geom );
164
165 virtual bool operator==( const QgsAbstractGeometry &other ) const = 0;
166 virtual bool operator!=( const QgsAbstractGeometry &other ) const = 0;
167
178 virtual bool fuzzyEqual( const QgsAbstractGeometry &other, double epsilon = 1e-8 ) const = 0;
179
193 virtual bool fuzzyDistanceEqual( const QgsAbstractGeometry &other, double epsilon = 1e-8 ) const = 0;
194
199
205 virtual int compareTo( const QgsAbstractGeometry *other ) const;
206
210 virtual void clear() = 0;
211
215 virtual QgsRectangle boundingBox() const;
216
222 virtual QgsBox3D boundingBox3D() const = 0;
223
224 //mm-sql interface
225
230 virtual int dimension() const = 0;
231
237 virtual QString geometryType() const = 0;
238
244 inline Qgis::WkbType wkbType() const SIP_HOLDGIL { return mWkbType; }
245
251 QString wktTypeStr() const;
252
257 bool is3D() const SIP_HOLDGIL
258 {
259 return QgsWkbTypes::hasZ( mWkbType );
260 }
261
267 {
268 return QgsWkbTypes::hasM( mWkbType );
269 }
270
277
287 virtual void normalize() = 0;
288
289 //import
290
296 virtual bool fromWkb( QgsConstWkbPtr &wkb ) = 0;
297
302 virtual bool fromWkt( const QString &wkt ) = 0;
303
304 //export
305
315 Q_DECLARE_FLAGS( WkbFlags, WkbFlag )
316
317
325
336 virtual QByteArray asWkb( WkbFlags flags = QgsAbstractGeometry::WkbFlags() ) const = 0;
337
346 virtual QString asWkt( int precision = 17 ) const = 0;
347
359 virtual QDomElement asGml2( QDomDocument &doc, int precision = 17, const QString &ns = "gml", AxisOrder axisOrder = QgsAbstractGeometry::AxisOrder::XY ) const = 0;
360
372 virtual QDomElement asGml3( QDomDocument &doc, int precision = 17, const QString &ns = "gml", AxisOrder axisOrder = QgsAbstractGeometry::AxisOrder::XY ) const = 0;
373
383 QString asJson( int precision = 17 );
384
395 virtual json asJsonObject( int precision = 17 ) SIP_SKIP const;
396
401 virtual QString asKml( int precision = 17 ) const = 0;
402
403
404 //render pipeline
405
416 virtual void transform( const QgsCoordinateTransform &ct, Qgis::TransformDirection d = Qgis::TransformDirection::Forward, bool transformZ = false ) SIP_THROW( QgsCsException ) = 0;
417
424 virtual void transform( const QTransform &t, double zTranslate = 0.0, double zScale = 1.0,
425 double mTranslate = 0.0, double mScale = 1.0 ) = 0;
426
431 virtual void draw( QPainter &p ) const = 0;
432
441 virtual QPainterPath asQPainterPath() const = 0;
442
452 virtual int vertexNumberFromVertexId( QgsVertexId id ) const = 0;
453
461 virtual bool nextVertex( QgsVertexId &id, QgsPoint &vertex SIP_OUT ) const = 0;
462
466 virtual void adjacentVertices( QgsVertexId vertex, QgsVertexId &previousVertex SIP_OUT, QgsVertexId &nextVertex SIP_OUT ) const = 0;
467
473
477 virtual int nCoordinates() const;
478
482 virtual QgsPoint vertexAt( QgsVertexId id ) const = 0;
483
496 virtual double closestSegment( const QgsPoint &pt, QgsPoint &segmentPt SIP_OUT,
497 QgsVertexId &vertexAfter SIP_OUT,
498 int *leftOf SIP_OUT = nullptr, double epsilon = 4 * std::numeric_limits<double>::epsilon() ) const = 0;
499
500 //low-level editing
501
510 virtual bool insertVertex( QgsVertexId position, const QgsPoint &vertex ) = 0;
511
520 virtual bool moveVertex( QgsVertexId position, const QgsPoint &newPos ) = 0;
521
529 virtual bool deleteVertex( QgsVertexId position ) = 0;
530
543 virtual double length() const;
544
557 virtual double perimeter() const;
558
571 virtual double area() const;
572
580 virtual double segmentLength( QgsVertexId startVertex ) const = 0;
581
583 virtual QgsPoint centroid() const;
584
588 virtual bool isEmpty() const;
589
593 virtual bool hasCurvedSegments() const;
594
603 virtual bool boundingBoxIntersects( const QgsRectangle &rectangle ) const SIP_HOLDGIL;
604
613 virtual bool boundingBoxIntersects( const QgsBox3D &box3d ) const SIP_HOLDGIL;
614
621 virtual QgsAbstractGeometry *segmentize( double tolerance = M_PI / 180., SegmentationToleranceType toleranceType = MaximumAngle ) const SIP_FACTORY;
622
630
653 virtual QgsAbstractGeometry *snappedToGrid( double hSpacing, double vSpacing, double dSpacing = 0, double mSpacing = 0, bool removeRedundantPoints = false ) const = 0 SIP_FACTORY;
654
667 virtual QgsAbstractGeometry *simplifyByDistance( double tolerance ) const = 0 SIP_FACTORY;
668
688 virtual bool removeDuplicateNodes( double epsilon = 4 * std::numeric_limits<double>::epsilon(), bool useZValues = false ) = 0;
689
697 virtual double vertexAngle( QgsVertexId vertex ) const = 0;
698
702 virtual int vertexCount( int part = 0, int ring = 0 ) const = 0;
703
707 virtual int ringCount( int part = 0 ) const = 0;
708
714 virtual int partCount() const = 0;
715
723 virtual bool addZValue( double zValue = 0 ) = 0;
724
732 virtual bool addMValue( double mValue = 0 ) = 0;
733
740 virtual bool dropZValue() = 0;
741
748 virtual bool dropMValue() = 0;
749
756 virtual void swapXy() = 0;
757
762 virtual bool convertTo( Qgis::WkbType type );
763
783
795 virtual bool isValid( QString &error SIP_OUT, Qgis::GeometryValidityFlags flags = Qgis::GeometryValidityFlags() ) const = 0;
796
810 virtual bool transform( QgsAbstractGeometryTransformer *transformer, QgsFeedback *feedback = nullptr ) = 0;
811
812#ifndef SIP_RUN
813
823 virtual void filterVertices( const std::function< bool( const QgsPoint & ) > &filter );
824
839 virtual void transformVertices( const std::function< QgsPoint( const QgsPoint & ) > &transform );
840
846 class CORE_EXPORT part_iterator
847 {
848 private:
849
850 int mIndex = 0;
851 QgsAbstractGeometry *mGeometry = nullptr;
852
853 public:
855 part_iterator() = default;
856
858 part_iterator( QgsAbstractGeometry *g, int index );
859
865
868
871
873 int partNumber() const;
874
875 bool operator==( part_iterator other ) const;
876 bool operator!=( part_iterator other ) const { return !( *this == other ); }
877 };
878
888 {
889 return part_iterator( this, 0 );
890 }
891
900 part_iterator parts_end();
901
909 QgsGeometryConstPartIterator parts() const;
910
916 class CORE_EXPORT const_part_iterator
917 {
918 private:
919
920 int mIndex = 0;
921 const QgsAbstractGeometry *mGeometry = nullptr;
922
923 public:
926
928 const_part_iterator( const QgsAbstractGeometry *g, int index );
929
935
938
940 const QgsAbstractGeometry *operator*() const;
941
943 int partNumber() const;
944
945 bool operator==( const_part_iterator other ) const;
946 bool operator!=( const_part_iterator other ) const { return !( *this == other ); }
947 };
948
957 {
958 return const_part_iterator( this, 0 );
959 }
960
968 const_part_iterator const_parts_end() const;
969
970
975 class CORE_EXPORT vertex_iterator
976 {
977 private:
978
984 struct Level
985 {
986 const QgsAbstractGeometry *g = nullptr;
987 int index = 0;
988
989 bool operator==( const Level &other ) const;
990 };
991
992 std::array<Level, 3> levels;
993 int depth = -1;
994
995 void digDown();
996
997 public:
999 vertex_iterator() = default;
1000
1002 vertex_iterator( const QgsAbstractGeometry *g, int index );
1003
1009
1012
1014 QgsPoint operator*() const;
1015
1017 QgsVertexId vertexId() const;
1018
1019 bool operator==( const vertex_iterator &other ) const;
1020 bool operator!=( const vertex_iterator &other ) const { return !( *this == other ); }
1021 };
1022
1031 {
1032 return vertex_iterator( this, 0 );
1033 }
1034
1043 {
1044 return vertex_iterator( this, childCount() );
1045 }
1046#endif
1047
1082
1083
1106 QgsVertexIterator vertices() const;
1107
1114
1115 protected:
1116
1123 int sortIndex() const;
1124
1135 virtual int compareToSameClass( const QgsAbstractGeometry *other ) const = 0;
1136
1141 virtual bool hasChildGeometries() const;
1142
1147 virtual int childCount() const { return 0; }
1148
1153 virtual QgsAbstractGeometry *childGeometry( int index ) const { Q_UNUSED( index ) return nullptr; }
1154
1159 virtual QgsPoint childPoint( int index ) const;
1160
1161 protected:
1163
1167 void setZMTypeFromSubGeometry( const QgsAbstractGeometry *subggeom, Qgis::WkbType baseGeomType );
1168
1173 virtual QgsRectangle calculateBoundingBox() const;
1174
1181 virtual QgsBox3D calculateBoundingBox3D() const;
1182
1186 virtual void clearCache() const;
1187
1188 friend class TestQgsGeometry;
1189};
1190
1191
1192#ifndef SIP_RUN
1193
1194template <class T>
1196{
1197 return std::remove_pointer<T>::type::cast( geom );
1198}
1199
1200template <class T>
1202{
1203 return std::remove_pointer<T>::type::cast( geom );
1204}
1205
1206#endif
1207
1208// clazy:excludeall=qstring-allocations
1209
1214class CORE_EXPORT QgsVertexIterator
1215{
1216 public:
1217
1219
1222 : g( geometry )
1223 , i( g->vertices_begin() )
1224 , n( g->vertices_end() )
1225 {
1226 }
1227
1229 bool hasNext() const
1230 {
1231 return g && g->vertices_end() != i;
1232 }
1233
1235 QgsPoint next();
1236
1237#ifdef SIP_RUN
1238 QgsVertexIterator *__iter__();
1239 % MethodCode
1240 sipRes = sipCpp;
1241 % End
1242
1243 SIP_PYOBJECT __next__() SIP_TYPEHINT( QgsPoint );
1244 % MethodCode
1245 if ( sipCpp->hasNext() )
1246 sipRes = sipConvertFromType( new QgsPoint( sipCpp->next() ), sipType_QgsPoint, Py_None );
1247 else
1248 PyErr_SetString( PyExc_StopIteration, "" );
1249 % End
1250#endif
1251
1252 private:
1253 const QgsAbstractGeometry *g = nullptr;
1255
1256};
1257
1264{
1265 public:
1266
1268
1271 : g( geometry )
1272 , i( g->parts_begin() )
1273 , n( g->parts_end() )
1274 {
1275 }
1276
1279 {
1280 return g && g->parts_end() != i;
1281 }
1282
1284 QgsAbstractGeometry *next();
1285
1286#ifdef SIP_RUN
1287 QgsGeometryPartIterator *__iter__();
1288 % MethodCode
1289 sipRes = sipCpp;
1290 % End
1291
1292 SIP_PYOBJECT __next__() SIP_TYPEHINT( QgsAbstractGeometry );
1293 % MethodCode
1294 if ( sipCpp->hasNext() )
1295 sipRes = sipConvertFromType( sipCpp->next(), sipType_QgsAbstractGeometry, NULL );
1296 else
1297 PyErr_SetString( PyExc_StopIteration, "" );
1298 % End
1299#endif
1300
1301 private:
1302 QgsAbstractGeometry *g = nullptr;
1304
1305};
1306
1307
1314{
1315 public:
1316
1318
1321 : g( geometry )
1322 , i( g->const_parts_begin() )
1323 , n( g->const_parts_end() )
1324 {
1325 }
1326
1329 {
1330 return g && g->const_parts_end() != i;
1331 }
1332
1334 const QgsAbstractGeometry *next();
1335
1336#ifdef SIP_RUN
1337 QgsGeometryConstPartIterator *__iter__();
1338 % MethodCode
1339 sipRes = sipCpp;
1340 % End
1341
1342 SIP_PYOBJECT __next__() SIP_TYPEHINT( QgsAbstractGeometry );
1343 % MethodCode
1344 if ( sipCpp->hasNext() )
1345 sipRes = sipConvertFromType( const_cast< QgsAbstractGeometry * >( sipCpp->next() ), sipType_QgsAbstractGeometry, NULL );
1346 else
1347 PyErr_SetString( PyExc_StopIteration, "" );
1348 % End
1349#endif
1350
1351 private:
1352 const QgsAbstractGeometry *g = nullptr;
1354
1355};
1356
1358
1359#endif //QGSABSTRACTGEOMETRYV2
Provides global constants and enumerations for use throughout the application.
Definition qgis.h:56
WkbType
The WKB type describes the number of dimensions a geometry has.
Definition qgis.h:277
@ Unknown
Unknown.
Definition qgis.h:278
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 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:42
A const WKB pointer.
Definition qgswkbptr.h:139
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:49
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:240
#define SIP_CONVERT_TO_SUBCLASS_CODE(code)
Definition qgis_sip.h:199
#define SIP_ENUM_BASETYPE(type)
Definition qgis_sip.h:275
#define SIP_SKIP
Definition qgis_sip.h:134
#define SIP_OUT
Definition qgis_sip.h:58
#define SIP_HOLDGIL
Definition qgis_sip.h:179
#define SIP_FACTORY
Definition qgis_sip.h:84
#define SIP_THROW(name,...)
Definition qgis_sip.h:211
#define SIP_END
Definition qgis_sip.h:216
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:250
Q_DECLARE_OPERATORS_FOR_FLAGS(QgsProjectionSelectionWidget::CrsOptions)
Utility class for identifying a unique vertex within a geometry.
Definition qgsvertexid.h:30