QGIS API Documentation 3.99.0-Master (8e76e220402)
Loading...
Searching...
No Matches
qgsmaplayerlegend.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsmaplayerlegend.cpp
3 --------------------------------------
4 Date : July 2014
5 Copyright : (C) 2014 by Martin Dobias
6 Email : wonder dot sk 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 ***************************************************************************/
15
16#include "qgsmaplayerlegend.h"
17
19#include "qgsdiagramrenderer.h"
20#include "qgsiconutils.h"
21#include "qgsimagecache.h"
22#include "qgslayertree.h"
24#include "qgsmeshlayer.h"
25#include "qgspluginlayer.h"
26#include "qgspointcloudlayer.h"
28#include "qgsrasterlayer.h"
29#include "qgsrasterrenderer.h"
30#include "qgsrenderer.h"
32#include "qgssettings.h"
33#include "qgssymbollayerutils.h"
34#include "qgsvectorlayer.h"
36
37#include <QString>
38
39#include "moc_qgsmaplayerlegend.cpp"
40
41using namespace Qt::StringLiterals;
42
44 : QObject( parent )
45{
46}
47
48void QgsMapLayerLegend::readXml( const QDomElement &elem, const QgsReadWriteContext & )
49{
51 mFlags.setFlag( Qgis::MapLayerLegendFlag::ExcludeByDefault, elem.attribute( u"excludeByDefault"_s, u"0"_s ).toInt() == 1 );
52}
53
54QDomElement QgsMapLayerLegend::writeXml( QDomDocument &doc, const QgsReadWriteContext & ) const
55{
56 QDomElement elem = doc.createElement( u"legend"_s );
57 if ( mFlags.testFlag( Qgis::MapLayerLegendFlag::ExcludeByDefault ) )
58 {
59 elem.setAttribute( u"excludeByDefault"_s, u"1"_s );
60 }
61 return elem;
62}
63
68
73
78
83
84// -------------------------------------------------------------------------
85
86
87void QgsMapLayerLegendUtils::setLegendNodeOrder( QgsLayerTreeLayer *nodeLayer, const QList<int> &order )
88{
89 QStringList orderStr;
90 const auto constOrder = order;
91 for ( const int id : constOrder )
92 orderStr << QString::number( id );
93 const QString str = orderStr.isEmpty() ? u"empty"_s : orderStr.join( ','_L1 );
94
95 nodeLayer->setCustomProperty( u"legend/node-order"_s, str );
96}
97
98static int _originalLegendNodeCount( QgsLayerTreeLayer *nodeLayer )
99{
100 // this is not particularly efficient way of finding out number of legend nodes
101 const QList<QgsLayerTreeModelLegendNode *> lst = nodeLayer->layer()->legend()->createLayerTreeModelLegendNodes( nodeLayer );
102 const int numNodes = lst.count();
103 qDeleteAll( lst );
104 return numNodes;
105}
106
107static QList<int> _makeNodeOrder( QgsLayerTreeLayer *nodeLayer )
108{
109 if ( !nodeLayer->layer() || !nodeLayer->layer()->legend() )
110 {
111 QgsDebugError( u"Legend node order manipulation is invalid without existing legend"_s );
112 return QList<int>();
113 }
114
115 const int numNodes = _originalLegendNodeCount( nodeLayer );
116
117 QList<int> order;
118 order.reserve( numNodes );
119 for ( int i = 0; i < numNodes; ++i )
120 order << i;
121 return order;
122}
123
125{
126 const QString orderStr = nodeLayer->customProperty( u"legend/node-order"_s ).toString();
127
128 if ( orderStr.isEmpty() )
129 return _makeNodeOrder( nodeLayer );
130
131 if ( orderStr == "empty"_L1 )
132 return QList<int>();
133
134 const int numNodes = _originalLegendNodeCount( nodeLayer );
135
136 QList<int> lst;
137 const auto constSplit = orderStr.split( ',' );
138 for ( const QString &item : constSplit )
139 {
140 bool ok;
141 const int id = item.toInt( &ok );
142 if ( !ok || id < 0 || id >= numNodes )
143 return _makeNodeOrder( nodeLayer );
144
145 lst << id;
146 }
147
148 return lst;
149}
150
152{
153 return nodeLayer->customProperties().contains( u"legend/node-order"_s );
154}
155
156void QgsMapLayerLegendUtils::setLegendNodeUserLabel( QgsLayerTreeLayer *nodeLayer, int originalIndex, const QString &newLabel )
157{
158 nodeLayer->setCustomProperty( "legend/label-" + QString::number( originalIndex ), newLabel );
159}
160
162{
163 return nodeLayer->customProperty( "legend/label-" + QString::number( originalIndex ) ).toString();
164}
165
167{
168 return nodeLayer->customProperties().contains( "legend/label-" + QString::number( originalIndex ) );
169}
170
172{
173 QDomDocument patchDoc;
174 QDomElement patchElem = patchDoc.createElement( u"patch"_s );
175 shape.writeXml( patchElem, patchDoc, QgsReadWriteContext() );
176 patchDoc.appendChild( patchElem );
177 nodeLayer->setCustomProperty( "legend/patch-shape-" + QString::number( originalIndex ), patchDoc.toString() );
178}
179
181{
182 const QString patchDef = nodeLayer->customProperty( "legend/patch-shape-" + QString::number( originalIndex ) ).toString();
183 if ( patchDef.isEmpty() )
184 return QgsLegendPatchShape();
185
186 QDomDocument doc( u"patch"_s );
187 doc.setContent( patchDef );
189 shape.readXml( doc.documentElement(), QgsReadWriteContext() );
190 return shape;
191}
192
193void QgsMapLayerLegendUtils::setLegendNodeSymbolSize( QgsLayerTreeLayer *nodeLayer, int originalIndex, QSizeF size )
194{
195 if ( size.isValid() )
196 nodeLayer->setCustomProperty( "legend/symbol-size-" + QString::number( originalIndex ), QgsSymbolLayerUtils::encodeSize( size ) );
197 else
198 nodeLayer->removeCustomProperty( "legend/symbol-size-" + QString::number( originalIndex ) );
199}
200
202{
203 const QString size = nodeLayer->customProperty( "legend/symbol-size-" + QString::number( originalIndex ) ).toString();
204 if ( size.isEmpty() )
205 return QSizeF();
206 else
207 return QgsSymbolLayerUtils::decodeSize( size );
208}
209
210void QgsMapLayerLegendUtils::setLegendNodeCustomSymbol( QgsLayerTreeLayer *nodeLayer, int originalIndex, const QgsSymbol *symbol )
211{
212 if ( symbol )
213 {
214 QDomDocument doc;
215 QgsReadWriteContext rwContext;
216 rwContext.setPathResolver( QgsProject::instance()->pathResolver() ); // skip-keyword-check
217 const QDomElement elem = QgsSymbolLayerUtils::saveSymbol( u"custom symbol"_s, symbol, doc, rwContext );
218 doc.appendChild( elem );
219 nodeLayer->setCustomProperty( "legend/custom-symbol-" + QString::number( originalIndex ), doc.toString() );
220 }
221 else
222 nodeLayer->removeCustomProperty( "legend/custom-symbol-" + QString::number( originalIndex ) );
223}
224
225std::unique_ptr< QgsSymbol > QgsMapLayerLegendUtils::legendNodeCustomSymbol( QgsLayerTreeLayer *nodeLayer, int originalIndex )
226{
227 const QString symbolDef = nodeLayer->customProperty( "legend/custom-symbol-" + QString::number( originalIndex ) ).toString();
228 if ( symbolDef.isEmpty() )
229 return nullptr;
230
231 QDomDocument doc;
232 doc.setContent( symbolDef );
233 const QDomElement elem = doc.documentElement();
234
235 QgsReadWriteContext rwContext;
236 rwContext.setPathResolver( QgsProject::instance()->pathResolver() ); // skip-keyword-check
237
238 return QgsSymbolLayerUtils::loadSymbol( elem, rwContext );
239}
240
242{
243 if ( settings )
244 {
245 QDomDocument doc;
246 QgsReadWriteContext rwContext;
247 rwContext.setPathResolver( QgsProject::instance()->pathResolver() ); // skip-keyword-check
248 QDomElement elem = doc.createElement( u"rampSettings"_s );
249 settings->writeXml( doc, elem, rwContext );
250 doc.appendChild( elem );
251 nodeLayer->setCustomProperty( "legend/custom-ramp-settings-" + QString::number( originalIndex ), doc.toString() );
252 }
253 else
254 nodeLayer->removeCustomProperty( "legend/custom-ramp-settings-" + QString::number( originalIndex ) );
255}
256
258{
259 const QString settingsDef = nodeLayer->customProperty( "legend/custom-ramp-settings-" + QString::number( originalIndex ) ).toString();
260 if ( settingsDef.isEmpty() )
261 return nullptr;
262
263 QDomDocument doc;
264 doc.setContent( settingsDef );
265 const QDomElement elem = doc.documentElement();
266
267 QgsReadWriteContext rwContext;
268 rwContext.setPathResolver( QgsProject::instance()->pathResolver() ); // skip-keyword-check
269
271 settings.readXml( elem, rwContext );
272 return new QgsColorRampLegendNodeSettings( std::move( settings ) );
273}
274
275void QgsMapLayerLegendUtils::setLegendNodeColumnBreak( QgsLayerTreeLayer *nodeLayer, int originalIndex, bool columnBreakBeforeNode )
276{
277 if ( columnBreakBeforeNode )
278 nodeLayer->setCustomProperty( "legend/column-break-" + QString::number( originalIndex ), u"1"_s );
279 else
280 nodeLayer->removeCustomProperty( "legend/column-break-" + QString::number( originalIndex ) );
281}
282
284{
285 return nodeLayer->customProperty( "legend/column-break-" + QString::number( originalIndex ) ).toInt();
286}
287
288void QgsMapLayerLegendUtils::applyLayerNodeProperties( QgsLayerTreeLayer *nodeLayer, QList<QgsLayerTreeModelLegendNode *> &nodes )
289{
290 // handle user labels
291 int i = 0;
292 const auto constNodes = nodes;
293 for ( QgsLayerTreeModelLegendNode *legendNode : constNodes )
294 {
295 const QString userLabel = QgsMapLayerLegendUtils::legendNodeUserLabel( nodeLayer, i );
296 if ( !userLabel.isNull() )
297 legendNode->setUserLabel( userLabel );
298
299 if ( QgsSymbolLegendNode *symbolNode = dynamic_cast< QgsSymbolLegendNode * >( legendNode ) )
300 {
302 symbolNode->setPatchShape( shape );
303
304 symbolNode->setCustomSymbol( QgsMapLayerLegendUtils::legendNodeCustomSymbol( nodeLayer, i ).release() );
305 }
306 else if ( QgsColorRampLegendNode *colorRampNode = dynamic_cast< QgsColorRampLegendNode * >( legendNode ) )
307 {
308 const std::unique_ptr< QgsColorRampLegendNodeSettings > settings( QgsMapLayerLegendUtils::legendNodeColorRampSettings( nodeLayer, i ) );
309 if ( settings )
310 {
311 colorRampNode->setSettings( *settings );
312 }
313 }
314
315 const QSizeF userSize = QgsMapLayerLegendUtils::legendNodeSymbolSize( nodeLayer, i );
316 if ( userSize.isValid() )
317 {
318 legendNode->setUserPatchSize( userSize );
319 }
320
321 if ( legendNodeColumnBreak( nodeLayer, i ) )
322 legendNode->setColumnBreak( true );
323
324 i++;
325 }
326
327 // handle user order of nodes
329 {
330 const QList<int> order = QgsMapLayerLegendUtils::legendNodeOrder( nodeLayer );
331
332 QList<QgsLayerTreeModelLegendNode *> newOrder;
333 QSet<int> usedIndices;
334 const auto constOrder = order;
335 for ( const int idx : constOrder )
336 {
337 if ( usedIndices.contains( idx ) )
338 {
339 QgsDebugError( u"invalid node order. ignoring."_s );
340 return;
341 }
342
343 newOrder << nodes[idx];
344 usedIndices << idx;
345 }
346
347 // delete unused nodes
348 for ( int i = 0; i < nodes.count(); ++i )
349 {
350 if ( !usedIndices.contains( i ) )
351 delete nodes[i];
352 }
353
354 nodes = newOrder;
355 }
356
357}
358
359// -------------------------------------------------------------------------
360
361
368
370{
371 QList<QgsLayerTreeModelLegendNode *> nodes;
372 if ( !mLayer )
373 return nodes;
374
375 const QString placeholderImage = mLayer->legendPlaceholderImage();
376 if ( !placeholderImage.isEmpty() )
377 {
378 bool fitsInCache;
379 const QImage img = QgsApplication::imageCache()->pathAsImage( placeholderImage, QSize(), false, 1.0, fitsInCache );
380 nodes << new QgsImageLegendNode( nodeLayer, img );
381 return nodes;
382 }
383
384 QgsFeatureRenderer *r = mLayer->renderer();
385 if ( !r )
386 return nodes;
387
388 if ( nodeLayer->customProperty( u"showFeatureCount"_s, 0 ).toBool() )
389 mLayer->countSymbolFeatures();
390
391 const QgsSettings settings;
392 if ( settings.value( u"qgis/showLegendClassifiers"_s, false ).toBool() && !r->legendClassificationAttribute().isEmpty() )
393 {
394 nodes.append( new QgsSimpleLegendNode( nodeLayer, r->legendClassificationAttribute() ) );
395 }
396
397 const QList<QgsLayerTreeModelLegendNode *> rendererNodes = r->createLegendNodes( nodeLayer );
398 for ( QgsLayerTreeModelLegendNode *node : rendererNodes )
399 {
400 if ( QgsSymbolLegendNode *legendNode = qobject_cast< QgsSymbolLegendNode *>( node ) )
401 {
402 const QString ruleKey = legendNode->data( static_cast< int >( QgsLayerTreeModelLegendNode::CustomRole::RuleKey ) ).toString();
403 if ( mTextOnSymbolEnabled && mTextOnSymbolContent.contains( ruleKey ) )
404 {
405 legendNode->setTextOnSymbolLabel( mTextOnSymbolContent.value( ruleKey ) );
406 legendNode->setTextOnSymbolTextFormat( mTextOnSymbolTextFormat );
407 }
408 }
409 nodes << node;
410 }
411
412 if ( nodes.count() == 1 && nodes[0]->data( Qt::EditRole ).toString().isEmpty() && qobject_cast< QgsSymbolLegendNode * >( nodes[0] ) )
413 nodes[0]->setEmbeddedInParent( true );
414
415 if ( mLayer->diagramsEnabled() )
416 {
417 const auto constLegendItems = mLayer->diagramRenderer()->legendItems( nodeLayer );
418 for ( QgsLayerTreeModelLegendNode *i : constLegendItems )
419 {
420 nodes.append( i );
421 }
422 }
423
424 if ( mLayer->labelsEnabled() && mShowLabelLegend )
425 {
426 const QgsAbstractVectorLayerLabeling *labeling = mLayer->labeling();
427 if ( labeling )
428 {
429 const QStringList pList = labeling->subProviders();
430 for ( int i = 0; i < pList.size(); ++i )
431 {
432 const QgsPalLayerSettings s = labeling->settings( pList.at( i ) );
433 QString description;
434 const QgsRuleBasedLabeling *ruleBasedLabeling = dynamic_cast<const QgsRuleBasedLabeling *>( labeling );
435 if ( ruleBasedLabeling && ruleBasedLabeling->rootRule() )
436 {
437 const QgsRuleBasedLabeling::Rule *rule = ruleBasedLabeling->rootRule()->findRuleByKey( pList.at( i ) );
438 if ( rule )
439 {
440 description = rule->description();
441 }
442 }
443 QgsVectorLabelLegendNode *node = new QgsVectorLabelLegendNode( nodeLayer, s );
444 node->setUserLabel( description );
445 nodes.append( node );
446 }
447 }
448 }
449
450 return nodes;
451}
452
453void QgsDefaultVectorLayerLegend::readXml( const QDomElement &elem, const QgsReadWriteContext &context )
454{
455 QgsMapLayerLegend::readXml( elem, context );
456
457 mTextOnSymbolEnabled = false;
458 mTextOnSymbolTextFormat = QgsTextFormat();
459 mTextOnSymbolContent.clear();
460
461 mShowLabelLegend = elem.attribute( u"showLabelLegend"_s, u"0"_s ).compare( u"1"_s, Qt::CaseInsensitive ) == 0;
462
463 const QDomElement tosElem = elem.firstChildElement( u"text-on-symbol"_s );
464 if ( !tosElem.isNull() )
465 {
466 mTextOnSymbolEnabled = true;
467 const QDomElement tosFormatElem = tosElem.firstChildElement( u"text-style"_s );
468 mTextOnSymbolTextFormat.readXml( tosFormatElem, context );
469 const QDomElement tosContentElem = tosElem.firstChildElement( u"content"_s );
470 QDomElement tosContentItemElem = tosContentElem.firstChildElement( u"item"_s );
471 while ( !tosContentItemElem.isNull() )
472 {
473 mTextOnSymbolContent.insert( tosContentItemElem.attribute( u"key"_s ), tosContentItemElem.attribute( u"value"_s ) );
474 tosContentItemElem = tosContentItemElem.nextSiblingElement( u"item"_s );
475 }
476 }
477}
478
479QDomElement QgsDefaultVectorLayerLegend::writeXml( QDomDocument &doc, const QgsReadWriteContext &context ) const
480{
481 QDomElement elem = QgsMapLayerLegend::writeXml( doc, context );
482 elem.setAttribute( u"type"_s, u"default-vector"_s );
483 elem.setAttribute( u"showLabelLegend"_s, mShowLabelLegend );
484
485 if ( mTextOnSymbolEnabled )
486 {
487 QDomElement tosElem = doc.createElement( u"text-on-symbol"_s );
488 const QDomElement tosFormatElem = mTextOnSymbolTextFormat.writeXml( doc, context );
489 tosElem.appendChild( tosFormatElem );
490 QDomElement tosContentElem = doc.createElement( u"content"_s );
491 for ( auto it = mTextOnSymbolContent.constBegin(); it != mTextOnSymbolContent.constEnd(); ++it )
492 {
493 QDomElement tosContentItemElem = doc.createElement( u"item"_s );
494 tosContentItemElem.setAttribute( u"key"_s, it.key() );
495 tosContentItemElem.setAttribute( u"value"_s, it.value() );
496 tosContentElem.appendChild( tosContentItemElem );
497 }
498 tosElem.appendChild( tosContentElem );
499 elem.appendChild( tosElem );
500 }
501
502 return elem;
503}
504
505
506// -------------------------------------------------------------------------
507
508
514
516{
517 QList<QgsLayerTreeModelLegendNode *> nodes;
518
519 // temporary solution for WMS. Ideally should be done with a delegate.
520 if ( mLayer->dataProvider() && mLayer->dataProvider()->supportsLegendGraphic() )
521 {
522 nodes << new QgsWmsLegendNode( nodeLayer );
523 }
524
525 const QString placeholderImage = mLayer->legendPlaceholderImage();
526 if ( !placeholderImage.isEmpty() )
527 {
528 bool fitsInCache;
529 const QImage img = QgsApplication::imageCache()->pathAsImage( placeholderImage, QSize(), false, 1.0, fitsInCache );
530 nodes << new QgsImageLegendNode( nodeLayer, img );
531 }
532 else if ( mLayer->renderer() )
533 nodes.append( mLayer->renderer()->createLegendNodes( nodeLayer ) );
534 return nodes;
535}
536
537// -------------------------------------------------------------------------
538
544
546{
547 QList<QgsLayerTreeModelLegendNode *> nodes;
548
549 const QgsMeshRendererSettings rendererSettings = mLayer->rendererSettings();
550
551 const int indexScalar = rendererSettings.activeScalarDatasetGroup();
552 const int indexVector = rendererSettings.activeVectorDatasetGroup();
553
554 QString name;
555 if ( indexScalar > -1 && indexVector > -1 && indexScalar != indexVector )
556 name = QString( "%1 / %2" ).arg( mLayer->datasetGroupMetadata( indexScalar ).name(), mLayer->datasetGroupMetadata( indexVector ).name() );
557 else if ( indexScalar > -1 )
558 name = mLayer->datasetGroupMetadata( indexScalar ).name();
559 else if ( indexVector > -1 )
560 name = mLayer->datasetGroupMetadata( indexVector ).name();
561 else
562 {
563 // neither contours nor vectors get rendered - no legend needed
564 return nodes;
565 }
566
567 if ( indexScalar > -1 )
568 {
569 const QString scalarNameKey = u"scalarName"_s;
570 nodes << new QgsSimpleLegendNode( nodeLayer, mLayer->datasetGroupMetadata( indexScalar ).name(),
571 QIcon(), nullptr, scalarNameKey );
572 const QgsMeshRendererScalarSettings settings = rendererSettings.scalarSettings( indexScalar );
573 const QgsColorRampShader shader = settings.colorRampShader();
574 switch ( shader.colorRampType() )
575 {
577 if ( !shader.legendSettings() || shader.legendSettings()->useContinuousLegend() )
578 {
579 // for interpolated shaders we use a ramp legend node
580 if ( !shader.colorRampItemList().isEmpty() )
581 {
582 nodes << new QgsColorRampLegendNode( nodeLayer, shader.createColorRamp(),
584 shader.minimumValue(),
585 shader.maximumValue(),
586 nullptr,
587 u"scalarLegend"_s,
588 scalarNameKey );
589 }
590 break;
591 }
592 [[fallthrough]];
595 {
596 // for all others we use itemised lists
597 QgsLegendColorList items;
598 settings.colorRampShader().legendSymbologyItems( items );
599 for ( const QPair< QString, QColor > &item : items )
600 {
601 nodes << new QgsRasterSymbolLegendNode( nodeLayer, item.second, item.first, nullptr, false,
602 u"scalarLegend"_s + QUuid::createUuid().toString(),
603 scalarNameKey
604 );
605 }
606 break;
607 }
608 }
609 }
610
611 if ( indexVector > -1 )
612 {
613 const QgsMeshRendererVectorSettings settings = rendererSettings.vectorSettings( indexVector );
614 const QString vectorNameKey = u"vectorName"_s;
615 switch ( settings.coloringMethod() )
616 {
618 {
619 const QColor arrowColor = settings.color();
620 const QIcon vectorIcon = QgsApplication::getThemeIcon( u"/propertyicons/meshvectors.svg"_s, arrowColor, arrowColor );
621 nodes << new QgsSimpleLegendNode( nodeLayer, mLayer->datasetGroupMetadata( indexVector ).name(),
622 vectorIcon, nullptr, vectorNameKey );
623 break;
624 }
626 {
627 const QIcon vectorIcon = QgsApplication::getThemeIcon( u"/propertyicons/meshvectors.svg"_s );
628 nodes << new QgsSimpleLegendNode( nodeLayer, mLayer->datasetGroupMetadata( indexVector ).name(),
629 vectorIcon, nullptr, vectorNameKey );
630 const QgsColorRampShader shader = settings.colorRampShader();
631 switch ( shader.colorRampType() )
632 {
634 if ( !shader.legendSettings() || shader.legendSettings()->useContinuousLegend() )
635 {
636 // for interpolated shaders we use a ramp legend node
637 if ( !shader.colorRampItemList().isEmpty() )
638 {
639 nodes << new QgsColorRampLegendNode( nodeLayer, shader.createColorRamp(),
641 shader.minimumValue(),
642 shader.maximumValue(),
643 nullptr,
644 u"vectorLegend"_s,
645 vectorNameKey );
646 }
647 break;
648 }
649 [[fallthrough]];
652 {
653 // for all others we use itemised lists
654 QgsLegendColorList items;
655 settings.colorRampShader().legendSymbologyItems( items );
656 for ( const QPair< QString, QColor > &item : items )
657 {
658 nodes << new QgsRasterSymbolLegendNode( nodeLayer, item.second, item.first, nullptr, false,
659 u"vectorLegend"_s + QUuid::createUuid().toString(),
660 vectorNameKey
661 );
662 }
663 break;
664 }
665 break;
666 }
667 }
668 }
669 }
670
671 return nodes;
672}
673
674//
675// QgsDefaultPointCloudLayerLegend
676//
677
683
685{
686 QgsPointCloudRenderer *renderer = mLayer->renderer();
687 if ( !renderer )
688 return QList<QgsLayerTreeModelLegendNode *>();
689
690 return renderer->createLegendNodes( nodeLayer );
691}
QFlags< MapLayerLegendFlag > MapLayerLegendFlags
Map layer legend flags.
Definition qgis.h:4658
@ Exact
Assigns the color of the exact matching value in the color ramp item list.
Definition qgis.h:1486
@ Linear
Interpolates the color between two class breaks linearly.
Definition qgis.h:1484
@ Discrete
Assigns the color of the higher class for every pixel between two class breaks.
Definition qgis.h:1485
@ ExcludeByDefault
If set, the layer should not be included in legends by default, and must be manually added by a user.
Definition qgis.h:4649
Abstract base class - its implementations define different approaches to the labeling of a vector lay...
virtual QStringList subProviders() const
Gets list of sub-providers within the layer's labeling.
virtual QgsPalLayerSettings settings(const QString &providerId=QString()) const =0
Gets associated label settings.
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
static QgsImageCache * imageCache()
Returns the application's image cache, used for caching resampled versions of raster images.
Settings for a color ramp legend node.
bool useContinuousLegend() const
Returns true if a continuous gradient legend will be used.
void readXml(const QDomElement &element, const QgsReadWriteContext &context)
Reads settings from an XML element.
void writeXml(QDomDocument &doc, QDomElement &element, const QgsReadWriteContext &context) const
Writes settings to an XML element.
A legend node which renders a color ramp.
A ramp shader will color a raster pixel based on a list of values ranges in a ramp.
void legendSymbologyItems(QList< QPair< QString, QColor > > &symbolItems) const override
Returns legend symbology items if provided by renderer.
Qgis::ShaderInterpolationMethod colorRampType() const
Returns the color ramp interpolation method.
const QgsColorRampLegendNodeSettings * legendSettings() const
Returns the color ramp shader legend settings.
QList< QgsColorRampShader::ColorRampItem > colorRampItemList() const
Returns the custom color map.
QgsColorRamp * createColorRamp() const
Creates a gradient color ramp from shader settings.
Default legend implementation for mesh layers.
QgsDefaultMeshLayerLegend(QgsMeshLayer *ml)
Creates an instance for the given mesh layer.
QList< QgsLayerTreeModelLegendNode * > createLayerTreeModelLegendNodes(QgsLayerTreeLayer *nodeLayer) override
Returns list of legend nodes to be used for a particular layer tree layer node.
Default legend implementation for point cloud layers.
QList< QgsLayerTreeModelLegendNode * > createLayerTreeModelLegendNodes(QgsLayerTreeLayer *nodeLayer) override
Returns list of legend nodes to be used for a particular layer tree layer node.
QgsDefaultPointCloudLayerLegend(QgsPointCloudLayer *layer)
Creates an instance for the given point cloud layer.
Default legend implementation for raster layers.
QgsDefaultRasterLayerLegend(QgsRasterLayer *rl)
QList< QgsLayerTreeModelLegendNode * > createLayerTreeModelLegendNodes(QgsLayerTreeLayer *nodeLayer) override
Returns list of legend nodes to be used for a particular layer tree layer node.
Default legend implementation for vector layers.
QList< QgsLayerTreeModelLegendNode * > createLayerTreeModelLegendNodes(QgsLayerTreeLayer *nodeLayer) override
Returns list of legend nodes to be used for a particular layer tree layer node.
QDomElement writeXml(QDomDocument &doc, const QgsReadWriteContext &context) const override
Writes configuration to a DOM element, to be used later with readXml().
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads configuration from a DOM element previously written by writeXml().
QgsDefaultVectorLayerLegend(QgsVectorLayer *vl)
Abstract base class for all 2D vector feature renderers.
virtual QList< QgsLayerTreeModelLegendNode * > createLegendNodes(QgsLayerTreeLayer *nodeLayer) const
Returns a list of legend nodes to be used for the legend for the renderer.
virtual QString legendClassificationAttribute() const
If supported by the renderer, return classification attribute for the use in legend.
QImage pathAsImage(const QString &path, const QSize size, const bool keepAspectRatio, const double opacity, bool &fitsInCache, bool blocking=false, double targetDpi=96, int frameNumber=-1, bool *isMissing=nullptr)
Returns the specified path rendered as an image.
Implementation of legend node interface for displaying arbitrary raster images.
@ ColorRamp
Render with a color ramp.
@ SingleColor
Render with a single color.
Layer tree node points to a map layer.
QString name() const override
Returns the layer's name.
QgsMapLayer * layer() const
Returns the map layer associated with this node.
An abstract interface for legend items returned from QgsMapLayerLegend implementation.
virtual QVariant data(int role) const =0
Returns data associated with the item. Must be implemented in derived class.
virtual void setColumnBreak(bool breakBeforeNode)
Sets whether a forced column break should occur before the node.
virtual void setUserPatchSize(QSizeF size)
Sets the user (overridden) size for the legend node.
virtual void setUserLabel(const QString &userLabel)
void setCustomProperty(const QString &key, const QVariant &value)
Sets a custom property for the node. Properties are stored in a map and saved in project file.
void removeCustomProperty(const QString &key)
Remove a custom property from layer. Properties are stored in a map and saved in project file.
QVariant customProperty(const QString &key, const QVariant &defaultValue=QVariant()) const
Read a custom property from layer. Properties are stored in a map and saved in project file.
QStringList customProperties() const
Returns list of keys stored in custom properties.
Represents a patch shape for use in map legends.
void readXml(const QDomElement &element, const QgsReadWriteContext &context)
Read settings from a DOM element.
void writeXml(QDomElement &element, QDomDocument &doc, const QgsReadWriteContext &context) const
Write settings into a DOM element.
static void setLegendNodeOrder(QgsLayerTreeLayer *nodeLayer, const QList< int > &order)
static std::unique_ptr< QgsSymbol > legendNodeCustomSymbol(QgsLayerTreeLayer *nodeLayer, int originalIndex)
Returns the custom legend symbol for the legend node belonging to nodeLayer at the specified original...
static void setLegendNodeColorRampSettings(QgsLayerTreeLayer *nodeLayer, int originalIndex, const QgsColorRampLegendNodeSettings *settings)
Sets a custom legend color ramp settings for the legend node belonging to nodeLayer at the specified ...
static void setLegendNodeCustomSymbol(QgsLayerTreeLayer *nodeLayer, int originalIndex, const QgsSymbol *symbol)
Sets a custom legend symbol for the legend node belonging to nodeLayer at the specified originalIndex...
static QString legendNodeUserLabel(QgsLayerTreeLayer *nodeLayer, int originalIndex)
static QSizeF legendNodeSymbolSize(QgsLayerTreeLayer *nodeLayer, int originalIndex)
Returns the legend node symbol size for the legend node belonging to nodeLayer at the specified origi...
static bool hasLegendNodeUserLabel(QgsLayerTreeLayer *nodeLayer, int originalIndex)
static bool legendNodeColumnBreak(QgsLayerTreeLayer *nodeLayer, int originalIndex)
Returns whether a forced column break should occur before the node.
static bool hasLegendNodeOrder(QgsLayerTreeLayer *nodeLayer)
static void setLegendNodeUserLabel(QgsLayerTreeLayer *nodeLayer, int originalIndex, const QString &newLabel)
static void setLegendNodeSymbolSize(QgsLayerTreeLayer *nodeLayer, int originalIndex, QSizeF size)
Sets the legend symbol size for the legend node belonging to nodeLayer at the specified originalIndex...
static QgsColorRampLegendNodeSettings * legendNodeColorRampSettings(QgsLayerTreeLayer *nodeLayer, int originalIndex)
Returns the custom legend color ramp settings for the legend node belonging to nodeLayer at the speci...
static void setLegendNodeColumnBreak(QgsLayerTreeLayer *nodeLayer, int originalIndex, bool columnBreakBeforeNode)
Sets whether a forced column break should occur before the node.
static void setLegendNodePatchShape(QgsLayerTreeLayer *nodeLayer, int originalIndex, const QgsLegendPatchShape &shape)
Sets the legend patch shape for the legend node belonging to nodeLayer at the specified originalIndex...
static QList< int > legendNodeOrder(QgsLayerTreeLayer *nodeLayer)
static void applyLayerNodeProperties(QgsLayerTreeLayer *nodeLayer, QList< QgsLayerTreeModelLegendNode * > &nodes)
update according to layer node's custom properties (order of items, user labels for items)
static QgsLegendPatchShape legendNodePatchShape(QgsLayerTreeLayer *nodeLayer, int originalIndex)
Returns the legend patch shape for the legend node belonging to nodeLayer at the specified originalIn...
virtual void readXml(const QDomElement &elem, const QgsReadWriteContext &context)
Reads configuration from a DOM element previously written by writeXml().
static QgsMapLayerLegend * defaultMeshLegend(QgsMeshLayer *ml)
Create new legend implementation for mesh layer.
static QgsMapLayerLegend * defaultPointCloudLegend(QgsPointCloudLayer *layer)
Create new legend implementation for a point cloud layer.
QgsMapLayerLegend(QObject *parent=nullptr)
Constructor for QgsMapLayerLegend.
virtual QDomElement writeXml(QDomDocument &doc, const QgsReadWriteContext &context) const
Writes configuration to a DOM element, to be used later with readXml().
static QgsMapLayerLegend * defaultRasterLegend(QgsRasterLayer *rl)
Create new legend implementation for raster layer.
static QgsMapLayerLegend * defaultVectorLegend(QgsVectorLayer *vl)
Create new legend implementation for vector layer.
virtual QList< QgsLayerTreeModelLegendNode * > createLayerTreeModelLegendNodes(QgsLayerTreeLayer *nodeLayer)=0
Returns list of legend nodes to be used for a particular layer tree layer node.
void itemsChanged()
Emitted when existing items/nodes got invalid and should be replaced by new ones.
QgsMapLayerLegend * legend() const
Can be nullptr.
void rendererChanged()
Signal emitted when renderer is changed.
void nameChanged()
Emitted when the name has been changed.
Represents a mesh layer supporting display of data on structured or unstructured meshes.
Represents a mesh renderer settings for scalar datasets.
QgsColorRampShader colorRampShader() const
Returns color ramp shader function.
Represents all mesh renderer settings.
QgsMeshRendererScalarSettings scalarSettings(int groupIndex) const
Returns renderer settings.
int activeVectorDatasetGroup() const
Returns the active vector dataset group.
int activeScalarDatasetGroup() const
Returns the active scalar dataset group.
QgsMeshRendererVectorSettings vectorSettings(int groupIndex) const
Returns renderer settings.
Represents a renderer settings for vector datasets.
QColor color() const
Returns color used for drawing arrows.
QgsColorRampShader colorRampShader() const
Sets the color ramp shader used to render vector datasets.
QgsInterpolatedLineColor::ColoringMethod coloringMethod() const
Returns the coloring method used to render vector datasets.
Contains settings for how a map layer will be labeled.
Represents a map layer supporting display of point clouds.
Abstract base class for 2d point cloud renderers.
virtual QList< QgsLayerTreeModelLegendNode * > createLegendNodes(QgsLayerTreeLayer *nodeLayer)
Creates a set of legend nodes representing the renderer.
static QgsProject * instance()
Returns the QgsProject singleton instance.
Represents a raster layer.
double maximumValue() const
Returns the minimum value for the raster shader.
double minimumValue() const
Returns the maximum value for the raster shader.
Implementation of legend node interface for displaying raster legend entries.
A container for the context for various read/write operations on objects.
void setPathResolver(const QgsPathResolver &resolver)
Sets up path resolver for conversion between relative and absolute paths.
A child rule for QgsRuleBasedLabeling.
const QgsRuleBasedLabeling::Rule * findRuleByKey(const QString &key) const
Try to find a rule given its unique key.
QString description() const
A human readable description for this rule.
Rule based labeling for a vector layer.
QgsRuleBasedLabeling::Rule * rootRule()
Stores settings for use within QGIS.
Definition qgssettings.h:68
QVariant value(const QString &key, const QVariant &defaultValue=QVariant(), Section section=NoSection) const
Returns the value for setting key.
Implementation of legend node interface for displaying arbitrary labels with icons.
static std::unique_ptr< QgsSymbol > loadSymbol(const QDomElement &element, const QgsReadWriteContext &context)
Attempts to load a symbol from a DOM element.
static QString encodeSize(QSizeF size)
Encodes a QSizeF to a string.
static QDomElement saveSymbol(const QString &symbolName, const QgsSymbol *symbol, QDomDocument &doc, const QgsReadWriteContext &context)
Writes a symbol definition to XML.
static QSizeF decodeSize(const QString &string)
Decodes a QSizeF from a string.
Implementation of legend node interface for displaying preview of vector symbols and their labels and...
Abstract base class for all rendered symbols.
Definition qgssymbol.h:231
Container for all settings relating to text rendering.
A legend node for a labeling text symbol.
Represents a vector layer which manages a vector based dataset.
Implementation of legend node interface for displaying WMS legend entries.
#define QgsDebugError(str)
Definition qgslogger.h:59
QList< QPair< QString, QColor > > QgsLegendColorList