18 #ifndef QGSCIRCULARSTRING_H
19 #define QGSCIRCULARSTRING_H
37 virtual int dimension()
const override {
return 1; }
39 virtual void clear()
override;
43 virtual bool fromWkb(
const unsigned char * wkb )
override;
47 unsigned char*
asWkb(
int& binarySize )
const override;
71 virtual double length()
const override;
116 void sumUpArea(
double& sum )
const override;
128 virtual bool addZValue(
double zValue = 0 )
override;
129 virtual bool addMValue(
double mValue = 0 )
override;
140 double interpolateArc(
double angle,
double a1,
double a2,
double a3,
double zm1,
double zm2,
double zm3 )
const;
144 static QList<QgsPointV2> compassPointsOnSegment(
double p1Angle,
double p2Angle,
double p3Angle,
double centerX,
double centerY,
double radius );
145 static double closestPointOnArc(
double x1,
double y1,
double x2,
double y2,
double x3,
double y3,
147 void insertVertexBetween(
int after,
int before,
int pointOnCircle );
151 #endif // QGSCIRCULARSTRING_H
A rectangle specified with double values.
virtual double vertexAngle(const QgsVertexId &vertex) const =0
Returns approximate rotation angle for a vertex.
virtual bool moveVertex(const QgsVertexId &position, const QgsPointV2 &newPos)=0
Moves a vertex within the geometry.
Circular string geometry type.
virtual double length() const
Returns the length of the geometry.
virtual void points(QList< QgsPointV2 > &pt) const =0
Returns a list of points within the curve.
virtual QString asJSON(int precision=17) const =0
Returns a GeoJSON representation of the geometry.
virtual void addToPainterPath(QPainterPath &path) const =0
Adds a curve to a painter path.
TransformDirection
Enum used to indicate the direction (forward or inverse) of the transform.
virtual int wkbSize() const =0
Returns the size of the WKB representation of the geometry.
virtual bool insertVertex(const QgsVertexId &position, const QgsPointV2 &vertex)=0
Inserts a vertex into the geometry.
virtual bool addMValue(double mValue=0)=0
Adds a measure to the geometry, initialized to a preset value.
virtual void clear()=0
Clears the geometry, ie reset it to a null geometry.
virtual int numPoints() const =0
Returns the number of points in the curve.
virtual bool pointAt(int i, QgsPointV2 &vertex, QgsVertexId::VertexType &type) const =0
Returns the point and vertex id of a point within the curve.
Utility class for identifying a unique vertex within a geometry.
Line string geometry type.
virtual QgsRectangle calculateBoundingBox() const
Calculates the minimal bounding box for the geometry.
virtual bool fromWkb(const unsigned char *wkb)=0
Sets the geometry from a WKB string.
virtual unsigned char * asWkb(int &binarySize) const =0
Returns a WKB representation of the geometry.
virtual void transform(const QgsCoordinateTransform &ct, QgsCoordinateTransform::TransformDirection d=QgsCoordinateTransform::ForwardTransform)=0
Transforms the geometry using a coordinate transform.
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 QString geometryType() const override
Returns a unique string representing the geometry type.
virtual bool fromWkt(const QString &wkt)=0
Sets the geometry from a WKT string.
double ANALYSIS_EXPORT angle(Point3D *p1, Point3D *p2, Point3D *p3, Point3D *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored)
bool hasCurvedSegments() const override
Returns true if the geometry contains curved segments.
virtual void sumUpArea(double &sum) const =0
Calculates the area of the curve.
virtual bool deleteVertex(const QgsVertexId &position)=0
Deletes a vertex within the geometry.
virtual QgsLineStringV2 * curveToLine() const =0
Returns a new line string geometry corresponding to a segmentized approximation of the curve...
virtual QgsPointV2 endPoint() const =0
Returns the end point of the curve.
virtual int dimension() const override
Returns the inherent dimension of the geometry.
QgsAbstractGeometryV2 * segmentize() const override
Returns a version of the geometry without curves.
virtual QString asWkt(int precision=17) const =0
Returns a WKT representation of the geometry.
virtual QgsPointV2 startPoint() const =0
Returns the starting point of the curve.
virtual void draw(QPainter &p) const =0
Draws the geometry using the specified QPainter.
virtual void drawAsPolygon(QPainter &p) const =0
Draws the curve as a polygon on 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'.
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 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.