|
QGIS API Documentation 3.99.0-Master (2fe06baccd8)
|
Line symbol layer used for decorating according to linear referencing. More...
#include <qgslinearreferencingsymbollayer.h>

Public Member Functions | |
| QgsLinearReferencingSymbolLayer () | |
| ~QgsLinearReferencingSymbolLayer () override | |
| double | averageAngleLength () const |
| Returns the length of line over which the line's direction is averaged when calculating individual label angles. | |
| const QgsMapUnitScale & | averageAngleMapUnitScale () const |
| Returns the map unit scale for the length over which the line's direction is averaged when calculating individual label angles. | |
| Qgis::RenderUnit | averageAngleUnit () const |
| Returns the unit for the length over which the line's direction is averaged when calculating individual label angles. | |
| QgsLinearReferencingSymbolLayer * | clone () const override |
| Shall be reimplemented by subclasses to create a deep copy of the instance. | |
| Qgis::SymbolLayerFlags | flags () const override |
| Returns flags which control the symbol layer's behavior. | |
| double | interval () const |
| Returns the interval between labels. | |
| QPointF | labelOffset () const |
| Returns the offset between the line and linear referencing labels. | |
| const QgsMapUnitScale & | labelOffsetMapUnitScale () const |
| Returns the map unit scale used for calculating the offset between the line and linear referencing labels. | |
| Qgis::RenderUnit | labelOffsetUnit () const |
| Returns the unit used for the offset between the line and linear referencing labels. | |
| Qgis::LinearReferencingLabelSource | labelSource () const |
| Returns the label source, which dictates what quantity to use for the labels shown. | |
| QString | layerType () const override |
| Returns a string that represents this layer type. | |
| QgsNumericFormat * | numericFormat () const |
| Returns the numeric format used to format the labels for the layer. | |
| Qgis::LinearReferencingPlacement | placement () const |
| Returns the placement mode for the labels. | |
| QVariantMap | properties () const override |
| Should be reimplemented by subclasses to return a string map that contains the configuration information for the symbol layer. | |
| void | renderPolyline (const QPolygonF &points, QgsSymbolRenderContext &context) override |
| Renders the line symbol layer along the line joining points, using the given render context. | |
| bool | rotateLabels () const |
Returns true if the labels and symbols are to be rotated to match their line segment orientation. | |
| void | setAverageAngleLength (double length) |
| Sets the length of line over which the line's direction is averaged when calculating individual label angles. | |
| void | setAverageAngleMapUnitScale (const QgsMapUnitScale &scale) |
| Sets the map unit scale for the length over which the line's direction is averaged when calculating individual label angles. | |
| void | setAverageAngleUnit (Qgis::RenderUnit unit) |
| Sets the unit for the length over which the line's direction is averaged when calculating individual label angles. | |
| void | setInterval (double interval) |
| Sets the interval between labels. | |
| void | setLabelOffset (const QPointF &offset) |
| Sets the offset between the line and linear referencing labels. | |
| void | setLabelOffsetMapUnitScale (const QgsMapUnitScale &scale) |
| Sets the map unit scale used for calculating the offset between the line and linear referencing labels. | |
| void | setLabelOffsetUnit (Qgis::RenderUnit unit) |
| Sets the unit used for the offset between the line and linear referencing labels. | |
| void | setLabelSource (Qgis::LinearReferencingLabelSource source) |
| Sets the label source, which dictates what quantity to use for the labels shown. | |
| void | setNumericFormat (QgsNumericFormat *format) |
| Sets the numeric format used to format the labels for the layer. | |
| void | setPlacement (Qgis::LinearReferencingPlacement placement) |
| Sets the placement mode for the labels. | |
| void | setRotateLabels (bool rotate) |
| Sets whether the labels and symbols should be rotated to match their line segment orientation. | |
| void | setShowMarker (bool show) |
| Sets whether a marker symbol should be shown corresponding to the labeled point on line. | |
| void | setSkipMultiplesOf (double multiple) |
| Sets the multiple distance to skip labels for. | |
| bool | setSubSymbol (QgsSymbol *symbol) override |
| Sets layer's subsymbol. takes ownership of the passed symbol. | |
| void | setTextFormat (const QgsTextFormat &format) |
| Sets the text format used to render the layer. | |
| bool | showMarker () const |
Returns true if a marker symbol should be shown corresponding to the labeled point on line. | |
| double | skipMultiplesOf () const |
| Returns the multiple distance to skip labels for. | |
| void | startRender (QgsSymbolRenderContext &context) override |
| Called before a set of rendering operations commences on the supplied render context. | |
| void | stopRender (QgsSymbolRenderContext &context) override |
| Called after a set of rendering operations has finished on the supplied render context. | |
| QgsSymbol * | subSymbol () override |
| Returns the symbol's sub symbol, if present. | |
| QgsTextFormat | textFormat () const |
| Returns the text format used to render the layer. | |
| Public Member Functions inherited from QgsLineSymbolLayer | |
| QgsLineSymbolLayer (const QgsLineSymbolLayer &other)=delete | |
| void | drawPreviewIcon (QgsSymbolRenderContext &context, QSize size) override |
| double | dxfWidth (const QgsDxfExport &e, QgsSymbolRenderContext &context) const override |
| Gets line width. | |
| QgsMapUnitScale | mapUnitScale () const override |
| double | offset () const |
| Returns the line's offset. | |
| const QgsMapUnitScale & | offsetMapUnitScale () const |
| Returns the map unit scale for the line's offset. | |
| Qgis::RenderUnit | offsetUnit () const |
| Returns the units for the line's offset. | |
| QgsLineSymbolLayer & | operator= (const QgsLineSymbolLayer &other)=delete |
| Qgis::RenderUnit | outputUnit () const override |
| Returns the units to use for sizes and widths within the symbol layer. | |
| virtual void | renderPolygonStroke (const QPolygonF &points, const QVector< QPolygonF > *rings, QgsSymbolRenderContext &context) |
| Renders the line symbol layer along the outline of polygon, using the given render context. | |
| RenderRingFilter | ringFilter () const |
| Returns the line symbol layer's ring filter, which controls which rings are rendered when the line symbol is being used to draw a polygon's rings. | |
| void | setMapUnitScale (const QgsMapUnitScale &scale) override |
| void | setOffset (double offset) |
| Sets the line's offset. | |
| void | setOffsetMapUnitScale (const QgsMapUnitScale &scale) |
| Sets the map unit scale for the line's offset. | |
| void | setOffsetUnit (Qgis::RenderUnit unit) |
| Sets the unit for the line's offset. | |
| void | setOutputUnit (Qgis::RenderUnit unit) override |
| Sets the units to use for sizes and widths within the symbol layer. | |
| void | setRingFilter (QgsLineSymbolLayer::RenderRingFilter filter) |
| Sets the line symbol layer's ring filter, which controls which rings are rendered when the line symbol is being used to draw a polygon's rings. | |
| virtual void | setWidth (double width) |
| Sets the width of the line symbol layer. | |
| void | setWidthMapUnitScale (const QgsMapUnitScale &scale) |
| void | setWidthUnit (Qgis::RenderUnit unit) |
| Sets the units for the line's width. | |
| virtual double | width () const |
| Returns the estimated width for the line symbol layer. | |
| virtual double | width (const QgsRenderContext &context) const |
| Returns the line symbol layer width, in painter units. | |
| const QgsMapUnitScale & | widthMapUnitScale () const |
| Qgis::RenderUnit | widthUnit () const |
| Returns the units for the line's width. | |
| Public Member Functions inherited from QgsSymbolLayer | |
| virtual | ~QgsSymbolLayer () |
| virtual bool | canCauseArtifactsBetweenAdjacentTiles () const |
Returns true if the symbol layer rendering can cause visible artifacts across a single feature when the feature is rendered as a series of adjacent map tiles each containing a portion of the feature's geometry. | |
| virtual QColor | color () const |
| Returns the "representative" color of the symbol layer. | |
| QgsPropertyCollection & | dataDefinedProperties () |
| Returns a reference to the symbol layer's property collection, used for data defined overrides. | |
| const QgsPropertyCollection & | dataDefinedProperties () const |
| Returns a reference to the symbol layer's property collection, used for data defined overrides. | |
| virtual double | dxfAngle (QgsSymbolRenderContext &context) const |
| Gets angle. | |
| virtual QColor | dxfBrushColor (QgsSymbolRenderContext &context) const |
| Gets brush/fill color. | |
| virtual Qt::BrushStyle | dxfBrushStyle () const |
| Gets brush/fill style. | |
| virtual QColor | dxfColor (QgsSymbolRenderContext &context) const |
| Gets color. | |
| virtual QVector< qreal > | dxfCustomDashPattern (Qgis::RenderUnit &unit) const |
| Gets dash pattern. | |
| virtual double | dxfOffset (const QgsDxfExport &e, QgsSymbolRenderContext &context) const |
| Gets offset. | |
| virtual Qt::PenStyle | dxfPenStyle () const |
| Gets pen style. | |
| virtual double | dxfSize (const QgsDxfExport &e, QgsSymbolRenderContext &context) const |
| Gets marker size. | |
| bool | enabled () const |
Returns true if symbol layer is enabled and will be drawn. | |
| virtual double | estimateMaxBleed (const QgsRenderContext &context) const |
| Returns the estimated maximum distance which the layer style will bleed outside the drawn shape when drawn in the specified /a context. | |
| virtual QColor | fillColor () const |
| Returns the fill color for the symbol layer. | |
| virtual bool | hasDataDefinedProperties () const |
Returns true if the symbol layer (or any of its sub-symbols) contains data defined properties. | |
| QString | id () const |
| Returns symbol layer identifier This id is unique in the whole project. | |
| bool | installMasks (QgsRenderContext &context, bool recursive, const QRectF &rect=QRectF()) |
| When rendering, install masks on context painter. | |
| virtual bool | isCompatibleWithSymbol (QgsSymbol *symbol) const |
| Returns if the layer can be used below the specified symbol. | |
| bool | isLocked () const |
Returns true if the symbol layer colors are locked and the layer will ignore any symbol-level color changes. | |
| virtual QList< QgsSymbolLayerReference > | masks () const |
| Returns masks defined by this symbol layer. | |
| virtual QString | ogrFeatureStyle (double mmScaleFactor, double mapUnitScaleFactor) const |
| QgsSymbolLayer & | operator= (const QgsSymbolLayer &other)=delete |
| QgsPaintEffect * | paintEffect () const |
| Returns the current paint effect for the layer. | |
| virtual void | prepareExpressions (const QgsSymbolRenderContext &context) |
| Prepares all data defined property expressions for evaluation. | |
| virtual void | prepareMasks (const QgsSymbolRenderContext &context) |
| Prepares all mask internal objects according to what is defined in context This should be called prior to calling startRender() method. | |
| int | renderingPass () const |
| Specifies the rendering pass in which this symbol layer should be rendered. | |
| virtual bool | rendersIdenticallyTo (const QgsSymbolLayer *other) const |
Returns true if this symbol layer will always render identically to an other symbol layer. | |
| virtual void | setColor (const QColor &color) |
| Sets the "representative" color for the symbol layer. | |
| void | setDataDefinedProperties (const QgsPropertyCollection &collection) |
| Sets the symbol layer's property collection, used for data defined overrides. | |
| virtual void | setDataDefinedProperty (Property key, const QgsProperty &property) |
| Sets a data defined property for the layer. | |
| void | setEnabled (bool enabled) |
| Sets whether symbol layer is enabled and should be drawn. | |
| virtual void | setFillColor (const QColor &color) |
| Sets the fill color for the symbol layer. | |
| void | setId (const QString &id) |
| Set symbol layer identifier This id has to be unique in the whole project. | |
| void | setLocked (bool locked) |
| Sets whether the layer's colors are locked. | |
| void | setPaintEffect (QgsPaintEffect *effect) |
| Sets the current paint effect for the layer. | |
| void | setRenderingPass (int renderingPass) |
| Specifies the rendering pass in which this symbol layer should be rendered. | |
| virtual void | setStrokeColor (const QColor &color) |
| Sets the stroke color for the symbol layer. | |
| void | setUserFlags (Qgis::SymbolLayerUserFlags flags) |
| Sets user-controlled flags which control the symbol layer's behavior. | |
| virtual void | startFeatureRender (const QgsFeature &feature, QgsRenderContext &context) |
| Called before the layer will be rendered for a particular feature. | |
| virtual void | stopFeatureRender (const QgsFeature &feature, QgsRenderContext &context) |
| Called after the layer has been rendered for a particular feature. | |
| virtual QColor | strokeColor () const |
| Returns the stroke color for the symbol layer. | |
| virtual Q_DECL_DEPRECATED void | toSld (QDomDocument &doc, QDomElement &element, const QVariantMap &props) const |
| Saves the symbol layer as SLD. | |
| virtual bool | toSld (QDomDocument &doc, QDomElement &element, QgsSldExportContext &context) const |
| Saves the symbol layer as SLD. | |
| Qgis::SymbolType | type () const |
| virtual QSet< QString > | usedAttributes (const QgsRenderContext &context) const |
| Returns the set of attributes referenced by the layer. | |
| Qgis::SymbolLayerUserFlags | userFlags () const |
| Returns user-controlled flags which control the symbol layer's behavior. | |
| virtual bool | usesMapUnits () const |
Returns true if the symbol layer has any components which use map unit based sizes. | |
| virtual bool | writeDxf (QgsDxfExport &e, double mmMapUnitScaleFactor, const QString &layerName, QgsSymbolRenderContext &context, QPointF shift=QPointF(0.0, 0.0)) const |
| write as DXF | |
Static Public Member Functions | |
| static QgsSymbolLayer * | create (const QVariantMap &properties=QVariantMap()) |
| Creates a new QgsLinearReferencingSymbolLayer, using the specified properties. | |
| Static Public Member Functions inherited from QgsSymbolLayer | |
| static const QgsPropertiesDefinition & | propertyDefinitions () |
| Returns the symbol layer property definitions. | |
Line symbol layer used for decorating according to linear referencing.
This symbol layer type allows placing text labels at regular intervals along a line (or at positions corresponding to existing vertices). Positions can be calculated using Cartesian distances, or interpolated from z or m values.
Definition at line 35 of file qgslinearreferencingsymbollayer.h.
| QgsLinearReferencingSymbolLayer::QgsLinearReferencingSymbolLayer | ( | ) |
Definition at line 115 of file qgslinearreferencingsymbollayer.cpp.
|
overridedefault |
|
inline |
Returns the length of line over which the line's direction is averaged when calculating individual label angles.
Longer lengths smooth out angles from jagged lines to a greater extent.
Units are retrieved through averageAngleUnit()
Definition at line 250 of file qgslinearreferencingsymbollayer.h.
|
inline |
Returns the map unit scale for the length over which the line's direction is averaged when calculating individual label angles.
Definition at line 302 of file qgslinearreferencingsymbollayer.h.
|
inline |
Returns the unit for the length over which the line's direction is averaged when calculating individual label angles.
Definition at line 282 of file qgslinearreferencingsymbollayer.h.
|
overridevirtual |
Shall be reimplemented by subclasses to create a deep copy of the instance.
Implements QgsSymbolLayer.
Definition at line 192 of file qgslinearreferencingsymbollayer.cpp.
|
static |
Creates a new QgsLinearReferencingSymbolLayer, using the specified properties.
The caller takes ownership of the returned object.
Definition at line 123 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Returns flags which control the symbol layer's behavior.
Reimplemented from QgsSymbolLayer.
Definition at line 290 of file qgslinearreferencingsymbollayer.cpp.
| double QgsLinearReferencingSymbolLayer::interval | ( | ) | const |
Returns the interval between labels.
Units are always in the original layer CRS units.
Definition at line 1082 of file qgslinearreferencingsymbollayer.cpp.
|
inline |
Returns the offset between the line and linear referencing labels.
The unit for the offset is retrievable via labelOffsetUnit().
Definition at line 152 of file qgslinearreferencingsymbollayer.h.
|
inline |
Returns the map unit scale used for calculating the offset between the line and linear referencing labels.
Definition at line 185 of file qgslinearreferencingsymbollayer.h.
|
inline |
Returns the unit used for the offset between the line and linear referencing labels.
Definition at line 170 of file qgslinearreferencingsymbollayer.h.
| Qgis::LinearReferencingLabelSource QgsLinearReferencingSymbolLayer::labelSource | ( | ) | const |
Returns the label source, which dictates what quantity to use for the labels shown.
Definition at line 1126 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Returns a string that represents this layer type.
Used for serialization. Should match with the string used to register this symbol layer in the registry.
Implements QgsSymbolLayer.
Definition at line 285 of file qgslinearreferencingsymbollayer.cpp.
| QgsNumericFormat * QgsLinearReferencingSymbolLayer::numericFormat | ( | ) | const |
Returns the numeric format used to format the labels for the layer.
Definition at line 1072 of file qgslinearreferencingsymbollayer.cpp.
| Qgis::LinearReferencingPlacement QgsLinearReferencingSymbolLayer::placement | ( | ) | const |
Returns the placement mode for the labels.
Definition at line 1116 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Should be reimplemented by subclasses to return a string map that contains the configuration information for the symbol layer.
This is used to serialize a symbol layer perstistently.
Implements QgsSymbolLayer.
Definition at line 219 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Renders the line symbol layer along the line joining points, using the given render context.
Implements QgsLineSymbolLayer.
Definition at line 376 of file qgslinearreferencingsymbollayer.cpp.
|
inline |
Returns true if the labels and symbols are to be rotated to match their line segment orientation.
Definition at line 135 of file qgslinearreferencingsymbollayer.h.
|
inline |
Sets the length of line over which the line's direction is averaged when calculating individual label angles.
Longer lengths smooth out angles from jagged lines to a greater extent.
Units are set through setAverageAngleUnit()
Definition at line 262 of file qgslinearreferencingsymbollayer.h.
|
inline |
Sets the map unit scale for the length over which the line's direction is averaged when calculating individual label angles.
Definition at line 292 of file qgslinearreferencingsymbollayer.h.
|
inline |
Sets the unit for the length over which the line's direction is averaged when calculating individual label angles.
Definition at line 272 of file qgslinearreferencingsymbollayer.h.
| void QgsLinearReferencingSymbolLayer::setInterval | ( | double | interval | ) |
Sets the interval between labels.
Units are always in the original layer CRS units.
Definition at line 1087 of file qgslinearreferencingsymbollayer.cpp.
|
inline |
Sets the offset between the line and linear referencing labels.
The unit for the offset is set via setLabelOffsetUnit().
Definition at line 162 of file qgslinearreferencingsymbollayer.h.
|
inline |
Sets the map unit scale used for calculating the offset between the line and linear referencing labels.
Definition at line 192 of file qgslinearreferencingsymbollayer.h.
|
inline |
Sets the unit used for the offset between the line and linear referencing labels.
Definition at line 178 of file qgslinearreferencingsymbollayer.h.
| void QgsLinearReferencingSymbolLayer::setLabelSource | ( | Qgis::LinearReferencingLabelSource | source | ) |
Sets the label source, which dictates what quantity to use for the labels shown.
Definition at line 1131 of file qgslinearreferencingsymbollayer.cpp.
| void QgsLinearReferencingSymbolLayer::setNumericFormat | ( | QgsNumericFormat * | format | ) |
Sets the numeric format used to format the labels for the layer.
Ownership of format is transferred to the layer.
Definition at line 1077 of file qgslinearreferencingsymbollayer.cpp.
| void QgsLinearReferencingSymbolLayer::setPlacement | ( | Qgis::LinearReferencingPlacement | placement | ) |
Sets the placement mode for the labels.
Definition at line 1121 of file qgslinearreferencingsymbollayer.cpp.
|
inline |
Sets whether the labels and symbols should be rotated to match their line segment orientation.
Definition at line 142 of file qgslinearreferencingsymbollayer.h.
| void QgsLinearReferencingSymbolLayer::setShowMarker | ( | bool | show | ) |
Sets whether a marker symbol should be shown corresponding to the labeled point on line.
The marker symbol is set using setSubSymbol()
Definition at line 1107 of file qgslinearreferencingsymbollayer.cpp.
| void QgsLinearReferencingSymbolLayer::setSkipMultiplesOf | ( | double | multiple | ) |
Sets the multiple distance to skip labels for.
If this value is non-zero, then any labels which are integer multiples of the returned value will be skipped. This allows creation of advanced referencing styles where a single QgsSymbol has multiple QgsLinearReferencingSymbolLayer symbol layers, eg allowing labeling every 100 in a normal font and every 1000 in a bold, larger font.
Definition at line 1097 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Sets layer's subsymbol. takes ownership of the passed symbol.
Reimplemented from QgsSymbolLayer.
Definition at line 301 of file qgslinearreferencingsymbollayer.cpp.
| void QgsLinearReferencingSymbolLayer::setTextFormat | ( | const QgsTextFormat & | format | ) |
Sets the text format used to render the layer.
Definition at line 1067 of file qgslinearreferencingsymbollayer.cpp.
| bool QgsLinearReferencingSymbolLayer::showMarker | ( | ) | const |
Returns true if a marker symbol should be shown corresponding to the labeled point on line.
The marker symbol is set using setSubSymbol()
Definition at line 1102 of file qgslinearreferencingsymbollayer.cpp.
| double QgsLinearReferencingSymbolLayer::skipMultiplesOf | ( | ) | const |
Returns the multiple distance to skip labels for.
If this value is non-zero, then any labels which are integer multiples of the returned value will be skipped. This allows creation of advanced referencing styles where a single QgsSymbol has multiple QgsLinearReferencingSymbolLayer symbol layers, eg allowing labeling every 100 in a normal font and every 1000 in a bold, larger font.
Definition at line 1092 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Called before a set of rendering operations commences on the supplied render context.
This is always followed by a call to stopRender() after all rendering operations have been completed.
Subclasses can use this method to prepare for a set of rendering operations, e.g. by pre-evaluating paths or images to render, and performing other one-time optimisations.
Implements QgsSymbolLayer.
Definition at line 312 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Called after a set of rendering operations has finished on the supplied render context.
This is always preceded by a call to startRender() before all rendering operations are commenced.
Subclasses can use this method to cleanup after a set of rendering operations.
Implements QgsSymbolLayer.
Definition at line 333 of file qgslinearreferencingsymbollayer.cpp.
|
overridevirtual |
Returns the symbol's sub symbol, if present.
Reimplemented from QgsSymbolLayer.
Definition at line 296 of file qgslinearreferencingsymbollayer.cpp.
| QgsTextFormat QgsLinearReferencingSymbolLayer::textFormat | ( | ) | const |
Returns the text format used to render the layer.
Definition at line 1062 of file qgslinearreferencingsymbollayer.cpp.