QGIS API Documentation 3.28.0-Firenze (ed3ad0430f)
qgstextmasksettings.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgstextmasksettings.cpp
3 -----------------
4 begin : May 2020
5 copyright : (C) Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#include "qgstextmasksettings.h"
17#include "qgstextrenderer_p.h"
18#include "qgspallabeling.h"
19#include "qgssymbollayerutils.h"
21#include "qgsapplication.h"
22
24{
25 d = new QgsTextMaskSettingsPrivate();
26}
27
29
31 : d( other.d )
32{
33}
34
36{
37 d = other.d;
38 return *this;
39}
40
42{
43 if ( d->enabled != other.enabled()
44 || d->type != other.type()
45 || d->size != other.size()
46 || d->sizeUnit != other.sizeUnit()
47 || d->sizeMapUnitScale != other.sizeMapUnitScale()
48 || d->joinStyle != other.joinStyle()
49 || d->opacity != other.opacity()
50 || d->maskedSymbolLayers != other.maskedSymbolLayers() )
51 return false;
52
53 if ( static_cast< bool >( d->paintEffect ) != static_cast< bool >( other.paintEffect() )
54 || ( d->paintEffect && d->paintEffect->properties() != other.paintEffect()->properties() ) )
55 return false;
56
57 return true;
58}
59
61{
62 return !( *this == other );
63}
64
66{
67 return d->enabled;
68}
69
71{
72 d->enabled = enabled;
73}
74
76{
77 return d->type;
78}
79
81{
82 d->type = type;
83}
84
85
87{
88 return d->size;
89}
90
92{
93 d->size = size;
94}
95
97{
98 return d->sizeUnit;
99}
100
102{
103 d->sizeUnit = unit;
104}
105
107{
108 return d->sizeMapUnitScale;
109}
110
112{
113 d->sizeMapUnitScale = scale;
114}
115
116Qt::PenJoinStyle QgsTextMaskSettings::joinStyle() const
117{
118 return d->joinStyle;
119}
120
121void QgsTextMaskSettings::setJoinStyle( Qt::PenJoinStyle style )
122{
123 d->joinStyle = style;
124}
125
127{
128 return d->opacity;
129}
130
132{
133 d->opacity = opacity;
134}
135
137{
138 return d->paintEffect.get();
139}
140
142{
143 d->paintEffect.reset( effect );
144}
145
147{
148 if ( properties.isActive( QgsPalLayerSettings::MaskEnabled ) )
149 {
150 context.expressionContext().setOriginalValueVariable( d->enabled );
151 d->enabled = properties.valueAsBool( QgsPalLayerSettings::MaskEnabled, context.expressionContext(), d->enabled );
152 }
153
155 {
156 context.expressionContext().setOriginalValueVariable( d->size );
157 d->size = properties.valueAsDouble( QgsPalLayerSettings::MaskBufferSize, context.expressionContext(), d->size );
158 }
159
161 {
162 const QVariant exprVal = properties.value( QgsPalLayerSettings::MaskBufferUnit, context.expressionContext() );
163 if ( !QgsVariantUtils::isNull( exprVal ) )
164 {
165 const QString units = exprVal.toString();
166 if ( !units.isEmpty() )
167 {
168 bool ok;
170 if ( ok )
171 d->sizeUnit = res;
172 }
173 }
174 }
175
176 if ( properties.isActive( QgsPalLayerSettings::MaskOpacity ) )
177 {
178 context.expressionContext().setOriginalValueVariable( d->opacity * 100 );
179 const QVariant val = properties.value( QgsPalLayerSettings::MaskOpacity, context.expressionContext(), d->opacity * 100 );
180 if ( !QgsVariantUtils::isNull( val ) )
181 {
182 d->opacity = val.toDouble() / 100.0;
183 }
184 }
185
187 {
188 const QVariant exprVal = properties.value( QgsPalLayerSettings::MaskJoinStyle, context.expressionContext() );
189 const QString joinstr = exprVal.toString().trimmed();
190 if ( !joinstr.isEmpty() )
191 {
192 d->joinStyle = QgsSymbolLayerUtils::decodePenJoinStyle( joinstr );
193 }
194 }
195}
196
198{
199 return QSet< QString >(); // nothing for now
200}
201
202void QgsTextMaskSettings::readXml( const QDomElement &elem )
203{
204 const QDomElement textMaskElem = elem.firstChildElement( QStringLiteral( "text-mask" ) );
205 d->enabled = textMaskElem.attribute( QStringLiteral( "maskEnabled" ), QStringLiteral( "0" ) ).toInt();
206 d->type = static_cast<QgsTextMaskSettings::MaskType>( textMaskElem.attribute( QStringLiteral( "maskType" ), QStringLiteral( "0" ) ).toInt() );
207 d->size = textMaskElem.attribute( QStringLiteral( "maskSize" ), QStringLiteral( "0" ) ).toDouble();
208 d->sizeUnit = QgsUnitTypes::decodeRenderUnit( textMaskElem.attribute( QStringLiteral( "maskSizeUnits" ) ) );
209 d->sizeMapUnitScale = QgsSymbolLayerUtils::decodeMapUnitScale( textMaskElem.attribute( QStringLiteral( "maskSizeMapUnitScale" ) ) );
210 d->joinStyle = static_cast< Qt::PenJoinStyle >( textMaskElem.attribute( QStringLiteral( "maskJoinStyle" ), QString::number( Qt::RoundJoin ) ).toUInt() );
211 d->opacity = textMaskElem.attribute( QStringLiteral( "maskOpacity" ), QStringLiteral( "1.0" ) ).toDouble();
212 const QDomElement effectElem = textMaskElem.firstChildElement( QStringLiteral( "effect" ) );
213 if ( !effectElem.isNull() )
215 else
216 setPaintEffect( nullptr );
217 d->maskedSymbolLayers = stringToSymbolLayerReferenceList( textMaskElem.attribute( QStringLiteral( "maskedSymbolLayers" ) ) );
218}
219
220QDomElement QgsTextMaskSettings::writeXml( QDomDocument &doc ) const
221{
222 QDomElement textMaskElem = doc.createElement( QStringLiteral( "text-mask" ) );
223 textMaskElem.setAttribute( QStringLiteral( "maskEnabled" ), d->enabled );
224 textMaskElem.setAttribute( QStringLiteral( "maskType" ), d->type );
225 textMaskElem.setAttribute( QStringLiteral( "maskSize" ), d->size );
226 textMaskElem.setAttribute( QStringLiteral( "maskSizeUnits" ), QgsUnitTypes::encodeUnit( d->sizeUnit ) );
227 textMaskElem.setAttribute( QStringLiteral( "maskSizeMapUnitScale" ), QgsSymbolLayerUtils::encodeMapUnitScale( d->sizeMapUnitScale ) );
228 textMaskElem.setAttribute( QStringLiteral( "maskJoinStyle" ), static_cast< unsigned int >( d->joinStyle ) );
229 textMaskElem.setAttribute( QStringLiteral( "maskOpacity" ), d->opacity );
230 if ( d->paintEffect && !QgsPaintEffectRegistry::isDefaultStack( d->paintEffect.get() ) )
231 d->paintEffect->saveProperties( doc, textMaskElem );
232 textMaskElem.setAttribute( QStringLiteral( "maskedSymbolLayers" ), symbolLayerReferenceListToString( d->maskedSymbolLayers ) );
233 return textMaskElem;
234}
235
236QList<QgsSymbolLayerReference> QgsTextMaskSettings::maskedSymbolLayers() const
237{
238 return d->maskedSymbolLayers;
239}
240
241void QgsTextMaskSettings::setMaskedSymbolLayers( const QList<QgsSymbolLayerReference> &maskedSymbols )
242{
243 d->maskedSymbolLayers = maskedSymbols;
244}
bool valueAsBool(int key, const QgsExpressionContext &context, bool defaultValue=false, bool *ok=nullptr) const
Calculates the current value of the property with the specified key and interprets it as an boolean.
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.
void setOriginalValueVariable(const QVariant &value)
Sets the original value variable value for the context.
Struct for storing maximum and minimum scales for measurements in map units.
static bool isDefaultStack(QgsPaintEffect *effect)
Tests whether a paint effect matches the default effects stack.
QgsPaintEffect * createEffect(const QString &name, const QVariantMap &properties=QVariantMap()) const
Creates a new paint effect given the effect name and properties map.
Base class for visual effects which can be applied to QPicture drawings.
virtual QVariantMap properties() const =0
Returns the properties describing the paint effect encoded in a string format.
@ MaskEnabled
Whether the mask is enabled.
@ MaskJoinStyle
Mask join style.
@ MaskBufferUnit
Mask buffer size unit.
@ MaskBufferSize
Mask buffer size.
@ MaskOpacity
Mask opacity.
A grouped map of multiple QgsProperty objects, each referenced by a integer key value.
QVariant value(int key, const QgsExpressionContext &context, const QVariant &defaultValue=QVariant()) const override
Returns the calculated value of the property with the specified key from within the collection.
bool isActive(int key) const override
Returns true if the collection contains an active property with the specified key.
Contains information about the context of a rendering operation.
QgsExpressionContext & expressionContext()
Gets the expression context.
static Qt::PenJoinStyle decodePenJoinStyle(const QString &str)
static QString encodeMapUnitScale(const QgsMapUnitScale &mapUnitScale)
static QgsMapUnitScale decodeMapUnitScale(const QString &str)
Container for settings relating to a selective masking around a text.
void setEnabled(bool)
Returns whether the mask is enabled.
void setMaskedSymbolLayers(const QList< QgsSymbolLayerReference > &maskedLayers)
Sets the symbol layers that will be masked by this buffer.
MaskType
Mask shape types.
QList< QgsSymbolLayerReference > maskedSymbolLayers() const
Returns a list of references to symbol layers that are masked by this buffer.
void setSize(double size)
Sets the size of the buffer.
QSet< QString > referencedFields(const QgsRenderContext &context) const
Returns all field names referenced by the configuration (e.g.
QgsMapUnitScale sizeMapUnitScale() const
Returns the map unit scale object for the buffer size.
double size() const
Returns the size of the buffer.
void setSizeMapUnitScale(const QgsMapUnitScale &scale)
Sets the map unit scale object for the buffer size.
void updateDataDefinedProperties(QgsRenderContext &context, const QgsPropertyCollection &properties)
Updates the format by evaluating current values of data defined properties.
void readXml(const QDomElement &elem)
Read settings from a DOM element.
void setSizeUnit(QgsUnitTypes::RenderUnit unit)
Sets the units used for the buffer size.
QDomElement writeXml(QDomDocument &doc) const
Write settings into a DOM element.
QgsPaintEffect * paintEffect() const
Returns the current paint effect for the mask.
void setJoinStyle(Qt::PenJoinStyle style)
Sets the join style used for drawing the buffer.
QgsUnitTypes::RenderUnit sizeUnit() const
Returns the units for the buffer size.
double opacity() const
Returns the mask's opacity.
bool enabled() const
Returns whether the mask is enabled.
bool operator==(const QgsTextMaskSettings &other) const
void setPaintEffect(QgsPaintEffect *effect)
Sets the current paint effect for the mask.
Qt::PenJoinStyle joinStyle() const
Returns the buffer join style.
void setType(MaskType type)
Sets the type of mask shape.
MaskType type() const
Returns the type of mask shape.
bool operator!=(const QgsTextMaskSettings &other) const
QgsTextMaskSettings & operator=(const QgsTextMaskSettings &other)
Copy constructor.
void setOpacity(double opacity)
Sets the mask's opacity.
static Q_INVOKABLE QString encodeUnit(QgsUnitTypes::DistanceUnit unit)
Encodes a distance unit to a string.
static Q_INVOKABLE QgsUnitTypes::RenderUnit decodeRenderUnit(const QString &string, bool *ok=nullptr)
Decodes a render unit from a string.
RenderUnit
Rendering size units.
Definition: qgsunittypes.h:168
static bool isNull(const QVariant &variant)
Returns true if the specified variant should be considered a NULL value.
QString symbolLayerReferenceListToString(const QgsSymbolLayerReferenceList &lst)
Utilitary function to turn a QgsSymbolLayerReferenceList into a string.
QgsSymbolLayerReferenceList stringToSymbolLayerReferenceList(const QString &str)
Utilitary function to parse a string originated from symbolLayerReferenceListToString into a QgsSymbo...