QGIS API Documentation 3.34.0-Prizren (ffbdd678812)
Loading...
Searching...
No Matches
qgscircle.h
Go to the documentation of this file.
1/***************************************************************************
2 qgscircle.h
3 --------------
4 begin : March 2017
5 copyright : (C) 2017 by Loîc Bartoletti
6 email : lbartoletti at tuxfamily dot org
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
18#ifndef QGSCIRCLE_H
19#define QGSCIRCLE_H
20
21#include <QString>
22
23#include "qgis_core.h"
24#include "qgsellipse.h"
25#include "qgspolygon.h"
26#include "qgsrectangle.h"
27#include "qgscircularstring.h"
28
29
30class QgsPoint;
31
43class CORE_EXPORT QgsCircle : public QgsEllipse
44{
45 public:
46 QgsCircle();
47
54 QgsCircle( const QgsPoint &center, double radius, double azimuth = 0 ) SIP_HOLDGIL;
55
66 static QgsCircle from2Points( const QgsPoint &pt1, const QgsPoint &pt2 ) SIP_HOLDGIL;
67
80 static QgsCircle from3Points( const QgsPoint &pt1, const QgsPoint &pt2, const QgsPoint &pt3, double epsilon = 1E-8 ) SIP_HOLDGIL;
81
89 static QgsCircle fromCenterDiameter( const QgsPoint &center, double diameter, double azimuth = 0 ) SIP_HOLDGIL;
90
91
100 static QgsCircle fromCenterPoint( const QgsPoint &center, const QgsPoint &pt1 ) SIP_HOLDGIL;
101
102
131 static QgsCircle from3Tangents( const QgsPoint &pt1_tg1, const QgsPoint &pt2_tg1,
132 const QgsPoint &pt1_tg2, const QgsPoint &pt2_tg2,
133 const QgsPoint &pt1_tg3, const QgsPoint &pt2_tg3,
134 double epsilon = 1E-8,
135 const QgsPoint &pos = QgsPoint() ) SIP_HOLDGIL;
136
177 static QVector<QgsCircle> from3TangentsMulti( const QgsPoint &pt1_tg1, const QgsPoint &pt2_tg1,
178 const QgsPoint &pt1_tg2, const QgsPoint &pt2_tg2,
179 const QgsPoint &pt1_tg3, const QgsPoint &pt2_tg3,
180 double epsilon = 1E-8,
181 const QgsPoint &pos = QgsPoint() ) SIP_HOLDGIL;
182
193 static QgsCircle fromExtent( const QgsPoint &pt1, const QgsPoint &pt2 ) SIP_HOLDGIL;
194
205 static QgsCircle minimalCircleFrom3Points( const QgsPoint &pt1, const QgsPoint &pt2, const QgsPoint &pt3, double epsilon = 1E-8 ) SIP_HOLDGIL;
206
221 int intersections( const QgsCircle &other, QgsPoint &intersection1 SIP_OUT, QgsPoint &intersection2 SIP_OUT, bool useZ = false ) const;
222
236 bool tangentToPoint( const QgsPointXY &p, QgsPointXY &pt1 SIP_OUT, QgsPointXY &pt2 SIP_OUT ) const;
237
259 int outerTangents( const QgsCircle &other,
260 QgsPointXY &line1P1 SIP_OUT, QgsPointXY &line1P2 SIP_OUT,
261 QgsPointXY &line2P1 SIP_OUT, QgsPointXY &line2P2 SIP_OUT ) const;
262
284 int innerTangents( const QgsCircle &other,
285 QgsPointXY &line1P1 SIP_OUT, QgsPointXY &line1P2 SIP_OUT,
286 QgsPointXY &line2P1 SIP_OUT, QgsPointXY &line2P2 SIP_OUT ) const;
287
288 double area() const override SIP_HOLDGIL;
289 double perimeter() const override SIP_HOLDGIL;
290
291 //inherited
292 // void setAzimuth(const double azimuth);
293 // double azimuth() const {return mAzimuth; }
294
295
301 void setSemiMajorAxis( double semiMajorAxis ) override SIP_HOLDGIL;
302
308 void setSemiMinorAxis( double semiMinorAxis ) override SIP_HOLDGIL;
309
311 double radius() const SIP_HOLDGIL {return mSemiMajorAxis;}
313 void setRadius( double radius ) SIP_HOLDGIL
314 {
315 mSemiMajorAxis = std::fabs( radius );
316 mSemiMinorAxis = mSemiMajorAxis;
317 }
318
325 QVector<QgsPoint> northQuadrant() const SIP_FACTORY;
326
331 QgsCircularString *toCircularString( bool oriented = false ) const;
332
334 bool contains( const QgsPoint &point, double epsilon = 1E-8 ) const;
335
336 QgsRectangle boundingBox() const override;
337
338 QString toString( int pointPrecision = 17, int radiusPrecision = 17, int azimuthPrecision = 2 ) const override;
339
349 QDomElement asGml2( QDomDocument &doc, int precision = 17, const QString &ns = "gml", QgsAbstractGeometry::AxisOrder axisOrder = QgsAbstractGeometry::AxisOrder::XY ) const;
350
368 QDomElement asGml3( QDomDocument &doc, int precision = 17, const QString &ns = "gml", QgsAbstractGeometry::AxisOrder axisOrder = QgsAbstractGeometry::AxisOrder::XY ) const;
369
370#ifdef SIP_RUN
371 SIP_PYOBJECT __repr__();
372 % MethodCode
373 QString str = QStringLiteral( "<QgsCircle: %1>" ).arg( sipCpp->toString() );
374 sipRes = PyUnicode_FromString( str.toUtf8().constData() );
375 % End
376#endif
377};
378
379#endif // QGSCIRCLE_H
Abstract base class for all geometries.
Circle geometry type.
Definition qgscircle.h:44
double radius() const
Returns the radius of the circle.
Definition qgscircle.h:311
void setRadius(double radius)
Sets the radius of the circle.
Definition qgscircle.h:313
Circular string geometry type.
Ellipse geometry type.
Definition qgsellipse.h:40
static QgsEllipse fromCenterPoint(const QgsPoint &ptc, const QgsPoint &pt1)
Constructs an ellipse by a center point and a another point.
double mSemiMajorAxis
Definition qgsellipse.h:253
virtual double perimeter() const
The circumference of the ellipse using first approximation of Ramanujan.
virtual void setSemiMinorAxis(double semiMinorAxis)
Sets the semi-minor axis.
static QgsEllipse fromExtent(const QgsPoint &pt1, const QgsPoint &pt2)
Constructs an ellipse by an extent (aka bounding box / QgsRectangle).
virtual double area() const
The area of the ellipse.
virtual void setSemiMajorAxis(double semiMajorAxis)
Sets the semi-major axis.
A class to represent a 2D point.
Definition qgspointxy.h:59
Point geometry type, with support for z-dimension and m-values.
Definition qgspoint.h:49
A rectangle specified with double values.
#define str(x)
Definition qgis.cpp:38
#define SIP_OUT
Definition qgis_sip.h:58
#define SIP_HOLDGIL
Definition qgis_sip.h:166
#define SIP_FACTORY
Definition qgis_sip.h:76
int precision