24using namespace Qt::StringLiterals;
28QString QgsSingleSidedBufferAlgorithm::name()
const
30 return u
"singlesidedbuffer"_s;
33QString QgsSingleSidedBufferAlgorithm::displayName()
const
35 return QObject::tr(
"Single sided buffer" );
38QStringList QgsSingleSidedBufferAlgorithm::tags()
const
40 return QObject::tr(
"rectangle,perpendicular,right,angles,square,quadrilateralise" ).split(
',' );
43QString QgsSingleSidedBufferAlgorithm::group()
const
45 return QObject::tr(
"Vector geometry" );
48QString QgsSingleSidedBufferAlgorithm::groupId()
const
50 return u
"vectorgeometry"_s;
53QString QgsSingleSidedBufferAlgorithm::shortHelpString()
const
55 return QObject::tr(
"This algorithm buffers lines by a specified distance on one "
56 "side of the line only.\n\nThe segments parameter controls "
57 "the number of line segments to use to approximate a quarter "
58 "circle when creating rounded buffers. The join style parameter "
59 "specifies whether round, miter or beveled joins should be used "
60 "when buffering corners in a line. The miter limit parameter is "
61 "only applicable for miter join styles, and controls the maximum "
62 "distance from the buffer to use when creating a mitered join." );
65QString QgsSingleSidedBufferAlgorithm::shortDescription()
const
67 return QObject::tr(
"Buffers lines by a specified distance on one side of the line only." );
70QString QgsSingleSidedBufferAlgorithm::outputName()
const
72 return QObject::tr(
"Buffered" );
75QList<int> QgsSingleSidedBufferAlgorithm::inputLayerTypes()
const
91QgsSingleSidedBufferAlgorithm *QgsSingleSidedBufferAlgorithm::createInstance()
const
93 return new QgsSingleSidedBufferAlgorithm();
96void QgsSingleSidedBufferAlgorithm::initParameters(
const QVariantMap & )
98 auto bufferParam = std::make_unique<QgsProcessingParameterDistance>( u
"DISTANCE"_s, QObject::tr(
"Distance" ), 10, u
"INPUT"_s );
99 bufferParam->setIsDynamic(
true );
101 bufferParam->setDynamicLayerParameterName( u
"INPUT"_s );
102 addParameter( bufferParam.release() );
104 addParameter(
new QgsProcessingParameterEnum( u
"SIDE"_s, QObject::tr(
"Side" ), QStringList() << QObject::tr(
"Left" ) << QObject::tr(
"Right" ),
false, 0 ) );
106 addParameter(
new QgsProcessingParameterEnum( u
"JOIN_STYLE"_s, QObject::tr(
"Join style" ), QStringList() << QObject::tr(
"Round" ) << QObject::tr(
"Miter" ) << QObject::tr(
"Bevel" ),
false, 0 ) );
112 mDistance = parameterAsDouble( parameters, u
"DISTANCE"_s, context );
114 if ( mDynamicDistance )
115 mDistanceProperty = parameters.value( u
"DISTANCE"_s ).value<
QgsProperty>();
117 mSide =
static_cast<Qgis::BufferSide>( parameterAsInt( parameters, u
"SIDE"_s, context ) );
118 mSegments = parameterAsInt( parameters, u
"SEGMENTS"_s, context );
119 mJoinStyle =
static_cast<Qgis::JoinStyle>( 1 + parameterAsInt( parameters, u
"JOIN_STYLE"_s, context ) );
120 mMiterLimit = parameterAsDouble( parameters, u
"MITER_LIMIT"_s, context );
131 double distance = mDistance;
132 if ( mDynamicDistance )
133 distance = mDistanceProperty.valueAsDouble( context.
expressionContext(), distance );
136 if ( outputGeometry.
isNull() )
ProcessingSourceType
Processing data source types.
@ VectorPolygon
Vector polygon layers.
@ VectorLine
Vector line layers.
BufferSide
Side of line to buffer.
JoinStyle
Join styles for buffers.
WkbType
The WKB type describes the number of dimensions a geometry has.
@ Double
Double/float values.
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.
A geometry is the spatial representation of a feature.
QgsGeometry singleSidedBuffer(double distance, int segments, Qgis::BufferSide side, Qgis::JoinStyle joinStyle=Qgis::JoinStyle::Round, double miterLimit=2.0) const
Returns a single sided buffer for a (multi)line geometry.
Contains information about the context in which a processing algorithm is executed.
QgsExpressionContext & expressionContext()
Returns the expression context.
Custom exception class for processing related exceptions.
Base class for providing feedback from a processing algorithm.
An enum based parameter for processing algorithms, allowing for selection from predefined values.
A numeric parameter for processing algorithms.
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.
@ Double
Double value (including negative values).
A store for object properties.
QList< QgsFeature > QgsFeatureList