QGIS API Documentation 3.41.0-Master (1deb1daf037)
Loading...
Searching...
No Matches
qgslegendsettings.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgslegendsettings.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 "qgslegendsettings.h"
18#include "qgsexpression.h"
19#include "qgsrendercontext.h"
20
21#include <QPainter>
22
24 : mSymbolSize( 7, 4 )
25 , mWmsLegendSize( 50, 25 )
26 , mRasterStrokeColor( Qt::black )
27{
36
38 f.setSize( 16.0 );
40 // these default line heights are not ideal, but needed to maintain api
41 f.setLineHeight( 1.1 );
44
46 f.setSize( 14.0 );
48 f.setLineHeight( 1.1 );
51
53 f.setSize( 12.0 );
55 f.setLineHeight( 1.1 );
58
60 f.setSize( 12.0 );
62 f.setLineHeight( 1.1 );
65}
66
74
79
87
92
98
100{
101 // line spacing *was* a fixed amount (in mm) added between each line of text.
102 mLineSpacing = s;
103
104 QgsTextFormat f = rstyle( Qgis::LegendComponent::Title ).textFormat();
105 // assume font sizes in points, since that was what we always had from before this method was deprecated
106 f.setLineHeight( f.size() * 0.352778 + s );
108 rstyle( Qgis::LegendComponent::Title ).setTextFormat( f );
109
110 f = rstyle( Qgis::LegendComponent::Group ).textFormat();
111 f.setLineHeight( f.size() * 0.352778 + s );
113 rstyle( Qgis::LegendComponent::Group ).setTextFormat( f );
114
115 f = rstyle( Qgis::LegendComponent::Subgroup ).textFormat();
116 f.setLineHeight( f.size() * 0.352778 + s );
118 rstyle( Qgis::LegendComponent::Subgroup ).setTextFormat( f );
119
120 f = rstyle( Qgis::LegendComponent::SymbolLabel ).textFormat();
121 f.setLineHeight( f.size() * 0.352778 + s );
123 rstyle( Qgis::LegendComponent::SymbolLabel ).setTextFormat( f );
124}
125
127{
128 return mMmPerMapUnit;
129}
130
131void QgsLegendSettings::setMmPerMapUnit( double mmPerMapUnit )
132{
133 mMmPerMapUnit = mmPerMapUnit;
134}
135
137{
138 return mUseAdvancedEffects;
139}
140
142{
143 mUseAdvancedEffects = use;
144}
145
147{
148 return mMapScale;
149}
150
152{
153 mMapScale = scale;
154}
155
157{
158 return 1 / ( mMmPerMapUnit * ( mDpi / 25.4 ) );
159}
160
161void QgsLegendSettings::setMapUnitsPerPixel( double mapUnitsPerPixel )
162{
163 mMmPerMapUnit = 1 / mapUnitsPerPixel / ( mDpi / 25.4 );
164}
165
167{
168 return mDpi;
169}
170
172{
173 mDpi = dpi;
174}
175
176QStringList QgsLegendSettings::evaluateItemText( const QString &text, const QgsExpressionContext &context ) const
177{
178 const QString textToRender = QgsExpression::replaceExpressionText( text, &context );
179 return splitStringForWrapping( textToRender );
180}
181
182QStringList QgsLegendSettings::splitStringForWrapping( const QString &stringToSplit ) const
183{
184 const QStringList lines = stringToSplit.split( '\n' );
185
186 // If the string contains nothing then just return the string without splitting.
187 if ( wrapChar().isEmpty() )
188 return lines;
189
190 QStringList res;
191 for ( const QString &line : lines )
192 {
193 res.append( line.split( wrapChar() ) );
194 }
195 return res;
196}
197
198#define FONT_WORKAROUND_SCALE 10 //scale factor for upscaling fontsize and downscaling painter
199
200
201void QgsLegendSettings::drawText( QPainter *p, double x, double y, const QString &text, const QFont &font ) const
202{
203 const QFont textFont = scaledFontPixelSize( font );
204
205 const QgsScopedQPainterState painterState( p );
206 p->setFont( textFont );
207 const double scaleFactor = 1.0 / FONT_WORKAROUND_SCALE;
208 p->scale( scaleFactor, scaleFactor );
209 p->drawText( QPointF( x * FONT_WORKAROUND_SCALE, y * FONT_WORKAROUND_SCALE ), text );
210}
211
212
213void QgsLegendSettings::drawText( QPainter *p, const QRectF &rect, const QString &text, const QFont &font, Qt::AlignmentFlag halignment, Qt::AlignmentFlag valignment, int flags ) const
214{
215 const QFont textFont = scaledFontPixelSize( font );
216
217 const QRectF scaledRect( rect.x() * FONT_WORKAROUND_SCALE, rect.y() * FONT_WORKAROUND_SCALE,
218 rect.width() * FONT_WORKAROUND_SCALE, rect.height() * FONT_WORKAROUND_SCALE );
219
220 const QgsScopedQPainterState painterState( p );
221 p->setFont( textFont );
222 const double scaleFactor = 1.0 / FONT_WORKAROUND_SCALE;
223 p->scale( scaleFactor, scaleFactor );
224 p->drawText( scaledRect, halignment | valignment | flags, text );
225}
226
227
228QFont QgsLegendSettings::scaledFontPixelSize( const QFont &font ) const
229{
230 QFont scaledFont = font;
231 const double pixelSize = pixelFontSize( font.pointSizeF() ) * FONT_WORKAROUND_SCALE + 0.5;
232 scaledFont.setPixelSize( pixelSize );
233 return scaledFont;
234}
235
236double QgsLegendSettings::pixelFontSize( double pointSize ) const
237{
238 return ( pointSize * 0.3527 );
239}
240
241double QgsLegendSettings::textWidthMillimeters( const QFont &font, const QString &text ) const
242{
243 const QFont metricsFont = scaledFontPixelSize( font );
244 const QFontMetricsF fontMetrics( metricsFont );
245 return ( fontMetrics.horizontalAdvance( text ) / FONT_WORKAROUND_SCALE );
246}
247
248double QgsLegendSettings::fontHeightCharacterMM( const QFont &font, QChar c ) const
249{
250 const QFont metricsFont = scaledFontPixelSize( font );
251 const QFontMetricsF fontMetrics( metricsFont );
252 return ( fontMetrics.boundingRect( c ).height() / FONT_WORKAROUND_SCALE );
253}
254
255double QgsLegendSettings::fontAscentMillimeters( const QFont &font ) const
256{
257 const QFont metricsFont = scaledFontPixelSize( font );
258 const QFontMetricsF fontMetrics( metricsFont );
259 return ( fontMetrics.ascent() / FONT_WORKAROUND_SCALE );
260}
261
262double QgsLegendSettings::fontDescentMillimeters( const QFont &font ) const
263{
264 const QFont metricsFont = scaledFontPixelSize( font );
265 const QFontMetricsF fontMetrics( metricsFont );
266 return ( fontMetrics.descent() / FONT_WORKAROUND_SCALE );
267}
268
270{
271 return mJsonRenderFlags;
272}
273
275{
276 mJsonRenderFlags = jsonRenderFlags;
277}
278
@ Symbol
Symbol icon (excluding label)
@ Group
Legend group title.
@ Subgroup
Legend subgroup title.
@ Title
Legend title.
@ SymbolLabel
Symbol label (excluding icon)
@ Percentage
Percentage of another measurement (e.g., canvas size, feature size)
@ Millimeters
Millimeters.
@ Points
Points (e.g., for font sizes)
QFlags< LegendJsonRenderFlag > LegendJsonRenderFlags
Definition qgis.h:4365
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
static QString replaceExpressionText(const QString &action, const QgsExpressionContext *context, const QgsDistanceArea *distanceArea=nullptr)
This function replaces each expression between [% and %] in the string with the result of its evaluat...
QString wrapChar() const
Returns the string used as a wrapping character.
Q_DECL_DEPRECATED void setFontColor(const QColor &c)
Sets the font color used for legend items.
Q_DECL_DEPRECATED QColor layerFontColor() const
Returns layer font color, defaults to fontColor()
void drawText(QPainter *p, double x, double y, const QString &text, const QFont &font) const
Draws Text.
QgsLegendStyle & rstyle(Qgis::LegendComponent s)
Returns modifiable reference to the style for a legend component.
Q_DECL_DEPRECATED void setMapScale(double scale)
Sets the legend map scale.
Q_DECL_DEPRECATED void setLayerFontColor(const QColor &fontColor)
Sets layer font color to fontColor Overrides fontColor()
Q_DECL_DEPRECATED void setMapUnitsPerPixel(double mapUnitsPerPixel)
Sets the mmPerMapUnit calculated by mapUnitsPerPixel mostly taken from the map settings.
Q_DECL_DEPRECATED void setLineSpacing(double s)
Sets the line spacing to use between lines of legend text.
Q_DECL_DEPRECATED void setMmPerMapUnit(double mmPerMapUnit)
Q_DECL_DEPRECATED void setDpi(int dpi)
void setJsonRenderFlags(const Qgis::LegendJsonRenderFlags &jsonRenderFlags)
Sets the the JSON export flags to jsonRenderFlags.
double fontDescentMillimeters(const QFont &font) const
Returns the font descent in Millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCA...
Q_DECL_DEPRECATED QColor fontColor() const
Returns the font color used for legend items.
double textWidthMillimeters(const QFont &font, const QString &text) const
Returns the font width in millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCALE...
Q_DECL_DEPRECATED bool useAdvancedEffects() const
double pixelFontSize(double pointSize) const
Calculates font to from point size to pixel size.
double fontHeightCharacterMM(const QFont &font, QChar c) const
Returns the font height of a character in millimeters.
Q_DECL_DEPRECATED void setUseAdvancedEffects(bool use)
void updateDataDefinedProperties(QgsRenderContext &context)
Updates any data-defined properties in the settings, using the specified render context.
double fontAscentMillimeters(const QFont &font) const
Returns the font ascent in Millimeters (considers upscaling and downscaling with FONT_WORKAROUND_SCAL...
QgsLegendStyle style(Qgis::LegendComponent s) const
Returns the style for a legend component.
Q_DECL_DEPRECATED int dpi() const
QFont scaledFontPixelSize(const QFont &font) const
Returns a font where size is in pixel and font size is upscaled with FONT_WORKAROUND_SCALE.
Q_DECL_DEPRECATED double mapUnitsPerPixel() const
Returns the factor of map units per pixel for symbols with size given in map units calculated by dpi ...
Q_DECL_DEPRECATED double mmPerMapUnit() const
QStringList evaluateItemText(const QString &text, const QgsExpressionContext &context) const
Splits a string using the wrap char taking into account handling empty wrap char which means no wrapp...
Qgis::LegendJsonRenderFlags jsonRenderFlags() const
Returns the JSON export flags.
QStringList splitStringForWrapping(const QString &stringToSplt) const
Splits a string using the wrap char taking into account handling empty wrap char which means no wrapp...
Q_DECL_DEPRECATED double mapScale() const
Returns the legend map scale.
void setIndent(double indent)
Sets the indent (in mm) of a group or subgroup.
QgsTextFormat & textFormat()
Returns the text format used for rendering this legend component.
void setMargin(Side side, double margin)
Sets the margin (in mm) for the specified side of the component.
void updateDataDefinedProperties(QgsRenderContext &context)
Updates any data-defined properties in the style, using the specified render context.
@ Left
Left side.
@ Bottom
Bottom side.
void setTextFormat(const QgsTextFormat &format)
Sets the text format used for rendering this legend component.
Contains information about the context of a rendering operation.
Scoped object for saving and restoring a QPainter object's state.
Container for all settings relating to text rendering.
void setColor(const QColor &color)
Sets the color that text will be rendered in.
void setSize(double size)
Sets the size for rendered text.
void setSizeUnit(Qgis::RenderUnit unit)
Sets the units for the size of rendered text.
void setLineHeightUnit(Qgis::RenderUnit unit)
Sets the unit for the line height for text.
double size() const
Returns the size for rendered text.
QColor color() const
Returns the color that text will be rendered in.
void setLineHeight(double height)
Sets the line height for text.
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
#define SIP_DEPRECATED
Definition qgis_sip.h:106
#define FONT_WORKAROUND_SCALE