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" ) )
38 void collectErrors(
const QMap<QString, QgsFeaturePool *> &featurePools, QList<QgsGeometryCheckError *> &errors, QStringList &messages,
QgsFeedback *feedback,
const LayerFeatureIds &ids = LayerFeatureIds() )
const override;
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