QGIS API Documentation 3.99.0-Master (2fe06baccd8)
Loading...
Searching...
No Matches
qgslayoutitemelevationprofile.h
Go to the documentation of this file.
1/***************************************************************************
2 qgslayoutitemelevationprofile.h
3 -------------------------------
4 begin : January 2023
5 copyright : (C) 2023 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 QGSLAYOUTITEMELEVATIONPROFILE_H
18#define QGSLAYOUTITEMELEVATIONPROFILE_H
19
20#include "qgis_core.h"
21#include "qgslayoutitem.h"
22#include "qgsmaplayerref.h"
23
24class QgsLayoutItemElevationProfilePlot;
25class Qgs2DXyPlot;
28class QgsLineSymbol;
29
36{
37 Q_OBJECT
38
39 public:
40
45
47
54
55 int type() const override;
56 QIcon icon() const override;
58 QgsLayoutItem::Flags itemFlags() const override;
59 bool requiresRasterization() const override;
60 bool containsAdvancedEffects() const override;
61
67
72 const Qgs2DXyPlot *plot() const SIP_SKIP;
73
79 QList< QgsMapLayer * > layers() const;
80
86 void setLayers( const QList< QgsMapLayer * > &layers );
87
95 QList<QgsAbstractProfileSource *> sources() const;
96
102 void setSources( const QList<QgsAbstractProfileSource *> &sources );
103
114
122 QgsCurve *profileCurve() const;
123
132
141
152 void setTolerance( double tolerance );
153
164 double tolerance() const;
165
171 bool atlasDriven() const { return mAtlasDriven; }
172
180 void setAtlasDriven( bool enabled );
181
185 QgsProfileRequest profileRequest() const;
186
187 void paint( QPainter *painter, const QStyleOptionGraphicsItem *itemStyle, QWidget *pWidget ) override;
188
195 Qgis::DistanceUnit distanceUnit() const;
196
203 void setDistanceUnit( Qgis::DistanceUnit unit );
204
212 {
213 return mSubsectionsSymbol.get();
214 }
215
223 void setSubsectionsSymbol( QgsLineSymbol *symbol SIP_TRANSFER );
224
225 public slots:
226
227 void refresh() override;
228 void invalidateCache() override;
229
230 signals:
231
238
239 protected:
240 void draw( QgsLayoutItemRenderContext &context ) override;
241 bool writePropertiesToElement( QDomElement &element, QDomDocument &document, const QgsReadWriteContext &context ) const override;
242 bool readPropertiesFromElement( const QDomElement &element, const QDomDocument &document, const QgsReadWriteContext &context ) override;
243
244 private slots:
245
246 void recreateCachedImageInBackground();
247 void profileGenerationFinished();
248 void setSourcesPrivate();
249
250 private:
251
252 std::unique_ptr< QgsLayoutItemElevationProfilePlot > mPlot;
253
254 QList< QgsMapLayerRef > mLayers;
255 QList< QgsAbstractProfileSource * > mSources;
256
259 std::unique_ptr< QgsCurve> mCurve;
260 bool mAtlasDriven = false;
261
262 double mTolerance = 0;
263
264 std::unique_ptr<QgsLineSymbol> mSubsectionsSymbol;
265
266 // render job handling
267
268 // see note in QgsLayoutItemMap about these!
269 std::unique_ptr< QImage > mCacheFinalImage;
270 std::unique_ptr< QImage > mCacheRenderingImage;
271 bool mUpdatesEnabled = true;
272 bool mCacheInvalidated = true;
273 bool mDrawing = false;
274 bool mDrawingPreview = false;
275 QTimer *mBackgroundUpdateTimer = nullptr;
276 double mPreviewScaleFactor = 0;
277 std::unique_ptr< QPainter > mPainter;
278 std::unique_ptr< QgsProfilePlotRenderer > mRenderJob;
279
280
281};
282
283#endif //QGSLAYOUTITEMELEVATIONPROFILE_H
DistanceUnit
Units of distance.
Definition qgis.h:5013
@ Unknown
Unknown distance unit.
Definition qgis.h:5063
Base class for 2-dimensional plot/chart/graphs with an X and Y axes.
Definition qgsplot.h:659
Represents a coordinate reference system (CRS).
Abstract base class for curved geometry type.
Definition qgscurve.h:36
static QgsLayoutItemElevationProfile * create(QgsLayout *layout)
Returns a new elevation profile item for the specified layout.
Qgs2DXyPlot * plot()
Returns a reference to the elevation plot object, which can be used to set plot appearance and proper...
QgsLayoutItemElevationProfile(QgsLayout *layout)
Constructor for QgsLayoutItemElevationProfile, with the specified parent layout.
QgsCurve * profileCurve() const
Returns the cross section profile curve, which represents the line along which the profile should be ...
void setLayers(const QList< QgsMapLayer * > &layers)
Sets the list of map layers participating in the elevation profile.
QList< QgsMapLayer * > layers() const
Returns the list of map layers participating in the elevation profile.
void setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the desired Coordinate Reference System (crs) for the profile.
QList< QgsAbstractProfileSource * > sources() const
Returns the list of sources participating in the elevation profile.
void setTolerance(double tolerance)
Sets the tolerance of the request (in crs() units).
QgsCoordinateReferenceSystem crs() const
Returns the desired Coordinate Reference System for the profile.
double tolerance() const
Returns the tolerance of the request (in crs() units).
QgsLineSymbol * subsectionsSymbol()
Returns the symbol used to draw the subsections.
bool atlasDriven() const
Returns whether the profile curve is set to follow the current atlas feature.
void setSources(const QList< QgsAbstractProfileSource * > &sources)
Sets the list of sources participating in the elevation profile.
void previewRefreshed()
Emitted whenever the item's preview has been refreshed.
void setProfileCurve(QgsCurve *curve)
Sets the cross section profile curve, which represents the line along which the profile should be gen...
Contains settings and helpers relating to a render of a QgsLayoutItem.
friend class QgsLayout
virtual void refreshDataDefinedProperty(QgsLayoutObject::DataDefinedProperty property=QgsLayoutObject::DataDefinedProperty::AllProperties)
Refreshes a data defined property for the item by reevaluating the property's value and redrawing the...
QgsLayoutItem(QgsLayout *layout, bool manageZValue=true)
Constructor for QgsLayoutItem, with the specified parent layout.
virtual QIcon icon() const
Returns the item's icon.
void paint(QPainter *painter, const QStyleOptionGraphicsItem *itemStyle, QWidget *pWidget) override
Handles preparing a paint surface for the layout item and painting the item's content.
virtual bool writePropertiesToElement(QDomElement &element, QDomDocument &document, const QgsReadWriteContext &context) const
Stores item state within an XML DOM element.
int type() const override
Returns a unique graphics item type identifier.
virtual bool requiresRasterization() const
Returns true if the item is drawn in such a way that forces the whole layout to be rasterized when ex...
virtual bool containsAdvancedEffects() const
Returns true if the item contains contents with blend modes or transparency effects which can only be...
virtual void invalidateCache()
Forces a deferred update of any cached image the item uses.
virtual Flags itemFlags() const
Returns the item's flags, which indicate how the item behaves.
virtual bool readPropertiesFromElement(const QDomElement &element, const QDomDocument &document, const QgsReadWriteContext &context)
Sets item state from a DOM element.
QFlags< Flag > Flags
void refresh() override
Refreshes the item, causing a recalculation of any property overrides and recalculation of its positi...
friend class QgsLayoutItemElevationProfile
virtual void draw(QgsLayoutItemRenderContext &context)=0
Draws the item's contents using the specified item render context.
const QgsLayout * layout() const
Returns the layout the object is attached to.
DataDefinedProperty
Data defined properties for different item types.
@ AllProperties
All properties for item.
A line symbol type, for rendering LineString and MultiLineString geometries.
Generates and renders elevation profile plots.
Encapsulates properties and constraints relating to fetching elevation profiles from different source...
A container for the context for various read/write operations on objects.
#define SIP_SKIP
Definition qgis_sip.h:134
#define SIP_TRANSFER
Definition qgis_sip.h:36
#define SIP_FACTORY
Definition qgis_sip.h:84