18 #ifndef QGSCURVEPOLYGONV2_H 19 #define QGSCURVEPOLYGONV2_H 40 virtual int dimension()
const override {
return 2; }
42 void clear()
override;
48 unsigned char*
asWkb(
int& binarySize )
const override;
55 virtual double area()
const override;
56 virtual double perimeter()
const override;
61 int numInteriorRings()
const;
77 virtual void setExteriorRing(
QgsCurveV2* ring );
82 virtual void addInteriorRing(
QgsCurveV2* ring );
84 bool removeInteriorRing(
int nr );
88 bool transformZ =
false )
override;
112 virtual int vertexCount(
int = 0,
int ring = 0 )
const override;
113 virtual int ringCount(
int = 0 )
const override {
return (
nullptr != mExteriorRing ) + mInteriorRings.size(); }
117 virtual bool addZValue(
double zValue = 0 )
override;
118 virtual bool addMValue(
double mValue = 0 )
override;
130 #endif // QGSCURVEPOLYGONV2_H
A rectangle specified with double values.
virtual bool dropMValue()=0
Drops any measure values which exist in the geometry.
virtual QgsPolygonV2 * surfaceToPolygon() const =0
virtual QgsCoordinateSequenceV2 coordinateSequence() const =0
Retrieves the sequence of geometries, rings and nodes.
virtual int dimension() const override
Returns the inherent dimension of the geometry.
virtual QgsAbstractGeometryV2 & operator=(const QgsAbstractGeometryV2 &geom)
SegmentationToleranceType
Segmentation tolerance as maximum angle or maximum difference between approximation and circle...
virtual QString asJSON(int precision=17) const =0
Returns a GeoJSON representation of the geometry.
virtual bool hasCurvedSegments() const
Returns true if the geometry contains curved segments.
Abstract base class for all geometries.
virtual bool dropZValue()=0
Drops any z-dimensions which exist in the geometry.
virtual int wkbSize() const =0
Returns the size of the WKB representation of the geometry.
virtual bool addMValue(double mValue=0)=0
Adds a measure to the geometry, initialized to a preset value.
virtual int partCount() const override
Returns count of parts contained in the geometry.
virtual void clear()=0
Clears the geometry, ie reset it to a null geometry.
virtual QString geometryType() const override
Returns a unique string representing the geometry type.
Utility class for identifying a unique vertex within a geometry.
virtual bool fromWkb(QgsConstWkbPtr wkb)=0
Sets the geometry from a WKB string.
Point geometry type, with support for z-dimension and m-values.
virtual QgsAbstractGeometryV2 * segmentize(double tolerance=M_PI/180., SegmentationToleranceType toleranceType=MaximumAngle) const
Returns a version of the geometry without curves.
virtual unsigned char * asWkb(int &binarySize) const =0
Returns a WKB representation of the geometry.
virtual bool addZValue(double zValue=0)=0
Adds a z-dimension to the geometry, initialized to a preset value.
virtual QDomElement asGML3(QDomDocument &doc, int precision=17, const QString &ns="gml") const =0
Returns a GML3 representation of the geometry.
virtual bool nextVertex(QgsVertexId &id, QgsPointV2 &vertex) const =0
Returns next vertex id and coordinates.
virtual bool fromWkt(const QString &wkt)=0
Sets the geometry from a WKT string.
virtual int ringCount(int=0) const override
virtual int nCoordinates() const
Returns the number of nodes contained in the geometry.
virtual double perimeter() const
Returns the perimeter of the geometry.
virtual QgsAbstractGeometryV2 * 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.
QList< QgsCurveV2 * > mInteriorRings
virtual bool deleteVertex(QgsVertexId position)=0
Deletes a vertex within the geometry.
virtual bool insertVertex(QgsVertexId position, const QgsPointV2 &vertex)=0
Inserts a vertex into the geometry.
virtual int vertexCount(int part=0, int ring=0) const =0
virtual int ringCount(int part=0) const =0
virtual QString asWkt(int precision=17) const =0
Returns a WKT representation of the geometry.
virtual void draw(QPainter &p) const =0
Draws the geometry using the specified QPainter.
double ANALYSIS_EXPORT leftOf(Point3D *thepoint, Point3D *p1, Point3D *p2)
Returns whether 'thepoint' is left or right of the line from 'p1' to 'p2'.
Curve polygon geometry type.
virtual QDomElement asGML2(QDomDocument &doc, int precision=17, const QString &ns="gml") const =0
Returns a GML2 representation of the geometry.
virtual QgsAbstractGeometryV2 * clone() const =0
Clones the geometry by performing a deep copy.
Abstract base class for curved geometry type.
virtual QgsRectangle calculateBoundingBox() const
Default calculator for the minimal bounding box for the geometry.
virtual bool moveVertex(QgsVertexId position, const QgsPointV2 &newPos)=0
Moves a vertex within the geometry.
virtual double closestSegment(const QgsPointV2 &pt, QgsPointV2 &segmentPt, QgsVertexId &vertexAfter, bool *leftOf, double epsilon) const =0
Searches for the closest segment of the geometry to a given point.
virtual double area() const
Returns the area of the geometry.
virtual void transform(const QgsCoordinateTransform &ct, QgsCoordinateTransform::TransformDirection d=QgsCoordinateTransform::ForwardTransform, bool transformZ=false)=0
Transforms the geometry using a coordinate transform.
virtual QgsPointV2 vertexAt(QgsVertexId id) const =0
Returns the point corresponding to a specified vertex id.
QgsCurveV2 * mExteriorRing