QGIS API Documentation
3.14.0-Pi (9f7028fd23)
|
Go to the documentation of this file.
35 for (
int iPart = 0, nParts = geom->
partCount(); iPart < nParts; ++iPart )
37 for (
int iRing = 0, nRings = geom->
ringCount( iPart ); iRing < nRings; ++iRing )
46 for (
int iVert = !closed; iVert < nVerts - !closed; ++iVert )
63 double angle = std::acos( v21 * v23 ) / M_PI * 180.0;
64 if (
angle < mMinAngle )
88 if ( !vidx.
isValid( geometry ) )
115 double angle = std::acos( v21 * v23 ) / M_PI * 180.0;
116 if (
angle >= mMinAngle )
131 error->
setFixFailed( tr(
"Resulting geometry is degenerate" ) );
160 static QStringList methods = QStringList() << tr(
"Delete node with small angle" ) << tr(
"No action" );
171 return tr(
"Minimal angle" );
196 return QStringLiteral(
"QgsGeometryAngleCheck" );
void setFixFailed(const QString &reason)
Set the error status to failed and specify the reason for failure.
Descripts a change to fix a geometry.
bool isValid() const
Returns true if the vertex id is valid.
static double sqrDistance2D(const QgsPoint &pt1, const QgsPoint &pt2)
Returns the squared 2D distance between two points.
void fixError(const QMap< QString, QgsFeaturePool * > &featurePools, QgsGeometryCheckError *error, int method, const QMap< QString, int > &mergeAttributeIndices, Changes &changes) const override
Fixes the error error with the specified method.
Point geometry type, with support for z-dimension and m-values.
QgsVector normalized() const
Returns the vector's normalized (or "unit") vector (ie same angle but length of 1....
void setObsolete()
Set the error status to obsolete.
QgsFeatureId featureId() const
The id of the feature on which this error has been detected.
QMap< QString, QMap< QgsFeatureId, QList< QgsGeometryCheck::Change > > > Changes
A collection of changes.
static int polyLineSize(const QgsAbstractGeometry *geom, int iPart, int iRing, bool *isClosed=nullptr)
Returns the number of points in a polyline, accounting for duplicate start and end point if the polyl...
QMap< QString, QgsFeatureIds > allLayerFeatureIds(const QMap< QString, QgsFeaturePool * > &featurePools) const
Returns all layers and feature ids.
@ FeatureNodeCheck
The check controls individual nodes.
const QgsGeometryCheckContext * context() const
Returns the context.
QString description() const override
Returns a human readable description for this check.
void collectErrors(const QMap< QString, QgsFeaturePool * > &featurePools, QList< QgsGeometryCheckError * > &errors, QStringList &messages, QgsFeedback *feedback, const LayerFeatureIds &ids=LayerFeatureIds()) const override
The main worker method.
virtual int partCount() const =0
Returns count of parts contained in the geometry.
Q_DECL_DEPRECATED QStringList resolutionMethods() const override
Returns a list of descriptions for available resolutions for errors.
bool getFeature(QgsFeatureId id, QgsFeature &feature)
Retrieves the feature with the specified id into feature.
QMap< QString, QgsFeatureIds > toMap() const
static QgsGeometryCheck::CheckType factoryCheckType()
virtual QgsPoint vertexAt(QgsVertexId id) const =0
Returns the point corresponding to a specified vertex id.
@ ChangeRemoved
Something has been removed.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
virtual void updateFeature(QgsFeature &feature)=0
Updates a feature in this pool.
void setFixed(int method)
Set the status to fixed and specify the method that has been used to fix the error.
@ ChangeNode
This change happens on node level.
virtual bool deleteVertex(QgsVertexId position)=0
Deletes a vertex within the geometry.
static QString factoryDescription()
A list of layers and feature ids for each of these layers.
const QgsVertexId & vidx() const
The id of the affected vertex.
Abstract base class for all geometries.
const QgsGeometryCheckContext * mContext
static bool canDeleteVertex(const QgsAbstractGeometry *geom, int iPart, int iRing)
QgsAbstractGeometry * get()
Returns a modifiable (non-const) reference to the underlying abstract geometry primitive.
static bool factoryIsCompatible(QgsVectorLayer *layer)
static QList< QgsWkbTypes::GeometryType > factoryCompatibleGeometryTypes()
CheckType
The type of a check.
static QString factoryId()
Utility class for identifying a unique vertex within a geometry.
const double tolerance
The tolerance to allow for in geometry checks.
QgsGeometryCheck::CheckType checkType() const override
Returns the check type.
QString id() const override
Returns an id for this check.
const QString & layerId() const
The id of the layer on which this error has been detected.
QList< QgsWkbTypes::GeometryType > compatibleGeometryTypes() const override
A list of geometry types for which this check can be performed.
Q_INVOKABLE QgsWkbTypes::GeometryType geometryType() const
Returns point, line or polygon.
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored)
virtual int ringCount(int part=0) const =0
Returns the number of rings of which this geometry is built.