QGIS API Documentation  3.14.0-Pi (9f7028fd23)
All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Modules Pages
qgs25drenderer.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgs25drenderer.cpp - qgs25drenderer
3  -----------------------------------
4 
5  begin : 14.1.2016
6  Copyright : (C) 2016 Matthias Kuhn
7  Email : matthias at opengis dot ch
8  ***************************************************************************
9  * *
10  * This program is free software; you can redistribute it and/or modify *
11  * it under the terms of the GNU General Public License as published by *
12  * the Free Software Foundation; either version 2 of the License, or *
13  * (at your option) any later version. *
14  * *
15  ***************************************************************************/
16 #include "qgs25drenderer.h"
18 #include "qgsfillsymbollayer.h"
19 #include "qgspainteffect.h"
20 #include "qgseffectstack.h"
21 #include "qgsgloweffect.h"
22 #include "qgsproperty.h"
23 #include "qgssymbollayerutils.h"
25 #include "qgsstyleentityvisitor.h"
26 
27 #define ROOF_EXPRESSION \
28  "translate(" \
29  " $geometry," \
30  " cos( radians( eval( @qgis_25d_angle ) ) ) * eval( @qgis_25d_height )," \
31  " sin( radians( eval( @qgis_25d_angle ) ) ) * eval( @qgis_25d_height )" \
32  ")"
33 
34 #define WALL_EXPRESSION \
35  "order_parts( "\
36  " extrude(" \
37  " segments_to_lines( $geometry )," \
38  " cos( radians( eval( @qgis_25d_angle ) ) ) * eval( @qgis_25d_height )," \
39  " sin( radians( eval( @qgis_25d_angle ) ) ) * eval( @qgis_25d_height )" \
40  " )," \
41  " 'distance( $geometry, translate( @map_extent_center, 1000 * @map_extent_width * cos( radians( @qgis_25d_angle + 180 ) ), 1000 * @map_extent_width * sin( radians( @qgis_25d_angle + 180 ) ) ))'," \
42  " False" \
43  ")"
44 
45 #define ORDER_BY_EXPRESSION \
46  "distance(" \
47  " $geometry," \
48  " translate(" \
49  " @map_extent_center," \
50  " 1000 * @map_extent_width * cos( radians( @qgis_25d_angle + 180 ) )," \
51  " 1000 * @map_extent_width * sin( radians( @qgis_25d_angle + 180 ) )" \
52  " )" \
53  ")"
54 
55 #define WALL_SHADING_EXPRESSION \
56  "set_color_part( " \
57  " @symbol_color," \
58  " 'value'," \
59  " 40 + 19 * abs( $pi - azimuth( " \
60  " point_n( geometry_n($geometry, @geometry_part_num) , 1 ), " \
61  " point_n( geometry_n($geometry, @geometry_part_num) , 2 )" \
62  " ) ) " \
63  ")"
64 
66  : QgsFeatureRenderer( QStringLiteral( "25dRenderer" ) )
67 {
68  mSymbol.reset( new QgsFillSymbol() );
69 
70  mSymbol->deleteSymbolLayer( 0 ); // We never asked for the default layer
71 
73 
74  QgsStringMap wallProperties;
75  wallProperties.insert( QStringLiteral( "geometryModifier" ), WALL_EXPRESSION );
76  wallProperties.insert( QStringLiteral( "symbolType" ), QStringLiteral( "Fill" ) );
78 
79  QgsStringMap roofProperties;
80  roofProperties.insert( QStringLiteral( "geometryModifier" ), ROOF_EXPRESSION );
81  roofProperties.insert( QStringLiteral( "symbolType" ), QStringLiteral( "Fill" ) );
83 
84  floor->setLocked( true );
85 
86  mSymbol->appendSymbolLayer( floor );
87  mSymbol->appendSymbolLayer( walls );
88  mSymbol->appendSymbolLayer( roof );
89 
90  QgsEffectStack *effectStack = new QgsEffectStack();
91  QgsOuterGlowEffect *glowEffect = new QgsOuterGlowEffect();
92  glowEffect->setBlurLevel( 5 );
94  effectStack->appendEffect( glowEffect );
95  floor->setPaintEffect( effectStack );
96 
97  // These methods must only be used after the above initialization!
98 
99  setRoofColor( QColor( 177, 169, 124 ) );
100  setWallColor( QColor( 119, 119, 119 ) );
101 
103 
104  setShadowSpread( 4 );
105  setShadowColor( QColor( 17, 17, 17 ) );
106 
110  false );
111 
112  setOrderBy( orderBy );
113  setOrderByEnabled( true );
114 }
115 
116 QDomElement Qgs25DRenderer::save( QDomDocument &doc, const QgsReadWriteContext &context )
117 {
118  QDomElement rendererElem = doc.createElement( RENDERER_TAG_NAME );
119 
120  rendererElem.setAttribute( QStringLiteral( "type" ), QStringLiteral( "25dRenderer" ) );
121 
122  QDomElement symbolElem = QgsSymbolLayerUtils::saveSymbol( QStringLiteral( "symbol" ), mSymbol.get(), doc, context );
123 
124  rendererElem.appendChild( symbolElem );
125 
126  return rendererElem;
127 }
128 
129 QgsFeatureRenderer *Qgs25DRenderer::create( QDomElement &element, const QgsReadWriteContext &context )
130 {
131  Qgs25DRenderer *renderer = new Qgs25DRenderer();
132 
133  QDomNodeList symbols = element.elementsByTagName( QStringLiteral( "symbol" ) );
134  if ( symbols.size() )
135  {
136  renderer->mSymbol.reset( QgsSymbolLayerUtils::loadSymbol( symbols.at( 0 ).toElement(), context ) );
137  }
138 
139  return renderer;
140 }
141 
143 {
144  QgsFeatureRenderer::startRender( context, fields );
145 
146  mSymbol->startRender( context, fields );
147 }
148 
150 {
152 
153  mSymbol->stopRender( context );
154 }
155 
156 QSet<QString> Qgs25DRenderer::usedAttributes( const QgsRenderContext &context ) const
157 {
158  return mSymbol->usedAttributes( context );
159 }
160 
162 {
164  c->mSymbol.reset( mSymbol->clone() );
165  return c;
166 }
167 
169 {
170  Q_UNUSED( feature )
171  Q_UNUSED( context )
172  return mSymbol.get();
173 }
174 
176 {
177  Q_UNUSED( context )
178  QgsSymbolList lst;
179  lst.append( mSymbol.get() );
180  return lst;
181 }
182 
184 {
185  if ( mSymbol )
186  {
187  QgsStyleSymbolEntity entity( mSymbol.get() );
188  return visitor->visit( QgsStyleEntityVisitorInterface::StyleLeaf( &entity ) );
189  }
190  return true;
191 }
192 
193 QgsFillSymbolLayer *Qgs25DRenderer::roofLayer() const
194 {
195  return static_cast<QgsFillSymbolLayer *>( mSymbol->symbolLayer( 2 )->subSymbol()->symbolLayer( 0 ) );
196 }
197 
198 QgsFillSymbolLayer *Qgs25DRenderer::wallLayer() const
199 {
200  return static_cast<QgsFillSymbolLayer *>( mSymbol->symbolLayer( 1 )->subSymbol()->symbolLayer( 0 ) );
201 }
202 
203 QgsOuterGlowEffect *Qgs25DRenderer::glowEffect() const
204 {
205  QgsEffectStack *stack = static_cast<QgsEffectStack *>( mSymbol->symbolLayer( 0 )->paintEffect() );
206  return static_cast<QgsOuterGlowEffect *>( stack->effect( 0 ) );
207 }
208 
210 {
211  return glowEffect()->enabled();
212 }
213 
215 {
216  glowEffect()->setEnabled( value );
217 }
218 
220 {
221  return glowEffect()->color();
222 }
223 
224 void Qgs25DRenderer::setShadowColor( const QColor &shadowColor )
225 {
226  glowEffect()->setColor( shadowColor );
227 }
228 
230 {
231  return glowEffect()->spread();
232 }
233 
234 void Qgs25DRenderer::setShadowSpread( double spread )
235 {
236  glowEffect()->setSpread( spread );
237 }
238 
240 {
241  return wallLayer()->fillColor();
242 }
243 
244 void Qgs25DRenderer::setWallColor( const QColor &wallColor )
245 {
246  wallLayer()->setFillColor( wallColor );
247  wallLayer()->setStrokeColor( wallColor );
248 }
249 
251 {
253 }
254 
256 {
258 }
259 
261 {
262  return roofLayer()->fillColor();
263 }
264 
265 void Qgs25DRenderer::setRoofColor( const QColor &roofColor )
266 {
267  roofLayer()->setFillColor( roofColor );
268  roofLayer()->setStrokeColor( roofColor );
269 }
270 
272 {
273  if ( renderer->type() == QLatin1String( "25dRenderer" ) )
274  {
275  return static_cast<Qgs25DRenderer *>( renderer->clone() );
276  }
277  else
278  {
279  return new Qgs25DRenderer();
280  }
281 }
282 
ORDER_BY_EXPRESSION
#define ORDER_BY_EXPRESSION
Definition: qgs25drenderer.cpp:45
Qgs25DRenderer::setShadowEnabled
void setShadowEnabled(bool value)
Enable or disable the shadow.
Definition: qgs25drenderer.cpp:214
QgsProperty::isActive
bool isActive() const
Returns whether the property is currently active.
Definition: qgsproperty.cpp:266
Qgs25DRenderer::setShadowSpread
void setShadowSpread(double shadowSpread)
Set the shadow's spread distance in map units.
Definition: qgs25drenderer.cpp:234
QgsFeatureRequest::OrderByClause
Definition: qgsfeaturerequest.h:142
QgsSimpleFillSymbolLayer::create
static QgsSymbolLayer * create(const QgsStringMap &properties=QgsStringMap())
Creates a new QgsSimpleFillSymbolLayer using the specified properties map containing symbol propertie...
Definition: qgsfillsymbollayer.cpp:150
Qgs25DRenderer::symbolForFeature
QgsSymbol * symbolForFeature(const QgsFeature &feature, QgsRenderContext &context) const override
To be overridden.
Definition: qgs25drenderer.cpp:168
QgsSymbolLayer::dataDefinedProperties
QgsPropertyCollection & dataDefinedProperties()
Returns a reference to the symbol layer's property collection, used for data defined overrides.
Definition: qgssymbollayer.h:480
QgsReadWriteContext
Definition: qgsreadwritecontext.h:34
Qgs25DRenderer::setRoofColor
void setRoofColor(const QColor &roofColor)
Set the roof color.
Definition: qgs25drenderer.cpp:265
QgsFeatureRenderer::setOrderByEnabled
void setOrderByEnabled(bool enabled)
Sets whether custom ordering should be applied before features are processed by this renderer.
Definition: qgsrenderer.cpp:450
Qgs25DRenderer::usedAttributes
QSet< QString > usedAttributes(const QgsRenderContext &context) const override
Returns a list of attributes required by this renderer.
Definition: qgs25drenderer.cpp:156
QgsStyleSymbolEntity
Definition: qgsstyle.h:1134
QgsGlowEffect::color
QColor color() const
Returns the color for the glow.
Definition: qgsgloweffect.h:204
Qgs25DRenderer::Qgs25DRenderer
Qgs25DRenderer()
Definition: qgs25drenderer.cpp:65
QgsSymbolLayer::PropertyFillColor
@ PropertyFillColor
Fill color.
Definition: qgssymbollayer.h:135
QgsGlowEffect::setBlurLevel
void setBlurLevel(const double level)
Sets blur level (radius) for the glow.
Definition: qgsgloweffect.h:119
qgssymbollayerutils.h
QgsFields
Definition: qgsfields.h:44
QgsFeatureRenderer::type
QString type() const
Definition: qgsrenderer.h:141
Qgs25DRenderer
Definition: qgs25drenderer.h:28
QgsRenderContext
Definition: qgsrendercontext.h:57
QgsStyleEntityVisitorInterface
Definition: qgsstyleentityvisitor.h:33
Qgs25DRenderer::roofColor
QColor roofColor() const
Gets the roof color.
Definition: qgs25drenderer.cpp:260
Qgs25DRenderer::shadowSpread
double shadowSpread() const
Gets the shadow's spread distance in map units.
Definition: qgs25drenderer.cpp:229
QgsSymbol
Definition: qgssymbol.h:63
QgsProperty::fromExpression
static QgsProperty fromExpression(const QString &expression, bool isActive=true)
Returns a new ExpressionBasedProperty created from the specified expression.
Definition: qgsproperty.cpp:212
qgspainteffect.h
Qgs25DRenderer::setWallColor
void setWallColor(const QColor &wallColor)
Set the wall color.
Definition: qgs25drenderer.cpp:244
ROOF_EXPRESSION
#define ROOF_EXPRESSION
Definition: qgs25drenderer.cpp:27
QgsStyleEntityVisitorInterface::StyleLeaf
Contains information relating to the style entity currently being visited.
Definition: qgsstyleentityvisitor.h:60
WALL_EXPRESSION
#define WALL_EXPRESSION
Definition: qgs25drenderer.cpp:34
QgsFeatureRenderer::stopRender
virtual void stopRender(QgsRenderContext &context)
Must be called when a render cycle has finished, to allow the renderer to clean up.
Definition: qgsrenderer.cpp:107
QgsProperty::setActive
void setActive(bool active)
Sets whether the property is currently active.
Definition: qgsproperty.cpp:271
QgsPropertyCollection::property
QgsProperty property(int key) const override
Returns a matching property from the collection, if one exists.
Definition: qgspropertycollection.cpp:204
QgsFeatureRenderer::orderBy
QgsFeatureRequest::OrderBy orderBy() const
Gets the order in which features shall be processed by this renderer.
Definition: qgsrenderer.cpp:435
QgsSymbolLayer::setFillColor
virtual void setFillColor(const QColor &color)
Set fill color.
Definition: qgssymbollayer.h:246
Qgs25DRenderer::save
QDomElement save(QDomDocument &doc, const QgsReadWriteContext &context) override
store renderer info to XML element
Definition: qgs25drenderer.cpp:116
QgsSymbolLayer
Definition: qgssymbollayer.h:52
QgsSymbolList
QList< QgsSymbol * > QgsSymbolList
Definition: qgsrenderer.h:45
Qgs25DRenderer::shadowEnabled
bool shadowEnabled() const
Is the shadow enabled.
Definition: qgs25drenderer.cpp:209
QgsFeatureRenderer::clone
virtual QgsFeatureRenderer * clone() const =0
Create a deep copy of this renderer.
QgsEffectStack::effect
QgsPaintEffect * effect(int index) const
Returns a pointer to the effect at a specified index within the stack.
Definition: qgseffectstack.cpp:258
Qgs25DRenderer::wallShadingEnabled
bool wallShadingEnabled() const
Gets wall shading enabled.
Definition: qgs25drenderer.cpp:255
QgsGlowEffect::setSpreadUnit
void setSpreadUnit(const QgsUnitTypes::RenderUnit unit)
Sets the units used for the glow spread distance.
Definition: qgsgloweffect.h:82
Qgs25DRenderer::create
static QgsFeatureRenderer * create(QDomElement &element, const QgsReadWriteContext &context)
Create a new 2.5D renderer from XML.
Definition: qgs25drenderer.cpp:129
qgsgloweffect.h
RENDERER_TAG_NAME
#define RENDERER_TAG_NAME
Definition: qgsrenderer.h:51
Qgs25DRenderer::symbols
QgsSymbolList symbols(QgsRenderContext &context) const override
Returns list of symbols used by the renderer.
Definition: qgs25drenderer.cpp:175
Qgs25DRenderer::setShadowColor
void setShadowColor(const QColor &shadowColor)
Set the shadow's color.
Definition: qgs25drenderer.cpp:224
QgsSymbolLayer::setPaintEffect
void setPaintEffect(QgsPaintEffect *effect)
Sets the current paint effect for the layer.
Definition: qgssymbollayer.cpp:190
QgsSymbolLayerUtils::loadSymbol
static QgsSymbol * loadSymbol(const QDomElement &element, const QgsReadWriteContext &context)
Attempts to load a symbol from a DOM element.
Definition: qgssymbollayerutils.cpp:1041
qgs25drenderer.h
qgseffectstack.h
qgsfillsymbollayer.h
QgsGlowEffect::setColor
void setColor(const QColor &color)
Sets the color for the glow.
Definition: qgsgloweffect.h:194
QgsPaintEffect::setEnabled
void setEnabled(bool enabled)
Sets whether the effect is enabled.
Definition: qgspainteffect.cpp:44
QgsGlowEffect::setSpread
void setSpread(const double spread)
Sets the spread distance for drawing the glow effect.
Definition: qgsgloweffect.h:64
QgsSymbolLayer::fillColor
virtual QColor fillColor() const
Gets fill color.
Definition: qgssymbollayer.h:251
Qgs25DRenderer::wallColor
QColor wallColor() const
Gets the wall color.
Definition: qgs25drenderer.cpp:239
Qgs25DRenderer::convertFromRenderer
static Qgs25DRenderer * convertFromRenderer(QgsFeatureRenderer *renderer)
Try to convert from an existing renderer.
Definition: qgs25drenderer.cpp:271
QgsStringMap
QMap< QString, QString > QgsStringMap
Definition: qgis.h:714
WALL_SHADING_EXPRESSION
#define WALL_SHADING_EXPRESSION
Definition: qgs25drenderer.cpp:55
QgsFeatureRenderer
Definition: qgsrenderer.h:102
Qgs25DRenderer::accept
bool accept(QgsStyleEntityVisitorInterface *visitor) const override
Accepts the specified symbology visitor, causing it to visit all symbols associated with the renderer...
Definition: qgs25drenderer.cpp:183
QgsFeatureRequest::OrderBy
Definition: qgsfeaturerequest.h:242
c
As part of the API refactoring and improvements which landed in the Processing API was substantially reworked from the x version This was done in order to allow much of the underlying Processing framework to be ported into c
Definition: porting_processing.dox:1
QgsSymbolLayer::setStrokeColor
virtual void setStrokeColor(const QColor &color)
Set stroke color.
Definition: qgssymbollayer.h:236
QgsEffectStack::appendEffect
void appendEffect(QgsPaintEffect *effect)
Appends an effect to the end of the stack.
Definition: qgseffectstack.cpp:217
QgsFillSymbolLayer
Definition: qgssymbollayer.h:1092
QgsOuterGlowEffect
A paint effect which draws a glow outside of a picture.
Definition: qgsgloweffect.h:299
Qgs25DRenderer::startRender
void startRender(QgsRenderContext &context, const QgsFields &fields) override
Must be called when a new render cycle is started.
Definition: qgs25drenderer.cpp:142
QgsFillSymbol
Definition: qgssymbol.h:1212
qgsproperty.h
QgsSymbolLayer::setLocked
void setLocked(bool locked)
Definition: qgssymbollayer.h:358
QgsStyleEntityVisitorInterface::visit
virtual bool visit(const QgsStyleEntityVisitorInterface::StyleLeaf &entity)
Called when the visitor will visit a style entity.
Definition: qgsstyleentityvisitor.h:153
QgsFeatureRenderer::setOrderBy
void setOrderBy(const QgsFeatureRequest::OrderBy &orderBy)
Define the order in which features shall be processed by this renderer.
Definition: qgsrenderer.cpp:440
Qgs25DRenderer::setWallShadingEnabled
void setWallShadingEnabled(bool enabled)
Set wall shading enabled.
Definition: qgs25drenderer.cpp:250
QgsFeature
Definition: qgsfeature.h:55
qgsdatadefinedsizelegend.h
QgsGeometryGeneratorSymbolLayer::create
static QgsSymbolLayer * create(const QgsStringMap &properties)
Definition: qgsgeometrygeneratorsymbollayer.cpp:21
qgsgeometrygeneratorsymbollayer.h
Qgs25DRenderer::clone
QgsFeatureRenderer * clone() const override
Create a deep copy of this renderer.
Definition: qgs25drenderer.cpp:161
QgsPaintEffect::enabled
bool enabled() const
Returns whether the effect is enabled.
Definition: qgspainteffect.h:198
Qgs25DRenderer::shadowColor
QColor shadowColor() const
Gets the shadow's color.
Definition: qgs25drenderer.cpp:219
QgsFeatureRenderer::startRender
virtual void startRender(QgsRenderContext &context, const QgsFields &fields)
Must be called when a new render cycle is started.
Definition: qgsrenderer.cpp:93
QgsSymbolLayerUtils::saveSymbol
static QDomElement saveSymbol(const QString &symbolName, const QgsSymbol *symbol, QDomDocument &doc, const QgsReadWriteContext &context)
Writes a symbol definition to XML.
Definition: qgssymbollayerutils.cpp:1180
QgsUnitTypes::RenderMapUnits
@ RenderMapUnits
Map units.
Definition: qgsunittypes.h:169
QgsGlowEffect::spread
double spread() const
Returns the spread distance used for drawing the glow effect.
Definition: qgsgloweffect.h:73
QgsSymbolLayer::setDataDefinedProperty
virtual void setDataDefinedProperty(Property key, const QgsProperty &property)
Sets a data defined property for the layer.
Definition: qgssymbollayer.cpp:112
qgsstyleentityvisitor.h
Qgs25DRenderer::stopRender
void stopRender(QgsRenderContext &context) override
Must be called when a render cycle has finished, to allow the renderer to clean up.
Definition: qgs25drenderer.cpp:149
QgsEffectStack
A paint effect which consists of a stack of other chained paint effects.
Definition: qgseffectstack.h:44