42using namespace Qt::StringLiterals;
46void QgsDiagramLayerSettings::initPropertyDefinitions()
48 if ( !sPropertyDefinitions.isEmpty() )
51 const QString origin = u
"diagram"_s;
72 initPropertyDefinitions();
73 return sPropertyDefinitions;
78 initPropertyDefinitions();
84 , mPlacement( rh.mPlacement )
85 , mPlacementFlags( rh.mPlacementFlags )
86 , mPriority( rh.mPriority )
87 , mZIndex( rh.mZIndex )
88 , mObstacle( rh.mObstacle )
89 , mDistance( rh.mDistance )
90 , mRenderer( rh.mRenderer ? rh.mRenderer->clone() : nullptr )
91 , mShowAll( rh.mShowAll )
92 , mDataDefinedProperties( rh.mDataDefinedProperties )
95 initPropertyDefinitions();
99 : mCt( std::move( rh.mCt ) )
100 , mPlacement( rh.mPlacement )
101 , mPlacementFlags( rh.mPlacementFlags )
102 , mPriority( rh.mPriority )
103 , mZIndex( rh.mZIndex )
104 , mObstacle( rh.mObstacle )
105 , mDistance( rh.mDistance )
106 , mRenderer( std::move( rh.mRenderer ) )
107 , mShowAll( rh.mShowAll )
108 , mDataDefinedProperties( std::move( rh.mDataDefinedProperties ) )
117 mPlacement = rh.mPlacement;
118 mPlacementFlags = rh.mPlacementFlags;
119 mPriority = rh.mPriority;
120 mZIndex = rh.mZIndex;
121 mObstacle = rh.mObstacle;
122 mDistance = rh.mDistance;
123 mRenderer.reset( rh.mRenderer ? rh.mRenderer->clone() :
nullptr );
125 mShowAll = rh.mShowAll;
126 mDataDefinedProperties = rh.mDataDefinedProperties;
136 mPlacement = rh.mPlacement;
137 mPlacementFlags = rh.mPlacementFlags;
138 mPriority = rh.mPriority;
139 mZIndex = rh.mZIndex;
140 mObstacle = rh.mObstacle;
141 mDistance = rh.mDistance;
142 mRenderer = std::move( rh.mRenderer );
143 mCt = std::move( rh.mCt );
144 mShowAll = rh.mShowAll;
145 mDataDefinedProperties = std::move( rh.mDataDefinedProperties );
154 if ( diagramRenderer == mRenderer.get() )
157 mRenderer.reset( diagramRenderer );
167 const QDomNodeList propertyElems = elem.elementsByTagName( u
"properties"_s );
168 if ( !propertyElems.isEmpty() )
170 ( void ) mDataDefinedProperties.readXml( propertyElems.at( 0 ).toElement(), sPropertyDefinitions );
174 mDataDefinedProperties.clear();
177 mPlacement =
static_cast< Placement >( elem.attribute( u
"placement"_s ).toInt() );
178 mPlacementFlags =
static_cast< LinePlacementFlag >( elem.attribute( u
"linePlacementFlags"_s ).toInt() );
179 mPriority = elem.attribute( u
"priority"_s ).toInt();
180 mZIndex = elem.attribute( u
"zIndex"_s ).toDouble();
181 mObstacle = elem.attribute( u
"obstacle"_s ).toInt();
182 mDistance = elem.attribute( u
"dist"_s ).toDouble();
183 mShowAll = ( elem.attribute( u
"showAll"_s, u
"0"_s ) !=
"0"_L1 );
188 QDomElement diagramLayerElem = doc.createElement( u
"DiagramLayerSettings"_s );
189 QDomElement propertiesElem = doc.createElement( u
"properties"_s );
190 ( void ) mDataDefinedProperties.writeXml( propertiesElem, sPropertyDefinitions );
191 diagramLayerElem.appendChild( propertiesElem );
192 diagramLayerElem.setAttribute( u
"placement"_s, mPlacement );
193 diagramLayerElem.setAttribute( u
"linePlacementFlags"_s, mPlacementFlags );
194 diagramLayerElem.setAttribute( u
"priority"_s, mPriority );
195 diagramLayerElem.setAttribute( u
"zIndex"_s, mZIndex );
196 diagramLayerElem.setAttribute( u
"obstacle"_s, mObstacle );
197 diagramLayerElem.setAttribute( u
"dist"_s, QString::number( mDistance ) );
198 diagramLayerElem.setAttribute( u
"showAll"_s, mShowAll );
199 layerElem.appendChild( diagramLayerElem );
204 return mDataDefinedProperties.prepare( context );
209 QSet< QString > referenced;
211 referenced = mRenderer->referencedFields( context );
214 referenced.unite( mDataDefinedProperties.referencedFields( context ) );
221 enabled = ( elem.attribute( u
"enabled"_s, u
"1"_s ) !=
"0"_L1 );
224 font.fromString( elem.attribute( u
"font"_s ) );
226 backgroundColor.setNamedColor( elem.attribute( u
"backgroundColor"_s ) );
227 backgroundColor.setAlpha( elem.attribute( u
"backgroundAlpha"_s ).toInt() );
228 size.setWidth( elem.attribute( u
"width"_s ).toDouble() );
229 size.setHeight( elem.attribute( u
"height"_s ).toDouble() );
230 if ( elem.hasAttribute( u
"transparency"_s ) )
232 opacity = 1 - elem.attribute( u
"transparency"_s, u
"0"_s ).toInt() / 255.0;
236 opacity = elem.attribute( u
"opacity"_s, u
"1.00"_s ).toDouble();
239 penColor.setNamedColor( elem.attribute( u
"penColor"_s ) );
240 const int penAlpha = elem.attribute( u
"penAlpha"_s, u
"255"_s ).toInt();
242 penWidth = elem.attribute( u
"penWidth"_s ).toDouble();
244 mDirection =
static_cast< Direction >( elem.attribute( u
"direction"_s, u
"1"_s ).toInt() );
246 maximumScale = elem.attribute( u
"minScaleDenominator"_s, u
"-1"_s ).toDouble();
247 minimumScale = elem.attribute( u
"maxScaleDenominator"_s, u
"-1"_s ).toDouble();
248 if ( elem.hasAttribute( u
"scaleBasedVisibility"_s ) )
258 if ( elem.attribute( u
"sizeType"_s ) ==
"MapUnits"_L1 )
273 mSpacing = elem.attribute( u
"spacing"_s ).toDouble();
277 mStackedDiagramSpacing = elem.attribute( u
"stackedDiagramSpacing"_s ).toDouble();
282 if ( elem.attribute( u
"labelPlacementMethod"_s ) ==
"Height"_L1 )
292 if ( elem.attribute( u
"diagramOrientation"_s ) ==
"Left"_L1 )
296 else if ( elem.attribute( u
"diagramOrientation"_s ) ==
"Right"_L1 )
300 else if ( elem.attribute( u
"diagramOrientation"_s ) ==
"Down"_L1 )
310 if ( elem.attribute( u
"stackedDiagramMode"_s ) ==
"Horizontal"_L1 )
314 else if ( elem.attribute( u
"stackedDiagramMode"_s ) ==
"Vertical"_L1 )
320 if ( elem.attribute( u
"scaleDependency"_s ) ==
"Diameter"_L1 )
329 barWidth = elem.attribute( u
"barWidth"_s ).toDouble();
331 if ( elem.hasAttribute( u
"angleOffset"_s ) )
332 rotationOffset = std::fmod( 360.0 - elem.attribute( u
"angleOffset"_s ).toInt() / 16.0, 360.0 );
334 rotationOffset = elem.attribute( u
"rotationOffset"_s ).toDouble();
336 minimumSize = elem.attribute( u
"minimumSize"_s ).toDouble();
338 const QDomNodeList axisSymbolNodes = elem.elementsByTagName( u
"axisSymbol"_s );
339 if ( axisSymbolNodes.count() > 0 )
341 const QDomElement axisSymbolElem = axisSymbolNodes.at( 0 ).toElement().firstChildElement();
346 mAxisLineSymbol = std::make_unique< QgsLineSymbol >();
349 mShowAxis = elem.attribute( u
"showAxis"_s, u
"0"_s ).toInt();
353 const QDomNodeList attributes = elem.elementsByTagName( u
"attribute"_s );
356 if ( attributes.length() > 0 )
358 for (
int i = 0; i < attributes.size(); i++ )
360 const QDomElement attrElem = attributes.at( i ).toElement();
361 QColor newColor( attrElem.attribute( u
"color"_s ) );
362 newColor.setAlphaF( attrElem.attribute( u
"colorOpacity"_s, u
"1.0"_s ).toDouble() );
376 const QStringList colorList = elem.attribute( u
"colors"_s ).split(
'/' );
377 QStringList::const_iterator colorIt = colorList.constBegin();
378 for ( ; colorIt != colorList.constEnd(); ++colorIt )
380 QColor newColor( *colorIt );
386 const QStringList catList = elem.attribute( u
"categories"_s ).split(
'/' );
387 QStringList::const_iterator catIt = catList.constBegin();
388 for ( ; catIt != catList.constEnd(); ++catIt )
395 const QDomElement effectElem = elem.firstChildElement( u
"effect"_s );
396 if ( !effectElem.isNull() )
404 QDomElement categoryElem = doc.createElement( u
"DiagramCategory"_s );
405 categoryElem.setAttribute( u
"enabled"_s,
enabled );
407 categoryElem.setAttribute( u
"backgroundColor"_s,
backgroundColor.name() );
408 categoryElem.setAttribute( u
"backgroundAlpha"_s,
backgroundColor.alpha() );
409 categoryElem.setAttribute( u
"width"_s, QString::number(
size.width() ) );
410 categoryElem.setAttribute( u
"height"_s, QString::number(
size.height() ) );
411 categoryElem.setAttribute( u
"penColor"_s,
penColor.name() );
412 categoryElem.setAttribute( u
"penAlpha"_s,
penColor.alpha() );
413 categoryElem.setAttribute( u
"penWidth"_s, QString::number(
penWidth ) );
415 categoryElem.setAttribute( u
"minScaleDenominator"_s, QString::number(
maximumScale ) );
416 categoryElem.setAttribute( u
"maxScaleDenominator"_s, QString::number(
minimumScale ) );
417 categoryElem.setAttribute( u
"opacity"_s, QString::number(
opacity ) );
418 categoryElem.setAttribute( u
"spacing"_s, QString::number( mSpacing ) );
421 categoryElem.setAttribute( u
"stackedDiagramSpacing"_s, QString::number( mStackedDiagramSpacing ) );
422 categoryElem.setAttribute( u
"stackedDiagramSpacingUnit"_s,
QgsUnitTypes::encodeUnit( mStackedDiagramSpacingUnit ) );
424 categoryElem.setAttribute( u
"direction"_s, QString::number( mDirection ) );
437 categoryElem.setAttribute( u
"labelPlacementMethod"_s, u
"Height"_s );
441 categoryElem.setAttribute( u
"labelPlacementMethod"_s, u
"XHeight"_s );
446 categoryElem.setAttribute( u
"scaleDependency"_s, u
"Area"_s );
450 categoryElem.setAttribute( u
"scaleDependency"_s, u
"Diameter"_s );
457 categoryElem.setAttribute( u
"diagramOrientation"_s, u
"Left"_s );
461 categoryElem.setAttribute( u
"diagramOrientation"_s, u
"Right"_s );
465 categoryElem.setAttribute( u
"diagramOrientation"_s, u
"Down"_s );
469 categoryElem.setAttribute( u
"diagramOrientation"_s, u
"Up"_s );
477 categoryElem.setAttribute( u
"stackedDiagramMode"_s, u
"Horizontal"_s );
481 categoryElem.setAttribute( u
"stackedDiagramMode"_s, u
"Vertical"_s );
485 categoryElem.setAttribute( u
"barWidth"_s, QString::number(
barWidth ) );
486 categoryElem.setAttribute( u
"minimumSize"_s, QString::number(
minimumSize ) );
487 categoryElem.setAttribute( u
"rotationOffset"_s, QString::number(
rotationOffset ) );
490 for (
int i = 0; i < nCats; ++i )
492 QDomElement attributeElem = doc.createElement( u
"attribute"_s );
495 attributeElem.setAttribute( u
"color"_s,
categoryColors.at( i ).name() );
496 attributeElem.setAttribute( u
"colorOpacity"_s, QString::number(
categoryColors.at( i ).alphaF() ) );
498 categoryElem.appendChild( attributeElem );
501 categoryElem.setAttribute( u
"showAxis"_s, mShowAxis ? u
"1"_s : u
"0"_s );
502 QDomElement axisSymbolElem = doc.createElement( u
"axisSymbol"_s );
504 axisSymbolElem.appendChild( symbolElem );
505 categoryElem.appendChild( axisSymbolElem );
508 mPaintEffect->saveProperties( doc, categoryElem );
510 rendererElem.appendChild( categoryElem );
528 if ( &other ==
this )
555 c.expressionContext().setOriginalValueVariable( s.
penWidth );
562 std::unique_ptr< QgsEffectPainter > effectPainter;
563 if ( effect && effect->
enabled() )
565 effectPainter = std::make_unique< QgsEffectPainter >(
c, effect );
568 mDiagram->renderDiagram( feature,
c, s, pos );
582 const double rendererScale =
c.rendererScale();
600 if ( size.isValid() )
603 size.rheight() *= width / size.width();
604 size.setWidth( width );
611 QSet< QString > referenced;
617 for (
const QString &att : constDiagramAttributes )
621 for (
const QString &field : constReferencedColumns )
631 if ( !size.isValid() )
637 size.rwidth() *= pixelToMap;
638 size.rheight() *= pixelToMap;
645 QPaintDevice *device = painter->device();
648 return device->logicalDpiX();
658 const QString diagramType = elem.attribute( u
"diagramType"_s );
661 mDiagram = std::make_unique<QgsPieDiagram>();
665 mDiagram = std::make_unique<QgsTextDiagram>();
669 mDiagram = std::make_unique<QgsHistogramDiagram>();
673 mDiagram = std::make_unique<QgsStackedBarDiagram>();
677 mDiagram = std::make_unique<QgsStackedDiagram>();
682 mDiagram = std::make_unique<QgsHistogramDiagram>();
694 rendererElem.setAttribute( u
"diagramType"_s,
mDiagram->diagramName() );
720 QList<QgsDiagramSettings> settingsList;
721 settingsList.push_back( mSettings );
727 const QDomElement categoryElem = elem.firstChildElement( u
"DiagramCategory"_s );
728 if ( categoryElem.isNull() )
733 mSettings.readXml( categoryElem, context );
739 QDomElement rendererElem = doc.createElement( u
"SingleCategoryDiagramRenderer"_s );
740 mSettings.writeXml( rendererElem, doc, context );
742 layerElem.appendChild( rendererElem );
749 mInterpolationSettings.classificationAttributeIsExpression =
false;
754 , mSettings( other.mSettings )
755 , mInterpolationSettings( other.mInterpolationSettings )
756 , mDataDefinedSizeLegend( other.mDataDefinedSizeLegend ? new
QgsDataDefinedSizeLegend( *other.mDataDefinedSizeLegend ) : nullptr )
764 if ( &other ==
this )
768 mSettings = other.mSettings;
769 mInterpolationSettings = other.mInterpolationSettings;
770 mDataDefinedSizeLegend = std::make_unique<QgsDataDefinedSizeLegend>( *other.mDataDefinedSizeLegend );
782 QList<QgsDiagramSettings> settingsList;
783 settingsList.push_back( mSettings );
796 return mSettings.categoryAttributes;
802 if ( mInterpolationSettings.classificationAttributeIsExpression )
804 QgsExpression *expression =
mDiagram->getExpression( mInterpolationSettings.classificationAttributeExpression, context );
806 for (
const QString &field : constReferencedColumns )
813 referenced << mInterpolationSettings.classificationField;
820 return mDiagram->diagramSize( feature,
c, mSettings, mInterpolationSettings );
825 mInterpolationSettings.lowerValue = elem.attribute( u
"lowerValue"_s ).toDouble();
826 mInterpolationSettings.upperValue = elem.attribute( u
"upperValue"_s ).toDouble();
827 mInterpolationSettings.lowerSize.setWidth( elem.attribute( u
"lowerWidth"_s ).toDouble() );
828 mInterpolationSettings.lowerSize.setHeight( elem.attribute( u
"lowerHeight"_s ).toDouble() );
829 mInterpolationSettings.upperSize.setWidth( elem.attribute( u
"upperWidth"_s ).toDouble() );
830 mInterpolationSettings.upperSize.setHeight( elem.attribute( u
"upperHeight"_s ).toDouble() );
831 mInterpolationSettings.classificationAttributeIsExpression = elem.hasAttribute( u
"classificationAttributeExpression"_s );
832 if ( mInterpolationSettings.classificationAttributeIsExpression )
834 mInterpolationSettings.classificationAttributeExpression = elem.attribute( u
"classificationAttributeExpression"_s );
838 mInterpolationSettings.classificationField = elem.attribute( u
"classificationField"_s );
840 const QDomElement settingsElem = elem.firstChildElement( u
"DiagramCategory"_s );
841 if ( !settingsElem.isNull() )
843 mSettings.readXml( settingsElem );
846 mDataDefinedSizeLegend.reset();
848 const QDomElement ddsLegendSizeElem = elem.firstChildElement( u
"data-defined-size-legend"_s );
849 if ( !ddsLegendSizeElem.isNull() )
856 if ( elem.attribute( u
"sizeLegend"_s, u
"0"_s ) !=
"0"_L1 )
858 mDataDefinedSizeLegend = std::make_unique<QgsDataDefinedSizeLegend>();
859 const QDomElement sizeLegendSymbolElem = elem.firstChildElement( u
"symbol"_s );
860 if ( !sizeLegendSymbolElem.isNull() && sizeLegendSymbolElem.attribute( u
"name"_s ) ==
"sizeSymbol"_L1 )
867 mDataDefinedSizeLegend =
nullptr;
876 QDomElement rendererElem = doc.createElement( u
"LinearlyInterpolatedDiagramRenderer"_s );
877 rendererElem.setAttribute( u
"lowerValue"_s, QString::number( mInterpolationSettings.lowerValue ) );
878 rendererElem.setAttribute( u
"upperValue"_s, QString::number( mInterpolationSettings.upperValue ) );
879 rendererElem.setAttribute( u
"lowerWidth"_s, QString::number( mInterpolationSettings.lowerSize.width() ) );
880 rendererElem.setAttribute( u
"lowerHeight"_s, QString::number( mInterpolationSettings.lowerSize.height() ) );
881 rendererElem.setAttribute( u
"upperWidth"_s, QString::number( mInterpolationSettings.upperSize.width() ) );
882 rendererElem.setAttribute( u
"upperHeight"_s, QString::number( mInterpolationSettings.upperSize.height() ) );
883 if ( mInterpolationSettings.classificationAttributeIsExpression )
885 rendererElem.setAttribute( u
"classificationAttributeExpression"_s, mInterpolationSettings.classificationAttributeExpression );
889 rendererElem.setAttribute( u
"classificationField"_s, mInterpolationSettings.classificationField );
891 mSettings.writeXml( rendererElem, doc );
893 if ( mDataDefinedSizeLegend )
895 QDomElement ddsLegendElem = doc.createElement( u
"data-defined-size-legend"_s );
896 mDataDefinedSizeLegend->writeXml( ddsLegendElem, context );
897 rendererElem.appendChild( ddsLegendElem );
901 layerElem.appendChild( rendererElem );
908 , mSettings( other.mSettings )
909 , mDiagramRenderers()
914 mDiagramRenderers << renderer->clone();
920 if ( &other ==
this )
923 mSettings = other.mSettings;
924 qDeleteAll( mDiagramRenderers );
925 mDiagramRenderers.clear();
929 mDiagramRenderers <<
renderer->clone();
937 qDeleteAll( mDiagramRenderers );
947 QSizeF stackedSize( 0, 0 );
948 int enabledDiagramCount = 0;
955 QSizeF size = subRenderer->sizeMapUnits( feature,
c );
957 if ( size.isValid() )
959 enabledDiagramCount++;
960 switch ( mSettings.stackedDiagramMode )
963 stackedSize.setWidth( stackedSize.width() + size.width() );
964 stackedSize.setHeight( std::max( stackedSize.height(), size.height() ) );
968 stackedSize.setWidth( std::max( stackedSize.width(), size.width() ) );
969 stackedSize.setHeight( stackedSize.height() + size.height() );
975 if ( stackedSize.isValid() )
977 const double spacing =
c.convertToMapUnits( mSettings.stackedDiagramSpacing(), mSettings.stackedDiagramSpacingUnit(), mSettings.stackedDiagramSpacingMapUnitScale() );
979 switch ( mSettings.stackedDiagramMode )
982 stackedSize.scale( stackedSize.width() + spacing * ( enabledDiagramCount - 1 ), stackedSize.height(), Qt::IgnoreAspectRatio );
986 stackedSize.scale( stackedSize.width(), stackedSize.height() + spacing * ( enabledDiagramCount - 1 ), Qt::IgnoreAspectRatio );
1000 QPointF newPos = pos;
1003 const QList< QgsDiagramRenderer * > stackedRenderers =
renderers(
true );
1010 stackedRenderer->renderDiagram( feature,
c, newPos, properties );
1015 if ( !stackedRenderer->diagramSettings( feature,
c, s ) )
1028 const double rendererScale =
c.rendererScale();
1051 c.expressionContext().setOriginalValueVariable( s.
penWidth );
1058 std::unique_ptr< QgsEffectPainter > effectPainter;
1059 if ( effect && effect->
enabled() )
1061 effectPainter = std::make_unique< QgsEffectPainter >(
c, effect );
1064 stackedRenderer->diagram()->renderDiagram( feature,
c, s, newPos );
1082 return QSizeF( 0, 0 );
1087 QList<QgsDiagramSettings> settingsList;
1088 settingsList.push_back( mSettings );
1089 return settingsList;
1094 return mSettings.categoryAttributes;
1099 QList< QgsLayerTreeModelLegendNode * > nodes;
1102 nodes <<
renderer->legendItems( nodeLayer );
1110 QList< QgsDiagramRenderer * >
renderers = mDiagramRenderers;
1125 mDiagramRenderers.append(
renderer );
1131 return mDiagramRenderers.value( index );
1136 return mDiagramRenderers.size();
1141 const QDomElement categoryElem = elem.firstChildElement( u
"DiagramCategory"_s );
1142 if ( categoryElem.isNull() )
1147 mSettings.
readXml( categoryElem, context );
1154 qDeleteAll( mDiagramRenderers );
1155 mDiagramRenderers.clear();
1157 const QDomElement subRenderersElem = elem.firstChildElement( u
"DiagramRenderers"_s );
1159 if ( !subRenderersElem.isNull() )
1161 const QDomNodeList childRendererList = subRenderersElem.childNodes();
1163 for (
int i = 0; i < childRendererList.size(); i++ )
1165 const QDomElement subRendererElem = childRendererList.at( i ).toElement();
1167 if ( subRendererElem.nodeName() ==
"SingleCategoryDiagramRenderer"_L1 )
1169 auto singleCatDiagramRenderer = std::make_unique< QgsSingleCategoryDiagramRenderer >();
1170 singleCatDiagramRenderer->readXml( subRendererElem, context );
1171 addRenderer( singleCatDiagramRenderer.release() );
1173 else if ( subRendererElem.nodeName() ==
"LinearlyInterpolatedDiagramRenderer"_L1 )
1175 auto linearDiagramRenderer = std::make_unique< QgsLinearlyInterpolatedDiagramRenderer >();
1176 linearDiagramRenderer->readXml( subRendererElem, context );
1179 else if ( subRendererElem.nodeName() ==
"StackedDiagramRenderer"_L1 )
1181 auto stackedDiagramRenderer = std::make_unique< QgsStackedDiagramRenderer >();
1182 stackedDiagramRenderer->readXml( subRendererElem, context );
1191 QDomElement rendererElem = doc.createElement( u
"StackedDiagramRenderer"_s );
1192 mSettings.writeXml( rendererElem, doc, context );
1193 _writeXml( rendererElem, doc, context );
1195 layerElem.appendChild( rendererElem );
1200 QDomElement renderersElem = doc.createElement( u
"DiagramRenderers"_s );
1203 for (
int i = 0; i < mDiagramRenderers.count(); i++ )
1205 mDiagramRenderers.at( i )->writeXml( renderersElem, doc, context );
1207 rendererElem.appendChild( renderersElem );
1212 QList< QgsLayerTreeModelLegendNode * > list;
1216 QPixmap pix( 16, 16 );
1225 return mAxisLineSymbol.get();
1246 return mPaintEffect.get();
1251 if ( effect != mPaintEffect.get() )
1252 mPaintEffect.reset( effect );
1286 , mSpacing( other.mSpacing )
1287 , mSpacingUnit( other.mSpacingUnit )
1288 , mSpacingMapUnitScale( other.mSpacingMapUnitScale )
1289 , mStackedDiagramSpacing( other.mStackedDiagramSpacing )
1290 , mStackedDiagramSpacingUnit( other.mStackedDiagramSpacingUnit )
1291 , mStackedDiagramSpacingMapUnitScale( other.mStackedDiagramSpacingMapUnitScale )
1292 , mDirection( other.mDirection )
1293 , mShowAxis( other.mShowAxis )
1294 , mAxisLineSymbol( other.mAxisLineSymbol ? other.mAxisLineSymbol->clone() : nullptr )
1295 , mPaintEffect( other.mPaintEffect ? other.mPaintEffect->clone() : nullptr )
1300 if ( &other ==
this )
1327 mSpacing = other.mSpacing;
1328 mSpacingUnit = other.mSpacingUnit;
1329 mSpacingMapUnitScale = other.mSpacingMapUnitScale;
1330 mStackedDiagramSpacing = other.mStackedDiagramSpacing;
1331 mStackedDiagramSpacingUnit = other.mStackedDiagramSpacingUnit;
1332 mStackedDiagramSpacingMapUnitScale = other.mStackedDiagramSpacingMapUnitScale;
1333 mDirection = other.mDirection;
1334 mAxisLineSymbol.reset( other.mAxisLineSymbol ? other.mAxisLineSymbol->clone() :
nullptr );
1335 mShowAxis = other.mShowAxis;
1336 mPaintEffect.reset( other.mPaintEffect ? other.mPaintEffect->clone() :
nullptr );
1352 return QList< QgsLayerTreeModelLegendNode * >();
1357 QList< QgsLayerTreeModelLegendNode * > nodes;
1359 nodes = mSettings.legendItems( nodeLayer );
1366 QList< QgsLayerTreeModelLegendNode * > nodes;
1367 if ( !mSettings.enabled )
1373 nodes = mSettings.legendItems( nodeLayer );
1375 if ( mDataDefinedSizeLegend &&
mDiagram )
1385 QList<QgsDataDefinedSizeLegend::SizeClass> sizeClasses;
1386 if ( ddSizeLegend.
classes().isEmpty() )
1390 for (
const double v : prettyBreaks )
1392 const double size =
mDiagram->legendSize( v, mSettings, mInterpolationSettings );
1399 const auto constClasses = ddSizeLegend.
classes();
1402 const double size =
mDiagram->legendSize( sc.size, mSettings, mInterpolationSettings );
1411 if (
auto *lDataDefinedSizeLegendSettings = si.dataDefinedSizeLegendSettings() )
1423 mDataDefinedSizeLegend.reset( settings );
1428 return mDataDefinedSizeLegend.get();
QColor valueAsColor(int key, const QgsExpressionContext &context, const QColor &defaultColor=QColor(), bool *ok=nullptr) const
Calculates the current value of the property with the specified key and interprets it as a color.
double valueAsDouble(int key, const QgsExpressionContext &context, double defaultValue=0.0, bool *ok=nullptr) const
Calculates the current value of the property with the specified key and interprets it as a double.
static QgsPaintEffectRegistry * paintEffectRegistry()
Returns the application's paint effect registry, used for managing paint effects.
static QString colorToString(const QColor &color)
Encodes a color into a string value.
A legend node with a marker symbol.
Object that keeps configuration of appearance of marker symbol's data-defined size in legend.
QList< QgsDataDefinedSizeLegend::SizeClass > classes() const
Returns list of classes: each class is a pair of symbol size (in units used by the symbol) and label.
void setSymbol(QgsMarkerSymbol *symbol SIP_TRANSFER)
Sets marker symbol that will be used to draw markers in legend.
void setClasses(const QList< QgsDataDefinedSizeLegend::SizeClass > &classes)
Sets list of classes: each class is a pair of symbol size (in units used by the symbol) and label.
static QgsDataDefinedSizeLegend * readXml(const QDomElement &elem, const QgsReadWriteContext &context) SIP_FACTORY
Creates instance from given element and returns it (caller takes ownership). Returns nullptr on error...
QgsLegendSymbolList legendSymbolList() const
Generates legend symbol items according to the configuration.
LinePlacementFlag
Line placement flags for controlling line based placements.
QgsDiagramLayerSettings & operator=(const QgsDiagramLayerSettings &rh)
void setRenderer(QgsDiagramRenderer *diagramRenderer)
Sets the diagram renderer associated with the layer.
~QgsDiagramLayerSettings()
@ PositionX
X-coordinate data defined diagram position.
@ Distance
Distance to diagram from feature.
@ PositionY
Y-coordinate data defined diagram position.
@ Show
Whether to show the diagram.
@ Priority
Diagram priority (between 0 and 10).
@ ZIndex
Z-index for diagram ordering.
@ StrokeColor
Stroke color.
@ BackgroundColor
Diagram background color.
@ StartAngle
Angle offset for pie diagram.
@ IsObstacle
Whether diagram features act as obstacles for other diagrams/labels.
@ StrokeWidth
Stroke width.
@ AlwaysShow
Whether the diagram should always be shown, even if it overlaps other diagrams/labels.
void readXml(const QDomElement &elem)
Reads the diagram settings from a DOM element.
static const QgsPropertiesDefinition & propertyDefinitions()
Returns the diagram property definitions.
QgsDiagramLayerSettings()
QSet< QString > referencedFields(const QgsExpressionContext &context=QgsExpressionContext()) const
Returns the set of any fields referenced by the layer's diagrams.
void writeXml(QDomElement &layerElem, QDomDocument &doc) const
Writes the diagram settings to a DOM element.
bool prepare(const QgsExpressionContext &context=QgsExpressionContext()) const
Prepares the diagrams for a specified expression context.
void setCoordinateTransform(const QgsCoordinateTransform &transform)
Sets the coordinate transform associated with the layer.
Evaluates and returns the diagram settings relating to a diagram for a specific feature.
virtual QList< QgsLayerTreeModelLegendNode * > legendItems(QgsLayerTreeLayer *nodeLayer) const
Returns list of legend nodes for the diagram.
virtual QSizeF diagramSize(const QgsFeature &feature, const QgsRenderContext &c) const =0
Returns size of the diagram (in painter units) or an invalid size in case of error.
void _writeXml(QDomElement &rendererElem, QDomDocument &doc, const QgsReadWriteContext &context) const
Writes internal QgsDiagramRenderer diagram state to a DOM element.
virtual QSet< QString > referencedFields(const QgsExpressionContext &context=QgsExpressionContext()) const
Returns the set of any fields required for diagram rendering.
virtual void renderDiagram(const QgsFeature &feature, QgsRenderContext &c, QPointF pos, const QgsPropertyCollection &properties=QgsPropertyCollection()) const
Renders the diagram for a specified feature at a specific position in the passed render context.
void _readXml(const QDomElement &elem, const QgsReadWriteContext &context)
Reads internal QgsDiagramRenderer state from a DOM element.
QgsDiagramRenderer & operator=(const QgsDiagramRenderer &other)
virtual QSizeF sizeMapUnits(const QgsFeature &feature, const QgsRenderContext &c) const
Returns size of the diagram for a feature in map units. Returns an invalid QSizeF in case of error.
virtual QList< QString > diagramAttributes() const =0
Returns attribute indices needed for diagram rendering.
std::unique_ptr< QgsDiagram > mDiagram
Reference to the object that does the real diagram rendering.
void convertSizeToMapUnits(QSizeF &size, const QgsRenderContext &context) const
Converts size from mm to map units.
virtual QList< QgsDiagramSettings > diagramSettings() const =0
Returns list with all diagram settings in the renderer.
bool mShowAttributeLegend
Whether to show an attribute legend for the diagrams.
QgsDiagramRenderer()=default
virtual void readXml(const QDomElement &elem, const QgsReadWriteContext &context)=0
Reads diagram state from a DOM element.
void setDiagram(QgsDiagram *d)
virtual QgsDiagramRenderer * clone() const =0
Returns new instance that is equivalent to this one.
static int dpiPaintDevice(const QPainter *)
Returns the paint device dpi (or -1 in case of error.
Stores the settings for rendering a single diagram.
Direction direction() const
Returns the chart's angular direction.
StackedDiagramMode stackedDiagramMode
void setDirection(Direction direction)
Sets the chart's angular direction.
bool showAxis() const
Returns true if the diagram axis should be shown.
LabelPlacementMethod labelPlacementMethod
void readXml(const QDomElement &elem, const QgsReadWriteContext &context=QgsReadWriteContext())
Reads diagram settings from XML.
double opacity
Opacity, from 0 (transparent) to 1.0 (opaque).
QgsDiagramSettings & operator=(const QgsDiagramSettings &other)
QgsLineSymbol * axisLineSymbol() const
Returns the line symbol to use for rendering axis in diagrams.
Qgis::RenderUnit sizeType
Diagram size unit.
QList< QString > categoryAttributes
QList< QString > categoryLabels
DiagramOrientation diagramOrientation
QList< QgsLayerTreeModelLegendNode * > legendItems(QgsLayerTreeLayer *nodeLayer) const
Returns list of legend nodes for the diagram.
QgsMapUnitScale lineSizeScale
Line unit scale.
void writeXml(QDomElement &rendererElem, QDomDocument &doc, const QgsReadWriteContext &context=QgsReadWriteContext()) const
Writes diagram settings to XML.
QList< QColor > categoryColors
double rotationOffset
Rotation offset, in degrees clockwise from horizontal.
QgsMapUnitScale sizeScale
Diagram size unit scale.
double minimumScale
The minimum map scale (i.e.
bool scaleBasedVisibility
double maximumScale
The maximum map scale (i.e.
void setAxisLineSymbol(QgsLineSymbol *symbol)
Sets the line symbol to use for rendering axis in diagrams.
Qgis::RenderUnit lineSizeUnit
Line unit index.
double minimumSize
Scale diagrams smaller than mMinimumSize to mMinimumSize.
Direction
Angular directions.
void setShowAxis(bool showAxis)
Sets whether the diagram axis should be shown.
void setPaintEffect(QgsPaintEffect *effect)
Sets the paint effect to use while rendering diagrams.
QgsPaintEffect * paintEffect() const
Returns the paint effect to use while rendering diagrams.
Base class for all diagram types.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
Handles parsing and evaluation of expressions (formerly called "search strings").
QSet< QString > referencedColumns() const
Gets list of columns referenced by the expression.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
static bool setFromXmlChildNode(QFont &font, const QDomElement &element, const QString &childNode)
Sets the properties of a font to match the properties stored in an XML child node.
static QDomElement toXmlElement(const QFont &font, QDomDocument &document, const QString &elementName)
Returns a DOM element containing the properties of the font.
static const QString DIAGRAM_NAME_HISTOGRAM
Layer tree node points to a map layer.
Stores information about one class/rule of a vector layer renderer in a unified way that can be used ...
A line symbol type, for rendering LineString and MultiLineString geometries.
QgsLinearlyInterpolatedDiagramRenderer()
void setDataDefinedSizeLegend(QgsDataDefinedSizeLegend *settings)
Configures appearance of legend.
QSizeF diagramSize(const QgsFeature &, const QgsRenderContext &c) const override
Returns size of the diagram (in painter units) or an invalid size in case of error.
QList< QString > diagramAttributes() const override
Returns attribute indices needed for diagram rendering.
QSet< QString > referencedFields(const QgsExpressionContext &context=QgsExpressionContext()) const override
Returns the set of any fields required for diagram rendering.
QList< QgsDiagramSettings > diagramSettings() const override
Returns list with all diagram settings in the renderer.
void writeXml(QDomElement &layerElem, QDomDocument &doc, const QgsReadWriteContext &context) const override
Writes diagram state to a DOM element.
QgsLinearlyInterpolatedDiagramRenderer * clone() const override
Returns new instance that is equivalent to this one.
QList< QgsLayerTreeModelLegendNode * > legendItems(QgsLayerTreeLayer *nodeLayer) const override
Returns list of legend nodes for the diagram.
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads diagram state from a DOM element.
QgsDataDefinedSizeLegend * dataDefinedSizeLegend() const
Returns configuration of appearance of legend.
~QgsLinearlyInterpolatedDiagramRenderer() override
QgsLinearlyInterpolatedDiagramRenderer & operator=(const QgsLinearlyInterpolatedDiagramRenderer &other)
static const QString DIAGRAM_RENDERER_NAME_LINEARLY_INTERPOLATED
double mapUnitsPerPixel() const
Returns the current map units per pixel.
A marker symbol type, for rendering Point and MultiPoint geometries.
static std::unique_ptr< QgsMarkerSymbol > createSimple(const QVariantMap &properties)
Create a marker symbol with one symbol layer: SimpleMarker with specified properties.
QgsMarkerSymbol * clone() const override
Returns a deep copy of this symbol.
void setSizeMapUnitScale(const QgsMapUnitScale &scale) const
Sets the size map unit scale for the whole symbol (including all symbol layers).
void setSizeUnit(Qgis::RenderUnit unit) const
Sets the size units for the whole symbol (including all symbol layers).
static QgsPaintEffect * defaultStack()
Returns a new effect stack consisting of a sensible selection of default effects.
static bool isDefaultStack(QgsPaintEffect *effect)
Tests whether a paint effect matches the default effects stack.
Base class for visual effects which can be applied to QPicture drawings.
bool enabled() const
Returns whether the effect is enabled.
static const QString DIAGRAM_NAME_PIE
A grouped map of multiple QgsProperty objects, each referenced by an integer key value.
bool hasActiveProperties() const final
Returns true if the collection has any active properties, or false if all properties within the colle...
@ Double
Double value (including negative values).
@ StrokeWidth
Line stroke width.
@ Rotation
Rotation (value between 0-360 degrees).
@ ColorWithAlpha
Color with alpha channel.
@ DoublePositive
Positive double value (including 0).
A container for the context for various read/write operations on objects.
Contains information about the context of a rendering operation.
double scaleFactor() const
Returns the scaling factor for the render to convert painter units to physical sizes.
const QgsMapToPixel & mapToPixel() const
Returns the context's map to pixel transform, which transforms between map coordinates and device coo...
static bool equalToOrGreaterThanMinimumScale(const double scale, const double minScale)
Returns whether the scale is equal to or greater than the minScale, taking non-round numbers into acc...
static bool lessThanMaximumScale(const double scale, const double maxScale)
Returns whether the scale is less than the maxScale, taking non-round numbers into account.
Implementation of legend node interface for displaying arbitrary labels with icons.
QSizeF diagramSize(const QgsFeature &, const QgsRenderContext &c) const override
Returns size of the diagram (in painter units) or an invalid size in case of error.
void writeXml(QDomElement &layerElem, QDomDocument &doc, const QgsReadWriteContext &context) const override
Writes diagram state to a DOM element.
QgsSingleCategoryDiagramRenderer * clone() const override
Returns new instance that is equivalent to this one.
QgsSingleCategoryDiagramRenderer()=default
QList< QgsLayerTreeModelLegendNode * > legendItems(QgsLayerTreeLayer *nodeLayer) const override
Returns list of legend nodes for the diagram.
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads diagram state from a DOM element.
QList< QgsDiagramSettings > diagramSettings() const override
Returns list with all diagram settings in the renderer.
static const QString DIAGRAM_RENDERER_NAME_SINGLE_CATEGORY
static const QString DIAGRAM_NAME_STACKED_BAR
QgsStackedDiagramRenderer * clone() const override
Returns new instance that is equivalent to this one.
QList< QgsDiagramSettings > diagramSettings() const override
Returns list with all diagram settings in the renderer.
QSizeF diagramSize(const QgsFeature &, const QgsRenderContext &c) const override
Returns size of the diagram (in painter units) or an invalid size in case of error.
void renderDiagram(const QgsFeature &feature, QgsRenderContext &c, QPointF pos, const QgsPropertyCollection &properties=QgsPropertyCollection()) const override
Renders the diagram for a specified feature at a specific position in the passed render context,...
QList< QString > diagramAttributes() const override
Returns attribute indices needed for diagram rendering.
void writeXml(QDomElement &layerElem, QDomDocument &doc, const QgsReadWriteContext &context) const override
Writes diagram state to a DOM element.
static const QString DIAGRAM_RENDERER_NAME_STACKED
QgsStackedDiagramRenderer & operator=(const QgsStackedDiagramRenderer &other)
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads diagram state from a DOM element.
void addRenderer(QgsDiagramRenderer *renderer)
Adds a renderer to the stacked renderer object.
void _writeXmlSubRenderers(QDomElement &rendererElem, QDomDocument &doc, const QgsReadWriteContext &context) const
Writes stacked renderers state to a DOM element.
QList< QgsDiagramRenderer * > renderers(bool sortByDiagramMode=false) const
Returns an ordered list with the renderers of the stacked renderer object.
const QgsDiagramRenderer * renderer(const int index) const
Returns the renderer at the given index.
void _readXmlSubRenderers(const QDomElement &elem, const QgsReadWriteContext &context)
Reads stacked renderers state from a DOM element.
int rendererCount() const
Returns the number of sub renderers in the stacked diagram renderer.
QList< QgsLayerTreeModelLegendNode * > legendItems(QgsLayerTreeLayer *nodeLayer) const override
Returns list of legend nodes for the diagram.
QgsStackedDiagramRenderer()=default
~QgsStackedDiagramRenderer() override
QSizeF sizeMapUnits(const QgsFeature &feature, const QgsRenderContext &c) const override
Returns size of the diagram for a feature in map units. Returns an invalid QSizeF in case of error.
A diagram composed of several subdiagrams, located side by side.
static const QString DIAGRAM_NAME_STACKED
void subDiagramPosition(QPointF &newPos, const QgsRenderContext &c, const QgsDiagramSettings &s, const QgsDiagramSettings &subSettings)
Calculates the position for the next subdiagram, updating the newPos object.
static QString encodeMapUnitScale(const QgsMapUnitScale &mapUnitScale)
static QList< double > prettyBreaks(double minimum, double maximum, int classes)
Computes a sequence of about 'classes' equally spaced round values which cover the range of values fr...
static QgsMapUnitScale decodeMapUnitScale(const QString &str)
static std::unique_ptr< QgsSymbol > loadSymbol(const QDomElement &element, const QgsReadWriteContext &context)
Attempts to load a symbol from a DOM element.
static QDomElement saveSymbol(const QString &symbolName, const QgsSymbol *symbol, QDomDocument &doc, const QgsReadWriteContext &context)
Writes a symbol definition to XML.
Implementation of legend node interface for displaying preview of vector symbols and their labels and...
static const QString DIAGRAM_NAME_TEXT
static Q_INVOKABLE Qgis::RenderUnit decodeRenderUnit(const QString &string, bool *ok=nullptr)
Decodes a render unit from a string.
static Q_INVOKABLE QString encodeUnit(Qgis::DistanceUnit unit)
Encodes a distance unit to a string.
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
QMap< int, QgsPropertyDefinition > QgsPropertiesDefinition
Definition of available properties.
Definition of one class for the legend.