44 bool fuzzyHelper(
const QgsAbstractGeometry &other,
double epsilon,
bool useDistance )
const
65 if ( !( *mExteriorRing ).fuzzyDistanceEqual( *otherPolygon->
mExteriorRing, epsilon ) )
70 if ( !( *mExteriorRing ).fuzzyEqual( *otherPolygon->
mExteriorRing, epsilon ) )
101 return fuzzyHelper( other, epsilon,
false );
105 return fuzzyHelper( other, epsilon,
true );
122 void clear() override;
125 bool fromWkt( const QString &wkt ) override;
129 QString asWkt(
int precision = 17 ) const override;
132 json asJsonObject(
int precision = 17 ) const override
SIP_SKIP;
133 QString asKml(
int precision = 17 ) const override;
146 QgsCurvePolygon *snappedToGrid(
double hSpacing,
double vSpacing,
double dSpacing = 0,
double mSpacing = 0,
bool removeRedundantPoints = false ) const override
SIP_FACTORY;
148 bool removeDuplicateNodes(
double epsilon = 4 * std::numeric_limits<
double>::epsilon(),
bool useZValues = false ) override;
156 double roundness() const;
238 if ( a0 < 0 || a0 >= sipCpp->numInteriorRings() )
240 PyErr_SetString( PyExc_IndexError, QByteArray::number( a0 ) );
245 return sipConvertFromType(
const_cast< QgsCurve *
>( sipCpp->interiorRing( a0 ) ), sipType_QgsCurve, NULL );
256 virtual QgsPolygon *toPolygon(
double tolerance = M_PI_2 / 90, SegmentationToleranceType toleranceType = MaximumAngle )
const SIP_FACTORY;
266 virtual void setExteriorRing( QgsCurve *ring
SIP_TRANSFER );
269 void setInteriorRings(
const QVector<QgsCurve *> &rings
SIP_TRANSFER );
271 virtual void addInteriorRing( QgsCurve *ring
SIP_TRANSFER );
281 bool removeInteriorRing(
int ringIndex );
293 bool removeInteriorRing(
int i );
295 if ( a0 < 0 || a0 >= sipCpp->numInteriorRings() )
297 PyErr_SetString( PyExc_IndexError, QByteArray::number( a0 ) );
302 return PyBool_FromLong( sipCpp->removeInteriorRing( a0 ) );
313 void removeInteriorRings(
double minimumAllowedArea = -1 );
321 void removeInvalidRings();
346 void forceClockwise();
356 void forceCounterClockwise();
359 void draw( QPainter &p )
const override;
361 void transform( const QTransform &t,
double zTranslate = 0.0,
double zScale = 1.0,
double mTranslate = 0.0,
double mScale = 1.0 ) override;
363 bool insertVertex( QgsVertexId position, const QgsPoint &vertex ) override;
364 bool moveVertex( QgsVertexId position, const QgsPoint &newPos ) override;
365 bool deleteVertex( QgsVertexId position ) override;
368 int nCoordinates() const override;
369 int vertexNumberFromVertexId( QgsVertexId
id ) const override;
371 double closestSegment( const QgsPoint &pt, QgsPoint &segmentPt
SIP_OUT, QgsVertexId &vertexAfter
SIP_OUT,
int *leftOf
SIP_OUT =
nullptr,
double epsilon = 4 * std::numeric_limits<
double>::epsilon() ) const override;
373 bool nextVertex( QgsVertexId &
id, QgsPoint &vertex
SIP_OUT ) const override;
374 void adjacentVertices( QgsVertexId vertex, QgsVertexId &previousVertex
SIP_OUT, QgsVertexId &nextVertex
SIP_OUT ) const override;
375 bool hasCurvedSegments() const override;
382 QgsAbstractGeometry *segmentize(
double tolerance = M_PI_2 / 90, SegmentationToleranceType toleranceType = MaximumAngle ) const override
SIP_FACTORY;
389 double vertexAngle( QgsVertexId vertex ) const override;
391 int vertexCount(
int part = 0,
int ring = 0 ) const override;
392 int ringCount(
int part = 0 ) const override
SIP_HOLDGIL;
394 QgsPoint vertexAt( QgsVertexId
id ) const override;
395 double segmentLength( QgsVertexId startVertex ) const override;
397 bool addZValue(
double zValue = 0 ) override;
398 bool addMValue(
double mValue = 0 ) override;
399 bool dropZValue() override;
400 bool dropMValue() override;
401 void swapXy() override;
403 QgsCurvePolygon *toCurveType() const override
SIP_FACTORY;
405 bool transform( QgsAbstractGeometryTransformer *transformer, QgsFeedback *feedback =
nullptr ) override;
408 void filterVertices(
const std::function<
bool(
const QgsPoint & ) > &filter )
override;
409 void transformVertices(
const std::function< QgsPoint(
const QgsPoint & ) > &transform )
override;
457 SIP_PYOBJECT __repr__();
459 QString wkt = sipCpp->asWkt();
460 if ( wkt.length() > 1000 )
461 wkt = wkt.left( 1000 ) + QStringLiteral(
"..." );
462 QString str = QStringLiteral(
"<QgsCurvePolygon: %1>" ).arg( wkt );
463 sipRes = PyUnicode_FromString( str.toUtf8().constData() );