QGIS API Documentation 3.99.0-Master (09f76ad7019)
Loading...
Searching...
No Matches
qgsalgorithmconcavehullbyfeature.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsalgorithmconcavehullbyfeature.cpp
3 ---------------------
4 begin : May 2025
5 copyright : (C) 2025 by Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
19
21
22#include <QString>
23
24using namespace Qt::StringLiterals;
25
27
28QString QgsConcaveHullByFeatureAlgorithm::name() const
29{
30 return u"concavehullbyfeature"_s;
31}
32
33QString QgsConcaveHullByFeatureAlgorithm::displayName() const
34{
35 return QObject::tr( "Concave hull (by feature)" );
36}
37
38QStringList QgsConcaveHullByFeatureAlgorithm::tags() const
39{
40 return QObject::tr( "concave,hull,bounds,bounding,convex" ).split( ',' );
41}
42
43QString QgsConcaveHullByFeatureAlgorithm::group() const
44{
45 return QObject::tr( "Vector geometry" );
46}
47
48QString QgsConcaveHullByFeatureAlgorithm::groupId() const
49{
50 return u"vectorgeometry"_s;
51}
52
53QString QgsConcaveHullByFeatureAlgorithm::outputName() const
54{
55 return QObject::tr( "Concave hulls" );
56}
57
58QString QgsConcaveHullByFeatureAlgorithm::shortHelpString() const
59{
60 return QObject::tr( "This algorithm calculates the concave hull for each feature in an input layer." ) + u"\n\n"_s
61 + QObject::tr( "A concave hull is a polygon which contains all the points of the input geometries, but is a better approximation than the convex hull to the area occupied by the input." ) + u"\n\n"_s
62 + QObject::tr( "It is frequently used to convert a multi-point into a polygonal area which contains all the points from the input geometry." ) + u"\n\n"_s
63 + QObject::tr( "See the 'Concave hull (by layer)' algorithm for a concave hull calculation which covers the whole layer or grouped subsets of features." );
64}
65
66QString QgsConcaveHullByFeatureAlgorithm::shortDescription() const
67{
68 return QObject::tr( "Calculates the concave hull for each feature in an input layer." );
69}
70
71QgsConcaveHullByFeatureAlgorithm *QgsConcaveHullByFeatureAlgorithm::createInstance() const
72{
73 return new QgsConcaveHullByFeatureAlgorithm();
74}
75
76void QgsConcaveHullByFeatureAlgorithm::initParameters( const QVariantMap & )
77{
78 addParameter( new QgsProcessingParameterNumber( u"ALPHA"_s, QObject::tr( "Threshold (0-1, where 1 is equivalent with Convex Hull)" ), Qgis::ProcessingNumberParameterType::Double, 0.3, false, 0, 1 ) );
79 addParameter( new QgsProcessingParameterBoolean( u"HOLES"_s, QObject::tr( "Allow holes" ), true ) );
80}
81
82QList<int> QgsConcaveHullByFeatureAlgorithm::inputLayerTypes() const
83{
84 return QList<int>() << static_cast<int>( Qgis::ProcessingSourceType::VectorPoint );
85}
86
87QgsFields QgsConcaveHullByFeatureAlgorithm::outputFields( const QgsFields &inputFields ) const
88{
89 QgsFields newFields;
90 newFields.append( QgsField( u"area"_s, QMetaType::Type::Double, QString(), 20, 6 ) );
91 newFields.append( QgsField( u"perimeter"_s, QMetaType::Type::Double, QString(), 20, 6 ) );
92 return QgsProcessingUtils::combineFields( inputFields, newFields );
93}
94
95bool QgsConcaveHullByFeatureAlgorithm::prepareAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback * )
96{
97#if GEOS_VERSION_MAJOR == 3 && GEOS_VERSION_MINOR < 11
98 throw QgsProcessingException( QObject::tr( "This algorithm requires a QGIS build based on GEOS 3.11 or later" ) );
99#endif
100 mPercentage = parameterAsDouble( parameters, u"ALPHA"_s, context );
101 mAllowHoles = parameterAsBool( parameters, u"HOLES"_s, context );
102 return true;
103}
104
105QgsFeatureList QgsConcaveHullByFeatureAlgorithm::processFeature( const QgsFeature &feature, QgsProcessingContext &, QgsProcessingFeedback *feedback )
106{
107 QgsFeature f = feature;
108 if ( f.hasGeometry() )
109 {
110 QgsGeometry outputGeometry;
111 const QgsAbstractGeometry *inputGeometry = f.geometry().constGet();
113 if ( !collection || collection->numGeometries() == 1 )
114 {
115 feedback->reportError( QObject::tr( "Cannot calculate convex hull for a single point feature (%1) (try 'Concave hull (by layer)' algorithm instead)." ).arg( f.id() ) );
116 f.clearGeometry();
117 }
118 else
119 {
120 outputGeometry = f.geometry().concaveHull( mPercentage, mAllowHoles );
121 if ( outputGeometry.isNull() && !outputGeometry.lastError().isEmpty() )
122 feedback->reportError( outputGeometry.lastError() );
123 f.setGeometry( outputGeometry );
124 }
125 if ( outputGeometry.type() == Qgis::GeometryType::Polygon )
126 {
127 QgsAttributes attrs = f.attributes();
128 attrs << outputGeometry.constGet()->area()
129 << outputGeometry.constGet()->perimeter();
130 f.setAttributes( attrs );
131 }
132 else
133 {
134 if ( outputGeometry.type() == Qgis::GeometryType::Line )
135 {
136 feedback->pushWarning( QObject::tr( "Concave hull for feature %1 resulted in a linestring, ignoring" ).arg( f.id() ) );
137 }
138 else if ( outputGeometry.type() == Qgis::GeometryType::Point )
139 {
140 feedback->pushWarning( QObject::tr( "Concave hull for feature %1 resulted in a point, ignoring" ).arg( f.id() ) );
141 }
142 QgsAttributes attrs = f.attributes();
143 attrs << QVariant()
144 << QVariant();
145 f.setAttributes( attrs );
146 }
147 }
148 return QgsFeatureList() << f;
149}
150
@ VectorPoint
Vector point layers.
Definition qgis.h:3605
@ Point
Points.
Definition qgis.h:366
@ Line
Lines.
Definition qgis.h:367
@ Polygon
Polygons.
Definition qgis.h:368
@ Double
Double/float values.
Definition qgis.h:3875
Abstract base class for all geometries.
virtual double perimeter() const
Returns the planar, 2-dimensional perimeter of the geometry.
virtual double area() const
Returns the planar, 2-dimensional area of the geometry.
A vector of attributes.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Definition qgsfeature.h:60
QgsAttributes attributes
Definition qgsfeature.h:69
QgsFeatureId id
Definition qgsfeature.h:68
void setAttributes(const QgsAttributes &attrs)
Sets the feature's attributes.
QgsGeometry geometry
Definition qgsfeature.h:71
void clearGeometry()
Removes any geometry associated with the feature.
bool hasGeometry() const
Returns true if the feature has an associated geometry.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
Encapsulate a field in an attribute table or data source.
Definition qgsfield.h:56
Container of fields for a vector layer.
Definition qgsfields.h:46
bool append(const QgsField &field, Qgis::FieldOrigin origin=Qgis::FieldOrigin::Provider, int originIndex=-1)
Appends a field.
Definition qgsfields.cpp:76
int numGeometries() const
Returns the number of geometries within the collection.
A geometry is the spatial representation of a feature.
QString lastError() const
Returns an error string referring to the last error encountered either when this geometry was created...
const QgsAbstractGeometry * constGet() const
Returns a non-modifiable (const) reference to the underlying abstract geometry primitive.
Qgis::GeometryType type
QgsGeometry concaveHull(double targetPercent, bool allowHoles=false) const
Returns a possibly concave polygon that contains all the points in the geometry.
Contains information about the context in which a processing algorithm is executed.
Custom exception class for processing related exceptions.
Base class for providing feedback from a processing algorithm.
virtual void pushWarning(const QString &warning)
Pushes a warning informational message from the algorithm.
virtual void reportError(const QString &error, bool fatalError=false)
Reports that the algorithm encountered an error while executing.
A boolean parameter for processing algorithms.
A numeric parameter for processing algorithms.
static QgsFields combineFields(const QgsFields &fieldsA, const QgsFields &fieldsB, const QString &fieldsBPrefix=QString())
Combines two field lists, avoiding duplicate field names (in a case-insensitive manner).
T qgsgeometry_cast(QgsAbstractGeometry *geom)
QList< QgsFeature > QgsFeatureList