QGIS API Documentation 3.37.0-Master (fdefdf9c27f)
qgsalgorithmpointtolayer.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsalgorithmpointtolayer.cpp
3 ---------------------
4 begin : May 2019
5 copyright : (C) 2017 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
22QString QgsPointToLayerAlgorithm::name() const
23{
24 return QStringLiteral( "pointtolayer" );
25}
26
27void QgsPointToLayerAlgorithm::initAlgorithm( const QVariantMap & )
28{
29 addParameter( new QgsProcessingParameterPoint( QStringLiteral( "INPUT" ), QObject::tr( "Point" ) ) );
30 addParameter( new QgsProcessingParameterFeatureSink( QStringLiteral( "OUTPUT" ), QObject::tr( "Point" ), Qgis::ProcessingSourceType::VectorPoint ) );
31}
32
33QString QgsPointToLayerAlgorithm::shortHelpString() const
34{
35 return QObject::tr( "This algorithm creates a new vector layer that contains a single feature with geometry matching a point parameter.\n\n"
36 "It can be used in models to convert a point into a layer which can be used for other algorithms which require "
37 "a layer based input." );
38}
39
40QgsPointToLayerAlgorithm *QgsPointToLayerAlgorithm::createInstance() const
41{
42 return new QgsPointToLayerAlgorithm();
43}
44
45QVariantMap QgsPointToLayerAlgorithm::processAlgorithm( const QVariantMap &parameters, QgsProcessingContext &context, QgsProcessingFeedback *feedback )
46{
47 const QgsCoordinateReferenceSystem crs = parameterAsPointCrs( parameters, QStringLiteral( "INPUT" ), context );
48 const QgsGeometry geom = QgsGeometry::fromPointXY( parameterAsPoint( parameters, QStringLiteral( "INPUT" ), context ) );
49
50 QgsFields fields;
51 fields.append( QgsField( QStringLiteral( "id" ), QVariant::Int ) );
52
53 QString dest;
54 std::unique_ptr< QgsFeatureSink > sink( parameterAsSink( parameters, QStringLiteral( "OUTPUT" ), context, dest, fields, Qgis::WkbType::Point, crs ) );
55 if ( !sink )
56 throw QgsProcessingException( invalidSinkError( parameters, QStringLiteral( "OUTPUT" ) ) );
57
58 QgsFeature f;
59 f.setAttributes( QgsAttributes() << 1 );
60 f.setGeometry( geom );
61 if ( !sink->addFeature( f, QgsFeatureSink::FastInsert ) )
62 throw QgsProcessingException( writeFeatureError( sink.get(), parameters, QStringLiteral( "OUTPUT" ) ) );
63
64 feedback->setProgress( 100 );
65
66 QVariantMap outputs;
67 outputs.insert( QStringLiteral( "OUTPUT" ), dest );
68 return outputs;
69}
70
72
@ VectorPoint
Vector point layers.
A vector of attributes.
Definition: qgsattributes.h:59
This class represents a coordinate reference system (CRS).
@ FastInsert
Use faster inserts, at the cost of updating the passed features to reflect changes made at the provid...
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Definition: qgsfeature.h:56
void setAttributes(const QgsAttributes &attrs)
Sets the feature's attributes.
Definition: qgsfeature.cpp:160
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
Definition: qgsfeature.cpp:167
void setProgress(double progress)
Sets the current progress for the feedback object.
Definition: qgsfeedback.h:61
Encapsulate a field in an attribute table or data source.
Definition: qgsfield.h:53
Container of fields for a vector layer.
Definition: qgsfields.h:45
bool append(const QgsField &field, FieldOrigin origin=OriginProvider, int originIndex=-1)
Appends a field. The field must have unique name, otherwise it is rejected (returns false)
Definition: qgsfields.cpp:59
A geometry is the spatial representation of a feature.
Definition: qgsgeometry.h:162
static QgsGeometry fromPointXY(const QgsPointXY &point)
Creates a new geometry from a QgsPointXY object.
Contains information about the context in which a processing algorithm is executed.
Custom exception class for processing related exceptions.
Definition: qgsexception.h:83
Base class for providing feedback from a processing algorithm.
A feature sink output for processing algorithms.
A point parameter for processing algorithms.
const QgsCoordinateReferenceSystem & crs