QGIS API Documentation 3.99.0-Master (d270888f95f)
Loading...
Searching...
No Matches
qgsgeometryfollowboundariescheck.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsgeometryfollowboundariescheck.h
3 ---------------------
4 begin : September 2017
5 copyright : (C) 2017 by Sandro Mani / Sourcepole AG
6 email : smani at sourcepole dot ch
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#define SIP_NO_FILE
17
18#ifndef QGSGEOMETRYFOLLOWBOUNDARIESCHECK_H
19#define QGSGEOMETRYFOLLOWBOUNDARIESCHECK_H
20
21#include "qgsgeometrycheck.h"
22
23#include <QString>
24
25using namespace Qt::StringLiterals;
26
27class QgsSpatialIndex;
28
29
35{
36 Q_DECLARE_TR_FUNCTIONS( QgsGeometryFollowBoundariesCheck )
37 public:
38 QgsGeometryFollowBoundariesCheck( QgsGeometryCheckContext *context, const QVariantMap &configuration, QgsVectorLayer *checkLayer );
40 static QList<Qgis::GeometryType> factoryCompatibleGeometryTypes() { return { Qgis::GeometryType::Polygon }; }
41 static bool factoryIsCompatible( QgsVectorLayer *layer ) SIP_SKIP { return factoryCompatibleGeometryTypes().contains( layer->geometryType() ); }
42 QList<Qgis::GeometryType> compatibleGeometryTypes() const override { return factoryCompatibleGeometryTypes(); }
43 QgsGeometryCheck::Result collectErrors( const QMap<QString, QgsFeaturePool *> &featurePools, QList<QgsGeometryCheckError *> &errors, QStringList &messages, QgsFeedback *feedback, const LayerFeatureIds &ids = LayerFeatureIds() ) const override;
44 void fixError( const QMap<QString, QgsFeaturePool *> &featurePools, QgsGeometryCheckError *error, int method, const QMap<QString, int> &mergeAttributeIndices, Changes &changes ) const override;
45 Q_DECL_DEPRECATED QStringList resolutionMethods() const override;
46 static QString factoryDescription() { return tr( "Polygon does not follow boundaries" ); }
47 QString description() const override { return factoryDescription(); }
48 static QString factoryId() { return u"QgsGeometryFollowBoundariesCheck"_s; }
49 QString id() const override { return factoryId(); }
51 static QgsGeometryCheck::CheckType factoryCheckType() SIP_SKIP;
52
53 private:
54 enum ResolutionMethod
55 {
56 NoChange
57 };
58 QgsVectorLayer *mCheckLayer;
59 QgsSpatialIndex *mIndex = nullptr;
60
61 QgsGeometryFollowBoundariesCheck( const QgsGeometryFollowBoundariesCheck & ) = delete;
62 QgsGeometryFollowBoundariesCheck &operator=( const QgsGeometryFollowBoundariesCheck & ) = delete;
63};
64
65#endif // QGSGEOMETRYFOLLOWBOUNDARIESCHECK_H
@ Polygon
Polygons.
Definition qgis.h:368
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
Base configuration for geometry checks.
This represents an error reported by a geometry check.
virtual Q_DECL_DEPRECATED QStringList resolutionMethods() const
Returns a list of descriptions for available resolutions for errors.
CheckType
The type of a check.
Result
Result of the geometry checker operation.
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.
QgsGeometryCheck(const QgsGeometryCheckContext *context, const QVariantMap &configuration)
Create a new geometry check.
const QgsGeometryCheckContext * context() const
Returns the context.
virtual Result collectErrors(const QMap< QString, QgsFeaturePool * > &featurePools, QList< QgsGeometryCheckError * > &errors, QStringList &messages, QgsFeedback *feedback, const LayerFeatureIds &ids=QgsGeometryCheck::LayerFeatureIds()) const
The main worker method.
static QList< Qgis::GeometryType > factoryCompatibleGeometryTypes()
static QgsGeometryCheck::CheckType factoryCheckType()
QgsGeometryCheck::CheckType checkType() const override
Returns the check type.
QList< Qgis::GeometryType > compatibleGeometryTypes() const override
A list of geometry types for which this check can be performed.
static bool factoryIsCompatible(QgsVectorLayer *layer)
QString id() const override
Returns an id for this check.
QgsGeometryFollowBoundariesCheck(QgsGeometryCheckContext *context, const QVariantMap &configuration, QgsVectorLayer *checkLayer)
QString description() const override
Returns a human readable description for this check.
A spatial index for QgsFeature objects.
Represents a vector layer which manages a vector based dataset.
#define SIP_SKIP
Definition qgis_sip.h:134