QGIS API Documentation  3.37.0-Master (a5b4d9743e8)
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Static Protected Member Functions | Protected Attributes | List of all members
QgsFeatureRenderer Class Referenceabstract

#include <qgsrenderer.h>

Inheritance diagram for QgsFeatureRenderer:
Inheritance graph
[legend]

Public Types

typedef QFlags< CapabilityCapabilities
 
enum  Capability { SymbolLevels = 1 , MoreSymbolsPerFeature = 1 << 2 , Filter = 1 << 3 , ScaleDependent = 1 << 4 }
 Used to specify details about a renderer. More...
 

Public Member Functions

virtual ~QgsFeatureRenderer ()
 
virtual bool accept (QgsStyleEntityVisitorInterface *visitor) const
 Accepts the specified symbology visitor, causing it to visit all symbols associated with the renderer. More...
 
virtual bool canSkipRender ()
 Returns true if the renderer can be entirely skipped, i.e. More...
 
virtual QgsFeatureRenderer::Capabilities capabilities ()
 Returns details about internals of this renderer. More...
 
virtual void checkLegendSymbolItem (const QString &key, bool state=true)
 Sets whether the legend symbology item with the specified ley should be checked. More...
 
virtual QgsFeatureRendererclone () const =0
 Create a deep copy of this renderer. More...
 
void copyRendererData (QgsFeatureRenderer *destRenderer) const
 Clones generic renderer data to another renderer. More...
 
virtual QString dump () const
 Returns debug information about this renderer. More...
 
virtual const QgsFeatureRendererembeddedRenderer () const
 Returns the current embedded renderer (subrenderer) for this feature renderer. More...
 
virtual QString filter (const QgsFields &fields=QgsFields())
 If a renderer does not require all the features this method may be overridden and return an expression used as where clause. More...
 
virtual bool filterNeedsGeometry () const
 Returns true if this renderer requires the geometry to apply the filter. More...
 
bool forceRasterRender () const
 Returns whether the renderer must render as a raster. More...
 
virtual QString legendClassificationAttribute () const
 If supported by the renderer, return classification attribute for the use in legend. More...
 
QSet< QString > legendKeys () const
 Returns the set of all legend keys used by the renderer. More...
 
virtual QSet< QString > legendKeysForFeature (const QgsFeature &feature, QgsRenderContext &context) const
 Returns legend keys matching a specified feature. More...
 
virtual QString legendKeyToExpression (const QString &key, QgsVectorLayer *layer, bool &ok) const
 Attempts to convert the specified legend rule key to a QGIS expression matching the features displayed using that key. More...
 
virtual bool legendSymbolItemChecked (const QString &key)
 Returns true if the legend symbology item with the specified key is checked. More...
 
virtual QgsLegendSymbolList legendSymbolItems () const
 Returns a list of symbology items for the legend. More...
 
virtual bool legendSymbolItemsCheckable () const
 Returns true if symbology items in legend are checkable. More...
 
virtual void modifyRequestExtent (QgsRectangle &extent, QgsRenderContext &context)
 Allows for a renderer to modify the extent of a feature request prior to rendering. More...
 
QgsFeatureRequest::OrderBy orderBy () const
 Gets the order in which features shall be processed by this renderer. More...
 
bool orderByEnabled () const
 Returns whether custom ordering will be applied before features are processed by this renderer. More...
 
virtual QgsSymboloriginalSymbolForFeature (const QgsFeature &feature, QgsRenderContext &context) const
 Returns symbol for feature. More...
 
virtual QgsSymbolList originalSymbolsForFeature (const QgsFeature &feature, QgsRenderContext &context) const
 Equivalent of originalSymbolsForFeature() call extended to support renderers that may use more symbols per feature - similar to symbolsForFeature() More...
 
QgsPaintEffectpaintEffect () const
 Returns the current paint effect for the renderer. More...
 
double referenceScale () const
 Returns the symbology reference scale. More...
 
virtual bool renderFeature (const QgsFeature &feature, QgsRenderContext &context, int layer=-1, bool selected=false, bool drawVertexMarker=false)
 Render a feature using this renderer in the given context. More...
 
virtual QDomElement save (QDomDocument &doc, const QgsReadWriteContext &context)
 Stores renderer properties to an XML element. More...
 
virtual void setEmbeddedRenderer (QgsFeatureRenderer *subRenderer)
 Sets an embedded renderer (subrenderer) for this feature renderer. More...
 
void setForceRasterRender (bool forceRaster)
 Sets whether the renderer should be rendered to a raster destination. More...
 
virtual void setLegendSymbolItem (const QString &key, QgsSymbol *symbol)
 Sets the symbol to be used for a legend symbol item. More...
 
void setOrderBy (const QgsFeatureRequest::OrderBy &orderBy)
 Define the order in which features shall be processed by this renderer. More...
 
void setOrderByEnabled (bool enabled)
 Sets whether custom ordering should be applied before features are processed by this renderer. More...
 
void setPaintEffect (QgsPaintEffect *effect)
 Sets the current paint effect for the renderer. More...
 
void setReferenceScale (double scale)
 Sets the symbology reference scale. More...
 
void setUsingSymbolLevels (bool usingSymbolLevels)
 
void setVertexMarkerAppearance (Qgis::VertexMarkerType type, double size)
 Sets type and size of editing vertex markers for subsequent rendering. More...
 
virtual void startRender (QgsRenderContext &context, const QgsFields &fields)
 Must be called when a new render cycle is started. More...
 
virtual void stopRender (QgsRenderContext &context)
 Must be called when a render cycle has finished, to allow the renderer to clean up. More...
 
virtual QgsSymbolsymbolForFeature (const QgsFeature &feature, QgsRenderContext &context) const =0
 To be overridden. More...
 
virtual QgsSymbolList symbols (QgsRenderContext &context) const
 Returns list of symbols used by the renderer. More...
 
virtual QgsSymbolList symbolsForFeature (const QgsFeature &feature, QgsRenderContext &context) const
 Returns list of symbols used for rendering the feature. More...
 
virtual void toSld (QDomDocument &doc, QDomElement &element, const QVariantMap &props=QVariantMap()) const
 used from subclasses to create SLD Rule elements following SLD v1.1 specs More...
 
QString type () const
 
virtual QSet< QString > usedAttributes (const QgsRenderContext &context) const =0
 Returns a list of attributes required by this renderer. More...
 
virtual bool usesEmbeddedSymbols () const
 Returns true if the renderer uses embedded symbols for features. More...
 
bool usingSymbolLevels () const
 
virtual bool willRenderFeature (const QgsFeature &feature, QgsRenderContext &context) const
 Returns whether the renderer will render a feature or not. More...
 
virtual QDomElement writeSld (QDomDocument &doc, const QString &styleName, const QVariantMap &props=QVariantMap()) const
 create the SLD UserStyle element following the SLD v1.1 specs with the given name More...
 

Static Public Member Functions

static QgsFeatureRendererdefaultRenderer (Qgis::GeometryType geomType)
 Returns a new renderer - used by default in vector layers. More...
 
static QgsFeatureRendererload (QDomElement &symbologyElem, const QgsReadWriteContext &context)
 create a renderer from XML element More...
 
static QgsFeatureRendererloadSld (const QDomNode &node, Qgis::GeometryType geomType, QString &errorMessage)
 Create a new renderer according to the information contained in the UserStyle element of a SLD style document. More...
 

Protected Member Functions

 QgsFeatureRenderer (const QString &type)
 
void renderFeatureWithSymbol (const QgsFeature &feature, QgsSymbol *symbol, QgsRenderContext &context, int layer, bool selected, bool drawVertexMarker)
 Render the feature with the symbol using context. More...
 
void renderVertexMarker (QPointF pt, QgsRenderContext &context)
 render editing vertex marker at specified point More...
 
void renderVertexMarkerPolygon (QPolygonF &pts, QList< QPolygonF > *rings, QgsRenderContext &context)
 render editing vertex marker for a polygon More...
 
void renderVertexMarkerPolyline (QPolygonF &pts, QgsRenderContext &context)
 render editing vertex marker for a polyline More...
 
void saveRendererData (QDomDocument &doc, QDomElement &element, const QgsReadWriteContext &context)
 Saves generic renderer data into the specified element. More...
 

Static Protected Member Functions

static QPointF _getPoint (QgsRenderContext &context, const QgsPoint &point)
 Creates a point in screen coordinates from a wkb string in map coordinates. More...
 
static void convertSymbolRotation (QgsSymbol *symbol, const QString &field)
 
static void convertSymbolSizeScale (QgsSymbol *symbol, Qgis::ScaleMethod method, const QString &field)
 

Protected Attributes

double mCurrentVertexMarkerSize = 2
 The current size of editing marker. More...
 
Qgis::VertexMarkerType mCurrentVertexMarkerType = Qgis::VertexMarkerType::Cross
 The current type of editing marker. More...
 
bool mForceRaster = false
 
QgsFeatureRequest::OrderBy mOrderBy
 
bool mOrderByEnabled = false
 
QgsPaintEffectmPaintEffect = nullptr
 
double mReferenceScale = -1.0
 
QString mType
 
bool mUsingSymbolLevels = false
 

Detailed Description

Definition at line 101 of file qgsrenderer.h.

Member Typedef Documentation

◆ Capabilities

Definition at line 276 of file qgsrenderer.h.

Member Enumeration Documentation

◆ Capability

Used to specify details about a renderer.

Is returned from the capabilities() method.

Enumerator
SymbolLevels 

Rendering with symbol levels (i.e. implements symbols(), symbolForFeature())

MoreSymbolsPerFeature 

May use more than one symbol to render a feature: symbolsForFeature() will return them.

Filter 

Features may be filtered, i.e. some features may not be rendered (categorized, rule based ...)

ScaleDependent 

Depends on scale if feature will be rendered (rule based )

Definition at line 268 of file qgsrenderer.h.

Constructor & Destructor Documentation

◆ ~QgsFeatureRenderer()

QgsFeatureRenderer::~QgsFeatureRenderer ( )
virtual

Definition at line 68 of file qgsrenderer.cpp.

◆ QgsFeatureRenderer()

QgsFeatureRenderer::QgsFeatureRenderer ( const QString &  type)
protected

Definition at line 61 of file qgsrenderer.cpp.

Member Function Documentation

◆ _getPoint()

QPointF QgsFeatureRenderer::_getPoint ( QgsRenderContext context,
const QgsPoint point 
)
staticprotected

Creates a point in screen coordinates from a wkb string in map coordinates.

Definition at line 41 of file qgsrenderer.cpp.

◆ accept()

bool QgsFeatureRenderer::accept ( QgsStyleEntityVisitorInterface visitor) const
virtual

Accepts the specified symbology visitor, causing it to visit all symbols associated with the renderer.

Returns true if the visitor should continue visiting other objects, or false if visiting should be canceled.

Since
QGIS 3.10

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsPointDisplacementRenderer, QgsPointClusterRenderer, QgsMergedFeatureRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

Definition at line 502 of file qgsrenderer.cpp.

◆ canSkipRender()

bool QgsFeatureRenderer::canSkipRender ( )
virtual

Returns true if the renderer can be entirely skipped, i.e.

if it is known in advance that no features will be rendered.

Warning
Must be called between startRender() and stopRender() calls.
Since
QGIS 3.30

Reimplemented in QgsRuleBasedRenderer.

Definition at line 104 of file qgsrenderer.cpp.

◆ capabilities()

virtual QgsFeatureRenderer::Capabilities QgsFeatureRenderer::capabilities ( )
inlinevirtual

Returns details about internals of this renderer.

E.g. if you only want to deal with visible features:

if not renderer.capabilities().testFlag(QgsFeatureRenderer.Filter) or renderer.willRenderFeature(feature, context):
deal_with_my_feature()
else:
skip_the_curren_feature()

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 290 of file qgsrenderer.h.

◆ checkLegendSymbolItem()

void QgsFeatureRenderer::checkLegendSymbolItem ( const QString &  key,
bool  state = true 
)
virtual

Sets whether the legend symbology item with the specified ley should be checked.

See also
legendSymbolItemChecked()
legendKeys()

Reimplemented in QgsRuleBasedRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, QgsCategorizedSymbolRenderer, and QgsPointDistanceRenderer.

Definition at line 372 of file qgsrenderer.cpp.

◆ clone()

virtual QgsFeatureRenderer* QgsFeatureRenderer::clone ( ) const
pure virtual

Create a deep copy of this renderer.

Should be implemented by all subclasses and generate a proper subclass.

Returns
A copy of this renderer

Implemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDisplacementRenderer, QgsPointClusterRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsInvertedPolygonRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

◆ convertSymbolRotation()

void QgsFeatureRenderer::convertSymbolRotation ( QgsSymbol symbol,
const QString &  field 
)
staticprotected
Note
this function is used to convert old rotations expressions to symbol level DataDefined angle

Definition at line 529 of file qgsrenderer.cpp.

◆ convertSymbolSizeScale()

void QgsFeatureRenderer::convertSymbolSizeScale ( QgsSymbol symbol,
Qgis::ScaleMethod  method,
const QString &  field 
)
staticprotected
Note
this function is used to convert old sizeScale expressions to symbol level DataDefined size

Definition at line 507 of file qgsrenderer.cpp.

◆ copyRendererData()

void QgsFeatureRenderer::copyRendererData ( QgsFeatureRenderer destRenderer) const

Clones generic renderer data to another renderer.

Currently clones

  • Order by
  • Paint effect
  • Reference scale
  • Symbol levels enabled/disabled
  • Force raster render enabled/disabled
Parameters
destRendererdestination renderer for copied effect
Since
QGIS 3.22

Definition at line 46 of file qgsrenderer.cpp.

◆ defaultRenderer()

QgsFeatureRenderer * QgsFeatureRenderer::defaultRenderer ( Qgis::GeometryType  geomType)
static

Returns a new renderer - used by default in vector layers.

Definition at line 73 of file qgsrenderer.cpp.

◆ dump()

QString QgsFeatureRenderer::dump ( ) const
virtual

◆ embeddedRenderer()

const QgsFeatureRenderer * QgsFeatureRenderer::embeddedRenderer ( ) const
virtual

Returns the current embedded renderer (subrenderer) for this feature renderer.

The base class implementation does not use subrenderers and will always return nullptr.

See also
setEmbeddedRenderer()

Reimplemented in QgsPointDistanceRenderer, and QgsMergedFeatureRenderer.

Definition at line 497 of file qgsrenderer.cpp.

◆ filter()

virtual QString QgsFeatureRenderer::filter ( const QgsFields fields = QgsFields())
inlinevirtual

If a renderer does not require all the features this method may be overridden and return an expression used as where clause.

This will be called once after startRender() and before the first call to renderFeature(). By default this returns a null string and all features will be requested. You do not need to specify the extent in here, this is taken care of separately and will be combined with a filter returned from this method.

Returns
An expression used as where clause

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 213 of file qgsrenderer.h.

◆ filterNeedsGeometry()

bool QgsFeatureRenderer::filterNeedsGeometry ( ) const
virtual

Returns true if this renderer requires the geometry to apply the filter.

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 121 of file qgsrenderer.cpp.

◆ forceRasterRender()

bool QgsFeatureRenderer::forceRasterRender ( ) const
inline

Returns whether the renderer must render as a raster.

See also
setForceRasterRender

Definition at line 458 of file qgsrenderer.h.

◆ legendClassificationAttribute()

virtual QString QgsFeatureRenderer::legendClassificationAttribute ( ) const
inlinevirtual

If supported by the renderer, return classification attribute for the use in legend.

Reimplemented in QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 407 of file qgsrenderer.h.

◆ legendKeys()

QSet< QString > QgsFeatureRenderer::legendKeys ( ) const

Returns the set of all legend keys used by the renderer.

See also
legendSymbolItems()
Since
QGIS 3.32

Definition at line 333 of file qgsrenderer.cpp.

◆ legendKeysForFeature()

QSet< QString > QgsFeatureRenderer::legendKeysForFeature ( const QgsFeature feature,
QgsRenderContext context 
) const
virtual

Returns legend keys matching a specified feature.

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 83 of file qgsrenderer.cpp.

◆ legendKeyToExpression()

QString QgsFeatureRenderer::legendKeyToExpression ( const QString &  key,
QgsVectorLayer layer,
bool &  ok 
) const
virtual

Attempts to convert the specified legend rule key to a QGIS expression matching the features displayed using that key.

Parameters
keylegend key
layerassociated vector layer
okwill be set to true if legend key was successfully converted to a filter expression
Returns
QGIS expression string for matching features with the specified key
See also
legendKeys()
Since
QGIS 3.26

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 384 of file qgsrenderer.cpp.

◆ legendSymbolItemChecked()

bool QgsFeatureRenderer::legendSymbolItemChecked ( const QString &  key)
virtual

Returns true if the legend symbology item with the specified key is checked.

See also
checkLegendSymbolItem()
legendKeys()

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 366 of file qgsrenderer.cpp.

◆ legendSymbolItems()

QgsLegendSymbolList QgsFeatureRenderer::legendSymbolItems ( ) const
virtual

Returns a list of symbology items for the legend.

See also
legendKeys()

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 390 of file qgsrenderer.cpp.

◆ legendSymbolItemsCheckable()

bool QgsFeatureRenderer::legendSymbolItemsCheckable ( ) const
virtual

Returns true if symbology items in legend are checkable.

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 361 of file qgsrenderer.cpp.

◆ load()

QgsFeatureRenderer * QgsFeatureRenderer::load ( QDomElement &  symbologyElem,
const QgsReadWriteContext context 
)
static

create a renderer from XML element

Definition at line 156 of file qgsrenderer.cpp.

◆ loadSld()

QgsFeatureRenderer * QgsFeatureRenderer::loadSld ( const QDomNode &  node,
Qgis::GeometryType  geomType,
QString &  errorMessage 
)
static

Create a new renderer according to the information contained in the UserStyle element of a SLD style document.

Parameters
nodethe node in the SLD document whose the UserStyle element is a child
geomTypethe geometry type of the features, used to convert Symbolizer elements
errorMessageit will contain the error message if something went wrong
Returns
the renderer

Definition at line 221 of file qgsrenderer.cpp.

◆ modifyRequestExtent()

void QgsFeatureRenderer::modifyRequestExtent ( QgsRectangle extent,
QgsRenderContext context 
)
virtual

Allows for a renderer to modify the extent of a feature request prior to rendering.

Parameters
extentreference to request's filter extent. Modify extent to change the extent of feature request
contextrender context

Reimplemented in QgsHeatmapRenderer.

Definition at line 447 of file qgsrenderer.cpp.

◆ orderBy()

QgsFeatureRequest::OrderBy QgsFeatureRenderer::orderBy ( ) const

Gets the order in which features shall be processed by this renderer.

Note
this property has no effect if orderByEnabled() is false
See also
orderByEnabled()

Definition at line 472 of file qgsrenderer.cpp.

◆ orderByEnabled()

bool QgsFeatureRenderer::orderByEnabled ( ) const

Returns whether custom ordering will be applied before features are processed by this renderer.

See also
orderBy()
setOrderByEnabled()

Definition at line 482 of file qgsrenderer.cpp.

◆ originalSymbolForFeature()

QgsSymbol * QgsFeatureRenderer::originalSymbolForFeature ( const QgsFeature feature,
QgsRenderContext context 
) const
virtual

Returns symbol for feature.

The difference compared to symbolForFeature() is that it returns original symbol which can be used as an identifier for renderer's rule - the former may return a temporary replacement of a symbol for use in rendering.

Reimplemented in QgsSingleSymbolRenderer, QgsPointDistanceRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 78 of file qgsrenderer.cpp.

◆ originalSymbolsForFeature()

QgsSymbolList QgsFeatureRenderer::originalSymbolsForFeature ( const QgsFeature feature,
QgsRenderContext context 
) const
virtual

Equivalent of originalSymbolsForFeature() call extended to support renderers that may use more symbols per feature - similar to symbolsForFeature()

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, and QgsMergedFeatureRenderer.

Definition at line 453 of file qgsrenderer.cpp.

◆ paintEffect()

QgsPaintEffect * QgsFeatureRenderer::paintEffect ( ) const

Returns the current paint effect for the renderer.

Returns
paint effect
See also
setPaintEffect

Definition at line 461 of file qgsrenderer.cpp.

◆ referenceScale()

double QgsFeatureRenderer::referenceScale ( ) const
inline

Returns the symbology reference scale.

This represents the desired scale denominator for the rendered map, eg 1000.0 for a 1:1000 map render. A value of -1 indicates that symbology scaling by reference scale is disabled.

The symbology reference scale is an optional property which specifies the reference scale at which symbology in paper units (such a millimeters or points) is fixed to. For instance, if the scale is 1000 then a 2mm thick line will be rendered at exactly 2mm thick when a map is rendered at 1:1000, or 1mm thick when rendered at 1:2000, or 4mm thick at 1:500.

See also
setReferenceScale()
Since
QGIS 3.22

Definition at line 483 of file qgsrenderer.h.

◆ renderFeature()

bool QgsFeatureRenderer::renderFeature ( const QgsFeature feature,
QgsRenderContext context,
int  layer = -1,
bool  selected = false,
bool  drawVertexMarker = false 
)
virtual

Render a feature using this renderer in the given context.

Must be called between startRender() and stopRender() calls. Default implementation renders a symbol as determined by symbolForFeature() call. Returns true if the feature has been returned (this is used for example to determine whether the feature may be labelled).

If layer is not -1, the renderer should draw only a particular layer from symbols (in order to support symbol level rendering).

See also
startRender()
stopRender()

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsHeatmapRenderer, and QgsEmbeddedSymbolRenderer.

Definition at line 126 of file qgsrenderer.cpp.

◆ renderFeatureWithSymbol()

void QgsFeatureRenderer::renderFeatureWithSymbol ( const QgsFeature feature,
QgsSymbol symbol,
QgsRenderContext context,
int  layer,
bool  selected,
bool  drawVertexMarker 
)
protected

Render the feature with the symbol using context.

Use layer to specify the symbol layer, selected to specify if it should be rendered as selected and drawVertexMarker to specify if vertex markers should be rendered.

Definition at line 140 of file qgsrenderer.cpp.

◆ renderVertexMarker()

void QgsFeatureRenderer::renderVertexMarker ( QPointF  pt,
QgsRenderContext context 
)
protected

render editing vertex marker at specified point

Definition at line 406 of file qgsrenderer.cpp.

◆ renderVertexMarkerPolygon()

void QgsFeatureRenderer::renderVertexMarkerPolygon ( QPolygonF &  pts,
QList< QPolygonF > *  rings,
QgsRenderContext context 
)
protected

render editing vertex marker for a polygon

Definition at line 421 of file qgsrenderer.cpp.

◆ renderVertexMarkerPolyline()

void QgsFeatureRenderer::renderVertexMarkerPolyline ( QPolygonF &  pts,
QgsRenderContext context 
)
protected

render editing vertex marker for a polyline

Definition at line 414 of file qgsrenderer.cpp.

◆ save()

QDomElement QgsFeatureRenderer::save ( QDomDocument &  doc,
const QgsReadWriteContext context 
)
virtual

Stores renderer properties to an XML element.

Subclasses which override this method should call saveRendererData() as part of their implementation in order to store all common base class properties in the returned DOM element.

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDisplacementRenderer, QgsPointClusterRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsInvertedPolygonRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

Definition at line 192 of file qgsrenderer.cpp.

◆ saveRendererData()

void QgsFeatureRenderer::saveRendererData ( QDomDocument &  doc,
QDomElement &  element,
const QgsReadWriteContext context 
)
protected

Saves generic renderer data into the specified element.

This method should be called in a subclass' save() implementation in order to store all common base class properties in the DOM element.

Since
QGIS 3.22

Definition at line 203 of file qgsrenderer.cpp.

◆ setEmbeddedRenderer()

void QgsFeatureRenderer::setEmbeddedRenderer ( QgsFeatureRenderer subRenderer)
virtual

Sets an embedded renderer (subrenderer) for this feature renderer.

The base class implementation does nothing with subrenderers, but individual derived classes can use these to modify their behavior.

Parameters
subRendererthe embedded renderer. Ownership will be transferred.
See also
embeddedRenderer()

Reimplemented in QgsMergedFeatureRenderer, and QgsPointDistanceRenderer.

Definition at line 492 of file qgsrenderer.cpp.

◆ setForceRasterRender()

void QgsFeatureRenderer::setForceRasterRender ( bool  forceRaster)
inline

Sets whether the renderer should be rendered to a raster destination.

Parameters
forceRasterset to true if renderer must be drawn on a raster surface. This may be desirable for highly detailed layers where rendering as a vector would result in a large, complex vector output.
See also
forceRasterRender

Definition at line 467 of file qgsrenderer.h.

◆ setLegendSymbolItem()

void QgsFeatureRenderer::setLegendSymbolItem ( const QString &  key,
QgsSymbol symbol 
)
virtual

Sets the symbol to be used for a legend symbol item.

Parameters
keyrule key for legend symbol
symbolnew symbol for legend item. Ownership is transferred to renderer.
See also
legendKeys()

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsMergedFeatureRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 378 of file qgsrenderer.cpp.

◆ setOrderBy()

void QgsFeatureRenderer::setOrderBy ( const QgsFeatureRequest::OrderBy orderBy)

Define the order in which features shall be processed by this renderer.

Note
this property has no effect if orderByEnabled() is false
See also
setOrderByEnabled()

Definition at line 477 of file qgsrenderer.cpp.

◆ setOrderByEnabled()

void QgsFeatureRenderer::setOrderByEnabled ( bool  enabled)

Sets whether custom ordering should be applied before features are processed by this renderer.

Parameters
enabledset to true to enable custom feature ordering
See also
setOrderBy()
orderByEnabled()

Definition at line 487 of file qgsrenderer.cpp.

◆ setPaintEffect()

void QgsFeatureRenderer::setPaintEffect ( QgsPaintEffect effect)

Sets the current paint effect for the renderer.

Parameters
effectpaint effect. Ownership is transferred to the renderer.
See also
paintEffect

Definition at line 466 of file qgsrenderer.cpp.

◆ setReferenceScale()

void QgsFeatureRenderer::setReferenceScale ( double  scale)
inline

Sets the symbology reference scale.

This should match the desired scale denominator for the rendered map, eg 1000.0 for a 1:1000 map render. Set to -1 to disable symbology scaling by reference scale.

The symbology reference scale is an optional property which specifies the reference scale at which symbology in paper units (such a millimeters or points) is fixed to. For instance, if scale is set to 1000 then a 2mm thick line will be rendered at exactly 2mm thick when a map is rendered at 1:1000, or 1mm thick when rendered at 1:2000, or 4mm thick at 1:500.

See also
referenceScale()
Since
QGIS 3.22

Definition at line 499 of file qgsrenderer.h.

◆ setUsingSymbolLevels()

void QgsFeatureRenderer::setUsingSymbolLevels ( bool  usingSymbolLevels)
inline

Definition at line 299 of file qgsrenderer.h.

◆ setVertexMarkerAppearance()

void QgsFeatureRenderer::setVertexMarkerAppearance ( Qgis::VertexMarkerType  type,
double  size 
)

Sets type and size of editing vertex markers for subsequent rendering.

Definition at line 395 of file qgsrenderer.cpp.

◆ startRender()

void QgsFeatureRenderer::startRender ( QgsRenderContext context,
const QgsFields fields 
)
virtual

Must be called when a new render cycle is started.

A call to startRender() must always be followed by a corresponding call to stopRender() after all features have been rendered.

Parameters
contextAdditional information passed to the renderer about the job which will be rendered
fieldsThe fields available for rendering
See also
stopRender()
Warning
This method is not thread safe. Before calling startRender() in a non-main thread, the renderer should instead be cloned and startRender()/stopRender() called on the clone.

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsPointDisplacementRenderer, QgsPointClusterRenderer, QgsMergedFeatureRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

Definition at line 90 of file qgsrenderer.cpp.

◆ stopRender()

void QgsFeatureRenderer::stopRender ( QgsRenderContext context)
virtual

Must be called when a render cycle has finished, to allow the renderer to clean up.

Calls to stopRender() must always be preceded by a call to startRender().

Warning
This method is not thread safe. Before calling startRender() in a non-main thread, the renderer should instead be cloned and startRender()/stopRender() called on the clone.
See also
startRender()

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsPointDisplacementRenderer, QgsPointClusterRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

Definition at line 109 of file qgsrenderer.cpp.

◆ symbolForFeature()

virtual QgsSymbol* QgsFeatureRenderer::symbolForFeature ( const QgsFeature feature,
QgsRenderContext context 
) const
pure virtual

To be overridden.

Must be called between startRender() and stopRender() calls.

Parameters
featurefeature
contextrender context
Returns
returns pointer to symbol or 0 if symbol was not found

Implemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

◆ symbols()

QgsSymbolList QgsFeatureRenderer::symbols ( QgsRenderContext context) const
virtual

◆ symbolsForFeature()

QgsSymbolList QgsFeatureRenderer::symbolsForFeature ( const QgsFeature feature,
QgsRenderContext context 
) const
virtual

Returns list of symbols used for rendering the feature.

For renderers that do not support MoreSymbolsPerFeature it is more efficient to use symbolForFeature()

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, and QgsMergedFeatureRenderer.

Definition at line 439 of file qgsrenderer.cpp.

◆ toSld()

virtual void QgsFeatureRenderer::toSld ( QDomDocument &  doc,
QDomElement &  element,
const QVariantMap &  props = QVariantMap() 
) const
inlinevirtual

used from subclasses to create SLD Rule elements following SLD v1.1 specs

Reimplemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsGraduatedSymbolRenderer, and QgsCategorizedSymbolRenderer.

Definition at line 331 of file qgsrenderer.h.

◆ type()

QString QgsFeatureRenderer::type ( ) const
inline

Definition at line 142 of file qgsrenderer.h.

◆ usedAttributes()

virtual QSet<QString> QgsFeatureRenderer::usedAttributes ( const QgsRenderContext context) const
pure virtual

Returns a list of attributes required by this renderer.

Attributes not listed in here may not have been requested from the provider at rendering time.

Returns
A set of attributes

Implemented in QgsSingleSymbolRenderer, QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsPointDisplacementRenderer, QgsPointClusterRenderer, QgsNullSymbolRenderer, QgsMergedFeatureRenderer, QgsHeatmapRenderer, QgsGraduatedSymbolRenderer, QgsEmbeddedSymbolRenderer, QgsCategorizedSymbolRenderer, and Qgs25DRenderer.

◆ usesEmbeddedSymbols()

bool QgsFeatureRenderer::usesEmbeddedSymbols ( ) const
virtual

Returns true if the renderer uses embedded symbols for features.

The default implementation returns false.

Since
QGIS 3.20

Reimplemented in QgsEmbeddedSymbolRenderer.

Definition at line 116 of file qgsrenderer.cpp.

◆ usingSymbolLevels()

bool QgsFeatureRenderer::usingSymbolLevels ( ) const
inline

Definition at line 298 of file qgsrenderer.h.

◆ willRenderFeature()

bool QgsFeatureRenderer::willRenderFeature ( const QgsFeature feature,
QgsRenderContext context 
) const
virtual

Returns whether the renderer will render a feature or not.

Must be called between startRender() and stopRender() calls. Default implementation uses symbolForFeature().

Reimplemented in QgsRuleBasedRenderer, QgsPointDistanceRenderer, QgsNullSymbolRenderer, and QgsMergedFeatureRenderer.

Definition at line 401 of file qgsrenderer.cpp.

◆ writeSld()

QDomElement QgsFeatureRenderer::writeSld ( QDomDocument &  doc,
const QString &  styleName,
const QVariantMap &  props = QVariantMap() 
) const
virtual

create the SLD UserStyle element following the SLD v1.1 specs with the given name

Definition at line 346 of file qgsrenderer.cpp.

Member Data Documentation

◆ mCurrentVertexMarkerSize

double QgsFeatureRenderer::mCurrentVertexMarkerSize = 2
protected

The current size of editing marker.

Definition at line 614 of file qgsrenderer.h.

◆ mCurrentVertexMarkerType

Qgis::VertexMarkerType QgsFeatureRenderer::mCurrentVertexMarkerType = Qgis::VertexMarkerType::Cross
protected

The current type of editing marker.

Definition at line 611 of file qgsrenderer.h.

◆ mForceRaster

bool QgsFeatureRenderer::mForceRaster = false
protected

Definition at line 618 of file qgsrenderer.h.

◆ mOrderBy

QgsFeatureRequest::OrderBy QgsFeatureRenderer::mOrderBy
protected

Definition at line 634 of file qgsrenderer.h.

◆ mOrderByEnabled

bool QgsFeatureRenderer::mOrderByEnabled = false
protected

Definition at line 636 of file qgsrenderer.h.

◆ mPaintEffect

QgsPaintEffect* QgsFeatureRenderer::mPaintEffect = nullptr
protected

Definition at line 616 of file qgsrenderer.h.

◆ mReferenceScale

double QgsFeatureRenderer::mReferenceScale = -1.0
protected

Definition at line 620 of file qgsrenderer.h.

◆ mType

QString QgsFeatureRenderer::mType
protected

Definition at line 606 of file qgsrenderer.h.

◆ mUsingSymbolLevels

bool QgsFeatureRenderer::mUsingSymbolLevels = false
protected

Definition at line 608 of file qgsrenderer.h.


The documentation for this class was generated from the following files: