24 QString QgsTransectAlgorithm::name()
const 26 return QStringLiteral(
"transect" );
29 QString QgsTransectAlgorithm::displayName()
const 31 return QObject::tr(
"Transect" );
34 QStringList QgsTransectAlgorithm::tags()
const 36 return QObject::tr(
"transect,station,lines,extend," ).split(
',' );
39 QString QgsTransectAlgorithm::group()
const 41 return QObject::tr(
"Vector geometry" );
44 QString QgsTransectAlgorithm::groupId()
const 46 return QStringLiteral(
"vectorgeometry" );
49 void QgsTransectAlgorithm::initAlgorithm(
const QVariantMap & )
53 std::unique_ptr< QgsProcessingParameterDistance > length = qgis::make_unique< QgsProcessingParameterDistance >( QStringLiteral(
"LENGTH" ), QObject::tr(
"Length of the transect" ),
54 5.0, QStringLiteral(
"INPUT" ),
false, 0 );
55 length->setIsDynamic(
true );
57 length->setDynamicLayerParameterName( QStringLiteral(
"INPUT" ) );
58 addParameter( length.release() );
60 std::unique_ptr< QgsProcessingParameterNumber >
angle = qgis::make_unique< QgsProcessingParameterNumber >( QStringLiteral(
"ANGLE" ), QObject::tr(
"Angle in degrees from the original line at the vertices" ),
QgsProcessingParameterNumber::Double,
61 90.0,
false, 0, 360 );
62 angle->setIsDynamic(
true );
64 angle->setDynamicLayerParameterName( QStringLiteral(
"INPUT" ) );
65 addParameter( angle.release() );
67 addParameter(
new QgsProcessingParameterEnum( QStringLiteral(
"SIDE" ), QObject::tr(
"Side to create the transects" ), QStringList() << QObject::tr(
"Left" ) << QObject::tr(
"Right" ) << QObject::tr(
"Both" ),
false ) );
72 QString QgsTransectAlgorithm::shortHelpString()
const 75 return QObject::tr(
"This algorithm creates transects on vertices for (multi)linestring.\n" ) +
76 QObject::tr(
"A transect is a line oriented from an angle (by default perpendicular) to the input polylines (at vertices)." ) +
77 QStringLiteral(
"\n\n" ) +
78 QObject::tr(
"Field(s) from feature(s) are returned in the transect with these new fields:\n" ) +
79 QObject::tr(
"- TR_FID: ID of the original feature\n" ) +
80 QObject::tr(
"- TR_ID: ID of the transect. Each transect have an unique ID\n" ) +
81 QObject::tr(
"- TR_SEGMENT: ID of the segment of the linestring\n" ) +
82 QObject::tr(
"- TR_ANGLE: Angle in degrees from the original line at the vertex\n" ) +
83 QObject::tr(
"- TR_LENGTH: Total length of the transect returned\n" ) +
84 QObject::tr(
"- TR_ORIENT: Side of the transect (only on the left or right of the line, or both side)\n" );
88 QgsTransectAlgorithm *QgsTransectAlgorithm::createInstance()
const 90 return new QgsTransectAlgorithm();
95 Side orientation =
static_cast< QgsTransectAlgorithm::Side
>( parameterAsInt( parameters, QStringLiteral(
"SIDE" ), context ) );
96 double angle = fabs( parameterAsDouble( parameters, QStringLiteral(
"ANGLE" ), context ) );
100 angleProperty = parameters.
value( QStringLiteral(
"ANGLE" ) ).value<
QgsProperty >();
102 double length = parameterAsDouble( parameters, QStringLiteral(
"LENGTH" ), context );
106 lengthProperty = parameters.
value( QStringLiteral(
"LENGTH" ) ).value<
QgsProperty >();
108 if ( orientation == QgsTransectAlgorithm::Both )
111 std::unique_ptr< QgsFeatureSource > source( parameterAsSource( parameters, QStringLiteral(
"INPUT" ), context ) );
115 QgsExpressionContext expressionContext = createExpressionContext( parameters, context, dynamic_cast< QgsProcessingFeatureSource * >( source.get() ) );
119 fields.
append(
QgsField( QStringLiteral(
"TR_FID" ), QVariant::Int, QString(), 20 ) );
120 fields.
append(
QgsField( QStringLiteral(
"TR_ID" ), QVariant::Int, QString(), 20 ) );
121 fields.
append(
QgsField( QStringLiteral(
"TR_SEGMENT" ), QVariant::Int, QString(), 20 ) );
122 fields.
append(
QgsField( QStringLiteral(
"TR_ANGLE" ), QVariant::Double, QString(), 5, 2 ) );
123 fields.
append(
QgsField( QStringLiteral(
"TR_LENGTH" ), QVariant::Double, QString(), 20, 6 ) );
124 fields.
append(
QgsField( QStringLiteral(
"TR_ORIENT" ), QVariant::Int, QString(), 1 ) );
133 std::unique_ptr< QgsFeatureSink > sink( parameterAsSink( parameters, QStringLiteral(
"OUTPUT" ), context, dest, fields,
142 double step = source->featureCount() > 0 ? 100.0 / source->featureCount() : 1;
160 if ( dynamicLength || dynamicAngle )
165 double evaluatedLength = length;
168 double evaluatedAngle =
angle;
184 attrs << current << number << i + 1 << evaluatedAngle <<
185 ( ( orientation == QgsTransectAlgorithm::Both ) ? evaluatedLength * 2 : evaluatedLength ) <<
188 double angleAtVertex = line->
vertexAngle( vertexId );
189 outFeat.
setGeometry( calcTransect( *it, angleAtVertex, evaluatedLength, orientation, evaluatedAngle ) );
198 outputs.insert( QStringLiteral(
"OUTPUT" ), dest );
203 QgsGeometry QgsTransectAlgorithm::calcTransect(
const QgsPoint &point,
const double angleAtVertex,
const double length,
const QgsTransectAlgorithm::Side orientation,
const double angle )
210 if ( ( orientation == QgsTransectAlgorithm::Right ) || ( orientation == QgsTransectAlgorithm::Both ) )
212 pLeft = point.
project( length, angle + 180.0 / M_PI * angleAtVertex );
213 if ( orientation != QgsTransectAlgorithm::Both )
217 if ( ( orientation == QgsTransectAlgorithm::Left ) || ( orientation == QgsTransectAlgorithm::Both ) )
219 pRight = point.
project( -length, angle + 180.0 / M_PI * angleAtVertex );
220 if ( orientation != QgsTransectAlgorithm::Both )
224 line.append( pLeft );
225 line.append( pRight );
Wrapper for iterator of features from vector data provider or vector layer.
bool isCanceled() const
Tells whether the operation has been canceled already.
Use faster inserts, at the cost of updating the passed features to reflect changes made at the provid...
Base class for providing feedback from a processing algorithm.
static QgsGeometry fromPolyline(const QgsPolyline &polyline)
Creates a new LineString geometry from a list of QgsPoint points.
void setFeature(const QgsFeature &feature)
Convenience function for setting a feature for the context.
QVector< QgsPoint > QgsPolyline
Polyline as represented as a vector of points.
void setProgress(double progress)
Sets the current progress for the feedback object.
Multi line string geometry collection.
Container of fields for a vector layer.
A geometry is the spatial representation of a feature.
void setAttributes(const QgsAttributes &attrs)
Sets the feature's attributes.
const QgsAbstractGeometry * geometryN(int n) const
Returns a const reference to a geometry from within the collection.
The feature class encapsulates a single feature including its id, geometry and a list of field/values...
Positive double value (including 0)
vertex_iterator vertices_begin() const
Returns STL-style iterator pointing to the first vertex of the geometry.
static bool hasZ(Type type)
Tests whether a WKB type contains the z-dimension.
double ANALYSIS_EXPORT angle(QgsPoint *p1, QgsPoint *p2, QgsPoint *p3, QgsPoint *p4)
Calculates the angle between two segments (in 2 dimension, z-values are ignored)
A feature sink output for processing algorithms.
This flag indicates, that a primary key field cannot be guaranteed to be unique and the sink should i...
const QgsAbstractGeometry * constGet() const
Returns a non-modifiable (const) reference to the underlying abstract geometry primitive.
Type
The WKB type describes the number of dimensions a geometry has.
vertex_iterator vertices_end() const
Returns STL-style iterator pointing to the imaginary vertex after the last vertex of the geometry...
static Type addM(Type type)
Adds the m dimension to a WKB type and returns the new type.
An enum based parameter for processing algorithms, allowing for selection from predefined values...
Utility class for identifying a unique vertex within a geometry.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
static Type addZ(Type type)
Adds the z dimension to a WKB type and returns the new type.
Custom exception class for processing related exceptions.
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) ...
double valueAsDouble(const QgsExpressionContext &context, double defaultValue=0.0, bool *ok=nullptr) const
Calculates the current value of the property and interprets it as a double.
Encapsulate a field in an attribute table or data source.
int numGeometries() const
Returns the number of geometries within the collection.
The vertex_iterator class provides STL-style iterator for vertices.
A store for object properties.
Point geometry type, with support for z-dimension and m-values.
Double value (including negative values)
QgsExpressionContext & expressionContext()
Returns the expression context.
Definition for a property.
QVariant value(const QgsExpressionContext &context, const QVariant &defaultValue=QVariant(), bool *ok=nullptr) const
Calculates the current value of the property, including any transforms which are set for the property...
bool convertToMultiType()
Converts single type geometry into multitype geometry e.g.
An input feature source (such as vector layers) parameter for processing algorithms.
double vertexAngle(QgsVertexId vertex) const override
Returns approximate angle at a vertex.
Line string geometry type, with support for z-dimension and m-values.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
bool hasGeometry() const
Returns true if the feature has an associated geometry.
static bool hasM(Type type)
Tests whether a WKB type contains m values.
bool nextFeature(QgsFeature &f)
Contains information about the context in which a processing algorithm is executed.
QgsPoint project(double distance, double azimuth, double inclination=90.0) const
Returns a new point which correspond to this point projected by a specified distance with specified a...
QgsVertexId vertexId() const
Returns vertex ID of the current item.
static bool isDynamic(const QVariantMap ¶meters, const QString &name)
Returns true if the parameter with matching name is a dynamic parameter, and must be evaluated once f...