QGIS API Documentation 3.43.0-Master (b60ef06885e)
qgsrendererrange.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsrendererrange.h
3 ---------------------
4 begin : September 2019
5 copyright : (C) 2019 by Denis Rouzaud
6 email : denis@opengis.ch
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#ifndef QGSRENDERERRANGE_H
17#define QGSRENDERERRANGE_H
18
19#include "qgis_core.h"
20#include "qgis_sip.h"
21#include "qgssymbollayerutils.h"
22
23#include <QRegularExpression>
24
25class QDomDocument;
26class QDomElement;
27
28class QgsSymbol;
30
31
37class CORE_EXPORT QgsRendererRange
38{
39 public:
40
41 QgsRendererRange() = default;
43
51 QgsRendererRange( const QgsClassificationRange &range, QgsSymbol *symbol SIP_TRANSFER, bool render = true, const QString &uuid = QString() );
52
62 QgsRendererRange( double lowerValue, double upperValue, QgsSymbol *symbol SIP_TRANSFER, const QString &label, bool render = true, const QString &uuid = QString() );
63 QgsRendererRange( const QgsRendererRange &range );
64
65 // default dtor is OK
66 QgsRendererRange &operator=( QgsRendererRange range );
67
68 bool operator<( const QgsRendererRange &other ) const;
69
74 QString uuid() const;
75
82 double lowerValue() const;
83
90 double upperValue() const;
91
97 QgsSymbol *symbol() const;
98
104 QString label() const;
105
113 void setSymbol( QgsSymbol *s SIP_TRANSFER );
114
120 void setLabel( const QString &label );
121
128 void setLowerValue( double lowerValue );
129
136 void setUpperValue( double upperValue );
137
143 bool renderState() const;
144
150 void setRenderState( bool render );
151
155 QString dump() const;
156
165 void toSld( QDomDocument &doc, QDomElement &element, QVariantMap props, bool firstRange = false ) const;
166
167#ifdef SIP_RUN
168 SIP_PYOBJECT __repr__();
169 % MethodCode
170 const QString str = sipCpp->label().isEmpty()
171 ? QStringLiteral( "<QgsRendererRange: %1 - %2>" ).arg( sipCpp->lowerValue() ).arg( sipCpp->upperValue() )
172 : QStringLiteral( "<QgsRendererRange: %1 - %2 (%3)>" ).arg( sipCpp->lowerValue() ).arg( sipCpp->upperValue() ).arg( sipCpp->label() );
173 sipRes = PyUnicode_FromString( str.toUtf8().constData() );
174 % End
175
176 SIP_PYOBJECT __getitem__( int );
177 % MethodCode
178 if ( a0 == 0 )
179 {
180 sipRes = Py_BuildValue( "d", sipCpp->lowerValue() );
181 }
182 else if ( a0 == 1 )
183 {
184 sipRes = Py_BuildValue( "d", sipCpp->upperValue() );
185 }
186 else
187 {
188 QString msg = QString( "Bad index: %1" ).arg( a0 );
189 PyErr_SetString( PyExc_IndexError, msg.toLatin1().constData() );
190 }
191 % End
192#endif
193
194 protected:
195 double mLowerValue = 0, mUpperValue = 0;
196 std::unique_ptr<QgsSymbol> mSymbol;
197 QString mLabel;
198 bool mRender = true;
199 QString mUuid;
200};
201
202typedef QList<QgsRendererRange> QgsRangeList;
203
204
212class CORE_DEPRECATED_EXPORT QgsRendererRangeLabelFormat SIP_DEPRECATED
213{
214 public:
216 QgsRendererRangeLabelFormat( const QString &format, int precision = 4, bool trimTrailingZeroes = false );
217
218 bool operator==( const QgsRendererRangeLabelFormat &other ) const;
219 bool operator!=( const QgsRendererRangeLabelFormat &other ) const;
220
221 QString format() const { return mFormat; }
222 void setFormat( const QString &format ) { mFormat = format; }
223
224 int precision() const { return mPrecision; }
225 void setPrecision( int precision );
226
227 bool trimTrailingZeroes() const { return mTrimTrailingZeroes; }
228 void setTrimTrailingZeroes( bool trimTrailingZeroes ) { mTrimTrailingZeroes = trimTrailingZeroes; }
229
231 QString labelForRange( double lower, double upper ) const SIP_PYNAME( labelForLowerUpper );
232 QString labelForRange( const QgsRendererRange &range ) const;
233 QString formatNumber( double value ) const;
234
235 void setFromDomElement( QDomElement &element );
236 void saveToDomElement( QDomElement &element );
237
238 static const int MAX_PRECISION;
239 static const int MIN_PRECISION;
240
241 protected:
242 QString mFormat;
243 int mPrecision = 4;
244 bool mTrimTrailingZeroes = false;
245 // values used to manage number formatting - precision and trailing zeroes
246 double mNumberScale = 1.0;
248 QRegularExpression mReTrailingZeroes;
249 QRegularExpression mReNegativeZero;
250};
251
252
253#endif // QGSRENDERERRANGE_H
Contains the information about a classification range.
Encapsulates the formatting for a QgsRendererRange label.
void setFormat(const QString &format)
QRegularExpression mReTrailingZeroes
QRegularExpression mReNegativeZero
void setTrimTrailingZeroes(bool trimTrailingZeroes)
Represents a value range for a QgsGraduatedSymbolRenderer.
QgsRendererRange()=default
std::unique_ptr< QgsSymbol > mSymbol
Abstract base class for all rendered symbols.
Definition qgssymbol.h:231
bool operator<(const QVariant &v1, const QVariant &v2)
Compares two QVariant values and returns whether the first is less than the second.
Definition qgis.h:6687
#define SIP_DEPRECATED
Definition qgis_sip.h:106
#define SIP_PYNAME(name)
Definition qgis_sip.h:81
#define SIP_TRANSFER
Definition qgis_sip.h:36
bool operator==(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
bool operator!=(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
QList< QgsRendererRange > QgsRangeList
int precision