QGIS API Documentation  3.0.2-Girona (307d082)
qgsmultipoint.h
Go to the documentation of this file.
1 /***************************************************************************
2  qgsmultipoint.h
3  -------------------------------------------------------------------
4 Date : 29 Oct 2014
5 Copyright : (C) 2014 by Marco Hugentobler
6 email : 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 QGSMULTIPOINTV2_H
17 #define QGSMULTIPOINTV2_H
18 
19 #include "qgis_core.h"
20 #include "qgis.h"
21 #include "qgsgeometrycollection.h"
22 
29 class CORE_EXPORT QgsMultiPoint: public QgsGeometryCollection
30 {
31  public:
32  QgsMultiPoint();
33 
34  QString geometryType() const override;
35  QgsMultiPoint *clone() const override SIP_FACTORY;
36  QgsMultiPoint *toCurveType() const override SIP_FACTORY;
37  bool fromWkt( const QString &wkt ) override;
38  void clear() override;
39  QDomElement asGml2( QDomDocument &doc, int precision = 17, const QString &ns = "gml" ) const override;
40  QDomElement asGml3( QDomDocument &doc, int precision = 17, const QString &ns = "gml" ) const override;
41  QString asJson( int precision = 17 ) const override;
42  int nCoordinates() const override;
43  bool addGeometry( QgsAbstractGeometry *g SIP_TRANSFER ) override;
44  bool insertGeometry( QgsAbstractGeometry *g SIP_TRANSFER, int index ) override;
45  QgsAbstractGeometry *boundary() const override SIP_FACTORY;
46  int vertexNumberFromVertexId( QgsVertexId id ) const override;
47  double segmentLength( QgsVertexId startVertex ) const override;
48 
49 #ifndef SIP_RUN
50 
58  inline const QgsMultiPoint *cast( const QgsAbstractGeometry *geom ) const
59  {
60  if ( geom && QgsWkbTypes::flatType( geom->wkbType() ) == QgsWkbTypes::MultiPoint )
61  return static_cast<const QgsMultiPoint *>( geom );
62  return nullptr;
63  }
64 #endif
65 
67 
68  protected:
69 
70  bool wktOmitChildType() const override;
71 
72 };
73 
74 // clazy:excludeall=qstring-allocations
75 
76 #endif // QGSMULTIPOINTV2_H
QDomElement asGml2(QDomDocument &doc, int precision=17, const QString &ns="gml") const override
Returns a GML2 representation of the geometry.
void clear() override
Clears the geometry, ie reset it to a null geometry.
Multi point geometry collection.
Definition: qgsmultipoint.h:29
bool fromWkt(const QString &wkt) override
Sets the geometry from a WKT string.
QgsAbstractGeometry * boundary() const override
Returns the closure of the combinatorial boundary of the geometry (ie the topological boundary of the...
virtual bool wktOmitChildType() const
Returns whether child type names are omitted from Wkt representations of the collection.
double segmentLength(QgsVertexId startVertex) const override
Returns the length of the segment of the geometry which begins at startVertex.
QString asJson(int precision=17) const override
Returns a GeoJSON representation of the geometry.
virtual bool insertGeometry(QgsAbstractGeometry *g, int index)
Inserts a geometry before a specified index and takes ownership.
int nCoordinates() const override
Returns the number of nodes contained in the geometry.
QDomElement asGml3(QDomDocument &doc, int precision=17, const QString &ns="gml") const override
Returns a GML3 representation of the geometry.
Utility class for identifying a unique vertex within a geometry.
Geometry collection.
QgsGeometryCollection * createEmptyWithSameType() const override
Creates a new geometry with the same class and same WKB type as the original and transfers ownership...
#define SIP_TRANSFER
Definition: qgis_sip.h:36
QString geometryType() const override
Returns a unique string representing the geometry type.
#define SIP_FACTORY
Definition: qgis_sip.h:69
Abstract base class for all geometries.
QgsWkbTypes::Type wkbType() const
Returns the WKB type of the geometry.
int vertexNumberFromVertexId(QgsVertexId id) const override
Returns the vertex number corresponding to a vertex id.
const QgsMultiPoint * cast(const QgsAbstractGeometry *geom) const
Cast the geom to a QgsLineString.
Definition: qgsmultipoint.h:58
QgsGeometryCollection * toCurveType() const override
Returns the geometry converted to the more generic curve type.
QgsGeometryCollection * clone() const override
Clones the geometry by performing a deep copy.
static Type flatType(Type type)
Returns the flat type for a WKB type.
Definition: qgswkbtypes.h:427
virtual bool addGeometry(QgsAbstractGeometry *g)
Adds a geometry and takes ownership. Returns true in case of success.