18#ifndef QGS_GEOMETRY_AREA_CHECK_H
19#define QGS_GEOMETRY_AREA_CHECK_H
44 , mAreaThreshold( configurationValue<double>(
"areaThreshold" ) )
47 void collectErrors(
const QMap<QString, QgsFeaturePool *> &featurePools, QList<QgsGeometryCheckError *> &errors, QStringList &messages,
QgsFeedback *feedback,
const LayerFeatureIds &ids = LayerFeatureIds() )
const override;
48 void fixError(
const QMap<QString, QgsFeaturePool *> &featurePools,
QgsGeometryCheckError *error,
int method,
const QMap<QString, int> &mergeAttributeIndices, Changes &changes )
const override;
50 QString
id()
const override {
return factoryId(); }
55 QString
description()
const override {
return factoryDescription(); }
59 static QString factoryId() {
return QStringLiteral(
"QgsGeometryAreaCheck" ); }
60 static QString factoryDescription() {
return tr(
"Minimal area" ); }
61 virtual bool checkThreshold(
double layerToMapUnits,
const QgsAbstractGeometry *geom,
double &value )
const;
62 bool mergeWithNeighbor(
const QMap<QString, QgsFeaturePool *> &featurePools,
const QString &layerId,
QgsFeature &feature,
int partIdx,
int method,
int mergeAttributeIndex, Changes &changes, QString &errMsg )
const;
64 const double mAreaThreshold;
Abstract base class for all geometries.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Base class for feedback objects to be used for cancellation of something running in a worker thread.
@ MergeIdenticalAttribute
QList< Qgis::GeometryType > compatibleGeometryTypes() const override
A list of geometry types for which this check can be performed.
QgsGeometryAreaCheck(QgsGeometryCheckContext *context, const QVariantMap &configuration)
static QList< Qgis::GeometryType > factoryCompatibleGeometryTypes()
static bool factoryIsCompatible(QgsVectorLayer *layer)
QString description() const override
Returns a human readable description for this check.
static QgsGeometryCheck::CheckType factoryCheckType()
QString id() const override
Returns an id for this check.
QgsGeometryCheck::CheckType checkType() const override
Returns the check type.
Base configuration for geometry checks.
This represents an error reported by a geometry check.
This class implements a geometry check.
virtual void collectErrors(const QMap< QString, QgsFeaturePool * > &featurePools, QList< QgsGeometryCheckError * > &errors, QStringList &messages, QgsFeedback *feedback, const LayerFeatureIds &ids=QgsGeometryCheck::LayerFeatureIds()) const =0
The main worker method.
virtual Q_DECL_DEPRECATED QStringList resolutionMethods() const
Returns a list of descriptions for available resolutions for errors.
CheckType
The type of a check.
@ FeatureCheck
The check controls geometries as a whole.
virtual void fixError(const QMap< QString, QgsFeaturePool * > &featurePools, QgsGeometryCheckError *error, int method, const QMap< QString, int > &mergeAttributeIndices, Changes &changes) const
Fixes the error error with the specified method.
Represents a vector layer which manages a vector based data sets.