QGIS API Documentation 3.41.0-Master (f75d66fa9f9)
qgsembeddedsymbolrendererwidget.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsembeddedsymbolrendererwidget.cpp
3 ---------------------
4 begin : March 2021
5 copyright : (C) 2021 by Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
16#include "moc_qgsembeddedsymbolrendererwidget.cpp"
18#include "qgsrendererregistry.h"
19#include "qgssymbol.h"
20#include "qgsvectorlayer.h"
21
26
28 : QgsRendererWidget( layer, style )
29{
30 if ( !layer )
31 {
32 return;
33 }
34
36
37 // the renderer only applies to layers with providers supporting embedded symbols
39 {
40 //setup blank dialog
41 mRenderer.reset( nullptr );
42 QGridLayout *layout = new QGridLayout( this );
43 QLabel *label = new QLabel( tr( "The embedded symbols renderer can only be used with layers\n"
44 "containing embedded styling information.\n\n"
45 "'%1' does not contain embedded styling and cannot be displayed." )
46 .arg( layer->name() ),
47 this );
48 this->setLayout( layout );
49 layout->addWidget( label );
50 mDefaultSymbolToolButton = nullptr;
51 return;
52 }
53 setupUi( this );
54
55 mDefaultSymbolToolButton->setSymbolType( QgsSymbol::symbolTypeForGeometryType( type ) );
56
57 // try to recognize the previous renderer
58 // (null renderer means "no previous renderer")
59 if ( renderer )
60 {
62 }
63 if ( !mRenderer )
64 {
65 // use default embedded renderer
66 mRenderer.reset( new QgsEmbeddedSymbolRenderer( QgsSymbol::defaultSymbol( type ) ) );
67 if ( renderer )
68 renderer->copyRendererData( mRenderer.get() );
69 }
70
71 mDefaultSymbolToolButton->setSymbol( mRenderer->defaultSymbol()->clone() );
72 mDefaultSymbolToolButton->setDialogTitle( tr( "Default symbol" ) );
73 mDefaultSymbolToolButton->setLayer( mLayer );
74 mDefaultSymbolToolButton->registerExpressionContextGenerator( this );
75
76 connect( mDefaultSymbolToolButton, &QgsSymbolButton::changed, this, [=] {
77 mRenderer->setDefaultSymbol( mDefaultSymbolToolButton->symbol()->clone() );
78 emit widgetChanged();
79 } );
80}
81
83
88
90{
92 if ( mDefaultSymbolToolButton )
93 {
94 mDefaultSymbolToolButton->setMapCanvas( context.mapCanvas() );
95 mDefaultSymbolToolButton->setMessageBar( context.messageBar() );
96 }
97}
98
100{
102 if ( QgsExpressionContext *expressionContext = mContext.expressionContext() )
103 context = *expressionContext;
104 else
106
107 const QList<QgsExpressionContextScope> scopes = mContext.additionalExpressionContextScopes();
108 for ( const QgsExpressionContextScope &s : scopes )
109 {
111 }
112 return context;
113}
@ FeatureSymbology
Provider is able retrieve embedded symbology associated with individual features.
GeometryType
The geometry types are used to group Qgis::WkbType in a coarse way.
Definition qgis.h:337
A widget used represent options of a QgsEmbeddedSymbolRenderer.
static QgsRendererWidget * create(QgsVectorLayer *layer, QgsStyle *style, QgsFeatureRenderer *renderer)
Static creation method.
QgsEmbeddedSymbolRendererWidget(QgsVectorLayer *layer, QgsStyle *style, QgsFeatureRenderer *renderer)
Constructor.
QgsExpressionContext createExpressionContext() const override
This method needs to be reimplemented in all classes which implement this interface and return an exp...
void setContext(const QgsSymbolWidgetContext &context) override
Sets the context in which the renderer widget is shown, e.g., the associated map canvas and expressio...
QgsFeatureRenderer * renderer() override
Returns pointer to the renderer (no transfer of ownership)
A vector feature renderer which uses embedded feature symbology to render per-feature symbols.
static QgsEmbeddedSymbolRenderer * convertFromRenderer(const QgsFeatureRenderer *renderer)
Creates a QgsEmbeddedSymbolRenderer from an existing renderer.
Single scope for storing variables and functions for use within a QgsExpressionContext.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
Abstract base class for all 2D vector feature renderers.
void copyRendererData(QgsFeatureRenderer *destRenderer) const
Clones generic renderer data to another renderer.
QString name
Definition qgsmaplayer.h:80
void widgetChanged()
Emitted when the widget state changes.
Base class for renderer settings widgets.
QgsSymbolWidgetContext mContext
Context in which widget is shown.
virtual void setContext(const QgsSymbolWidgetContext &context)
Sets the context in which the renderer widget is shown, e.g., the associated map canvas and expressio...
QgsSymbolWidgetContext context() const
Returns the context in which the renderer widget is shown, e.g., the associated map canvas and expres...
QgsVectorLayer * mLayer
void changed()
Emitted when the symbol's settings are changed.
Contains settings which reflect the context in which a symbol (or renderer) widget is shown,...
QList< QgsExpressionContextScope > additionalExpressionContextScopes() const
Returns the list of additional expression context scopes to show as available within the layer.
QList< QgsExpressionContextScope * > globalProjectAtlasMapLayerScopes(const QgsMapLayer *layer) const
Returns list of scopes: global, project, atlas, map, layer.
QgsExpressionContext * expressionContext() const
Returns the expression context used for the widget, if set.
QgsMapCanvas * mapCanvas() const
Returns the map canvas associated with the widget.
QgsMessageBar * messageBar() const
Returns the message bar associated with the widget.
static Qgis::SymbolType symbolTypeForGeometryType(Qgis::GeometryType type)
Returns the default symbol type required for the specified geometry type.
static QgsSymbol * defaultSymbol(Qgis::GeometryType geomType)
Returns a new default symbol for the specified geometry type.
virtual Q_INVOKABLE Qgis::VectorProviderCapabilities capabilities() const
Returns flags containing the supported capabilities.
Represents a vector layer which manages a vector based data sets.
Q_INVOKABLE Qgis::WkbType wkbType() const FINAL
Returns the WKBType or WKBUnknown in case of error.
QgsVectorDataProvider * dataProvider() FINAL
Returns the layer's data provider, it may be nullptr.
static Qgis::GeometryType geometryType(Qgis::WkbType type)
Returns the geometry type for a WKB type, e.g., both MultiPolygon and CurvePolygon would have a Polyg...