QGIS API Documentation  3.24.2-Tisler (13c1a02865)
qgslabellinesettings.cpp
Go to the documentation of this file.
1 /***************************************************************************
2  qgslabellinesettings.cpp
3  ----------------------------
4  Date : August 2020
5  Copyright : (C) 2020 by 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 "qgslabellinesettings.h"
17 #include "qgspropertycollection.h"
18 #include "qgsexpressioncontext.h"
19 #include "qgslabelingengine.h"
20 #include "qgspallabeling.h"
21 
22 
24 {
26  {
28  const QString dataDefinedLineArrangement = properties.valueAsString( QgsPalLayerSettings::LinePlacementOptions, context );
29  if ( !dataDefinedLineArrangement.isEmpty() )
30  {
31  mPlacementFlags = QgsLabelingUtils::decodeLinePlacementFlags( dataDefinedLineArrangement );
32  }
33  }
34 
36  {
37  context.setOriginalValueVariable( mOverrunDistance );
38  mOverrunDistance = properties.valueAsDouble( QgsPalLayerSettings::OverrunDistance, context, mOverrunDistance );
39  }
40 
42  {
43  context.setOriginalValueVariable( mLineAnchorPercent );
44  mLineAnchorPercent = properties.valueAsDouble( QgsPalLayerSettings::LineAnchorPercent, context, mLineAnchorPercent );
45  }
46 
48  {
49  bool ok = false;
50  const QString value = properties.valueAsString( QgsPalLayerSettings::LineAnchorClipping, context, QString(), &ok ).trimmed();
51  if ( ok )
52  {
53  if ( value.compare( QLatin1String( "visible" ), Qt::CaseInsensitive ) == 0 )
54  mAnchorClipping = AnchorClipping::UseVisiblePartsOfLine;
55  else if ( value.compare( QLatin1String( "entire" ), Qt::CaseInsensitive ) == 0 )
56  mAnchorClipping = AnchorClipping::UseEntireLine;
57  }
58  }
59 }
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.
QString valueAsString(int key, const QgsExpressionContext &context, const QString &defaultString=QString(), bool *ok=nullptr) const
Calculates the current value of the property with the specified key and interprets it as a string.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
void setOriginalValueVariable(const QVariant &value)
Sets the original value variable value for the context.
@ UseEntireLine
Entire original feature line geometry is used when calculating the line anchor for labels.
@ UseVisiblePartsOfLine
Only visible parts of lines are considered when calculating the line anchor for labels.
void updateDataDefinedProperties(const QgsPropertyCollection &properties, QgsExpressionContext &context)
Updates the thinning settings to respect any data defined properties set within the specified propert...
static QString encodeLinePlacementFlags(QgsLabeling::LinePlacementFlags flags)
Encodes line placement flags to a string.
static QgsLabeling::LinePlacementFlags decodeLinePlacementFlags(const QString &string)
Decodes a string to set of line placement flags.
@ OverrunDistance
Distance which labels can extend past either end of linear features.
@ LineAnchorPercent
Portion along line at which labels should be anchored (since QGIS 3.16)
@ LineAnchorClipping
Clipping mode for line anchor calculation (since QGIS 3.20)
@ LinePlacementOptions
Line placement flags.
A grouped map of multiple QgsProperty objects, each referenced by a integer key value.
bool isActive(int key) const override
Returns true if the collection contains an active property with the specified key.