18 #ifndef QGS_GEOMETRY_AREA_CHECK_H 19 #define QGS_GEOMETRY_AREA_CHECK_H 31 enum ResolutionMethod { MergeLongestEdge, MergeLargestArea, MergeIdenticalAttribute, Delete, NoChange };
35 , mAreaThreshold( configurationValue<double>(
"areaThreshold" ) )
39 void fixError(
const QMap<QString, QgsFeaturePool *> &featurePools,
QgsGeometryCheckError *error,
int method,
const QMap<QString, int> &mergeAttributeIndices,
Changes &changes )
const override;
41 QString
id()
const override {
return factoryId(); }
47 QString
description()
const override {
return factoryDescription(); }
48 static QString
factoryId() {
return QStringLiteral(
"QgsGeometryAreaCheck" ); }
52 virtual bool checkThreshold(
double layerToMapUnits,
const QgsAbstractGeometry *geom,
double &value )
const;
53 bool mergeWithNeighbor(
const QMap<QString, QgsFeaturePool *> &featurePools,
const QString &layerId,
QgsFeature &feature,
int partIdx,
int method,
int mergeAttributeIndex,
Changes &changes, QString &errMsg )
const;
55 const double mAreaThreshold;
58 #endif // QGS_GEOMETRY_AREA_CHECK_H QList< QgsWkbTypes::GeometryType > compatibleGeometryTypes() const override
A list of geometry types for which this check can be performed.
static QString factoryDescription()
QgsGeometryCheck::CheckType checkType() const override
Returns the check type.
static QList< QgsWkbTypes::GeometryType > factoryCompatibleGeometryTypes()
CheckType
The type of a check.
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
Base class for feedback objects to be used for cancellation of something running in a worker thread...
Base configuration for geometry checks.
The check controls geometries as a whole.
static bool factoryIsCompatible(QgsVectorLayer *layer)
This class implements a geometry check.
Abstract base class for all geometries.
static QgsGeometryCheck::CheckType factoryCheckType()
A list of layers and feature ids for each of these layers.
QString id() const override
Returns an id for this check.
QMap< QString, QMap< QgsFeatureId, QList< QgsGeometryCheck::Change > > > Changes
A collection of changes.
virtual void fixError(const QMap< QString, QgsFeaturePool *> &featurePools, QgsGeometryCheckError *error, int method, const QMap< QString, int > &mergeAttributeIndices, Changes &changes) const
Fix the error error with the specified method.
virtual QStringList resolutionMethods() const =0
Returns a list of descriptions for available resolutions for errors.
This represents an error reported by 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.
Represents a vector layer which manages a vector based data sets.
QgsGeometryAreaCheck(QgsGeometryCheckContext *context, const QVariantMap &configuration)
QString description() const override
Returns a human readable description for this check.
static QString factoryId()