QGIS API Documentation 3.41.0-Master (d2aaa9c6e02)
Loading...
Searching...
No Matches
qgslayoutitemlabel.h
Go to the documentation of this file.
1/***************************************************************************
2 qgslayoutitemlabel.h
3 -------------------
4 begin : October 2017
5 copyright : (C) 2017 by Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17#ifndef QGSLAYOUTITEMLABEL_H
18#define QGSLAYOUTITEMLABEL_H
19
20#include "qgis_core.h"
21#include "qgslayoutitem.h"
22#include "qgstextformat.h"
23#include <QFont>
24#include <QUrl>
25
26class QgsVectorLayer;
27class QgsFeature;
28class QgsDistanceArea;
29
34class CORE_EXPORT QgsLayoutItemLabel: public QgsLayoutItem
35{
36 Q_OBJECT
37
38 public:
39
41 enum Mode
42 {
45 };
46
51
57 static QgsLayoutItemLabel *create( QgsLayout *layout ) SIP_FACTORY;
58
59 int type() const override;
60 QIcon icon() const override;
61 //Overridden to contain part of label's text
62 QString displayName() const override;
63
68 void adjustSizeToText();
69
78 void adjustSizeToText( QgsLayoutItem::ReferencePoint referencePoint );
79
84 QSizeF sizeForText() const;
85
91 QString text() const { return mText; }
92
97 void setText( const QString &text );
98
104 QString currentText() const;
105
110 Mode mode() const { return mMode; }
111
117 void setMode( Mode mode );
118
124 Q_DECL_DEPRECATED QFont font() const SIP_DEPRECATED;
125
131 Q_DECL_DEPRECATED void setFont( const QFont &font ) SIP_DEPRECATED;
132
138 Qt::AlignmentFlag vAlign() const { return mVAlignment; }
139
145 Qt::AlignmentFlag hAlign() const { return mHAlignment; }
146
152 void setHAlign( Qt::AlignmentFlag alignment ) { mHAlignment = alignment; invalidateCache(); }
153
159 void setVAlign( Qt::AlignmentFlag alignment ) { mVAlignment = alignment; invalidateCache(); }
160
167 double marginX() const { return mMarginX; }
168
175 double marginY() const { return mMarginY; }
176
188 void setMargin( double margin );
189
196 void setMarginX( double margin );
197
204 void setMarginY( double margin );
205
211 Q_DECL_DEPRECATED void setFontColor( const QColor &color ) SIP_DEPRECATED { mFormat.setColor( color ); }
212
218 Q_DECL_DEPRECATED QColor fontColor() const SIP_DEPRECATED { return mFormat.color(); }
219
220 // In case of negative margins, the bounding rect may be larger than the
221 // label's frame
222 QRectF boundingRect() const override;
223 void setFrameEnabled( bool drawFrame ) override;
224 void setFrameStrokeWidth( QgsLayoutMeasurement strokeWidth ) override;
225
231 QgsTextFormat textFormat() const;
232
238 void setTextFormat( const QgsTextFormat &format );
239
240 public slots:
241
242 void refresh() override;
243
250 void convertToStaticText();
251
252 protected:
253 void draw( QgsLayoutItemRenderContext &context ) override;
254 bool writePropertiesToElement( QDomElement &element, QDomDocument &document, const QgsReadWriteContext &context ) const override;
255 bool readPropertiesFromElement( const QDomElement &element, const QDomDocument &document, const QgsReadWriteContext &context ) override;
256
257 private slots:
258
259 void refreshExpressionContext();
261 void updateBoundingRect();
262
263 private:
264 // Text
265 QString mText;
266
267 Mode mMode = ModeFont;
268 double mHtmlUnitsToLayoutUnits = 1.0;
269 double htmlUnitsToLayoutUnits(); //calculate scale factor
270
272 void itemShiftAdjustSize( double newWidth, double newHeight, double &xShift, double &yShift ) const;
273
275 void contentChanged();
276
277 QgsTextFormat mFormat;
278
280 double mMarginX = 0.0;
282 double mMarginY = 0.0;
283
285 Qt::AlignmentFlag mHAlignment = Qt::AlignLeft;
286
288 Qt::AlignmentFlag mVAlignment = Qt::AlignTop;
289
291 void replaceDateText( QString &text ) const;
292
294 QFont createDefaultFont() const;
295
297 QUrl createStylesheetUrl() const;
298
300 QString createStylesheet() const;
301
302 std::unique_ptr< QgsDistanceArea > mDistanceArea;
303
304 QRectF mCurrentRectangle;
305
306 friend class QgsLayoutItemHtml;
307};
308
309#endif //QGSLAYOUTITEMLABEL_H
A general purpose distance and area calculator, capable of performing ellipsoid based calculations.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Definition qgsfeature.h:58
A layout multiframe subclass for HTML content.
A layout item subclass for text labels.
Mode mode() const
Returns the label's current mode.
void setHAlign(Qt::AlignmentFlag alignment)
Sets the horizontal alignment of the label.
Q_DECL_DEPRECATED QColor fontColor() const
Returns the label font color.
double marginX() const
Returns the horizontal margin between the edge of the frame and the label contents,...
double marginY() const
Returns the vertical margin between the edge of the frame and the label contents, in layout units.
QString text() const
Returns the label's preset text.
Q_DECL_DEPRECATED void setFontColor(const QColor &color)
Sets the label font color.
void setVAlign(Qt::AlignmentFlag alignment)
Sets for the vertical alignment of the label.
Qt::AlignmentFlag hAlign() const
Returns the horizontal alignment of the label.
@ ModeHtml
Label displays rendered HTML content.
@ ModeFont
Label displays text rendered using a single font.
Contains settings and helpers relating to a render of a QgsLayoutItem.
Base class for graphical items within a QgsLayout.
virtual void setFrameStrokeWidth(QgsLayoutMeasurement width)
Sets the frame stroke width.
virtual QIcon icon() const
Returns the item's icon.
ReferencePoint
Fixed position reference point.
virtual bool writePropertiesToElement(QDomElement &element, QDomDocument &document, const QgsReadWriteContext &context) const
Stores item state within an XML DOM element.
virtual void setFrameEnabled(bool drawFrame)
Sets whether this item has a frame drawn around it or not.
int type() const override
Returns a unique graphics item type identifier.
virtual QString displayName() const
Gets item display name.
virtual void invalidateCache()
Forces a deferred update of any cached image the item uses.
virtual bool readPropertiesFromElement(const QDomElement &element, const QDomDocument &document, const QgsReadWriteContext &context)
Sets item state from a DOM element.
void refresh() override
Refreshes the item, causing a recalculation of any property overrides and recalculation of its positi...
virtual void draw(QgsLayoutItemRenderContext &context)=0
Draws the item's contents using the specified item render context.
This class provides a method of storing measurements for use in QGIS layouts using a variety of diffe...
Base class for layouts, which can contain items such as maps, labels, scalebars, etc.
Definition qgslayout.h:49
The class is used as a container of context for various read/write operations on other objects.
Container for all settings relating to text rendering.
Represents a vector layer which manages a vector based data sets.
#define SIP_DEPRECATED
Definition qgis_sip.h:106
#define SIP_FACTORY
Definition qgis_sip.h:76