23QString QgsDensifyGeometriesByIntervalAlgorithm::name()
const
25 return QStringLiteral(
"densifygeometriesgivenaninterval" );
28QString QgsDensifyGeometriesByIntervalAlgorithm::displayName()
const
30 return QObject::tr(
"Densify by interval" );
33QStringList QgsDensifyGeometriesByIntervalAlgorithm::tags()
const
35 return QObject::tr(
"add,vertex,vertices,points,nodes" ).split(
',' );
38QString QgsDensifyGeometriesByIntervalAlgorithm::group()
const
40 return QObject::tr(
"Vector geometry" );
43QString QgsDensifyGeometriesByIntervalAlgorithm::groupId()
const
45 return QStringLiteral(
"vectorgeometry" );
48QString QgsDensifyGeometriesByIntervalAlgorithm::shortHelpString()
const
50 return QObject::tr(
"Geometries are densified by adding additional vertices on "
51 "edges that have a maximum distance of the interval parameter "
55QString QgsDensifyGeometriesByIntervalAlgorithm::shortDescription()
const
57 return QObject::tr(
"Creates a densified version of geometries." );
60QgsDensifyGeometriesByIntervalAlgorithm *QgsDensifyGeometriesByIntervalAlgorithm::createInstance()
const
62 return new QgsDensifyGeometriesByIntervalAlgorithm;
65QList<int> QgsDensifyGeometriesByIntervalAlgorithm::inputLayerTypes()
const
70void QgsDensifyGeometriesByIntervalAlgorithm::initParameters(
const QVariantMap &configuration )
72 Q_UNUSED( configuration )
73 std::unique_ptr<QgsProcessingParameterDistance> interval = std::make_unique<QgsProcessingParameterDistance>( QStringLiteral(
"INTERVAL" ), QObject::tr(
"Interval between vertices to add" ), 1, QStringLiteral(
"INPUT" ),
false, 0, 10000000 );
74 interval->setIsDynamic(
true );
76 interval->setDynamicLayerParameterName( QStringLiteral(
"INPUT" ) );
77 addParameter( interval.release() );
80QString QgsDensifyGeometriesByIntervalAlgorithm::outputName()
const
82 return QObject::tr(
"Densified" );
91 double interval = mInterval;
92 if ( mDynamicInterval )
93 interval = mIntervalProperty.valueAsDouble( context.
expressionContext(), interval );
104 mInterval = parameterAsDouble( parameters, QStringLiteral(
"INTERVAL" ), context );
107 if ( mDynamicInterval )
108 mIntervalProperty = parameters.value( QStringLiteral(
"INTERVAL" ) ).value<
QgsProperty>();
@ VectorPolygon
Vector polygon layers.
@ VectorLine
Vector line layers.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
bool hasGeometry() const
Returns true if the feature has an associated geometry.
void setGeometry(const QgsGeometry &geometry)
Set the feature's geometry.
QgsGeometry densifyByDistance(double distance) const
Densifies the geometry by adding regularly placed extra nodes inside each segment so that the maximum...
Contains information about the context in which a processing algorithm is executed.
QgsExpressionContext & expressionContext()
Returns the expression context.
Base class for providing feedback from a processing algorithm.
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...
Definition for a property.
@ DoublePositive
Positive double value (including 0)
A store for object properties.
QList< QgsFeature > QgsFeatureList