QGIS API Documentation 3.99.0-Master (26c88405ac0)
Loading...
Searching...
No Matches
qgselevationprofilecanvas.h
Go to the documentation of this file.
1/***************************************************************************
2 qgselevationprofilecanvas.h
3 ---------------
4 begin : March 2022
5 copyright : (C) 2022 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
18#ifndef QGSELEVATIONPROFILECANVAS_H
19#define QGSELEVATIONPROFILECANVAS_H
20
21#include "qgsconfig.h"
22
23#include "qgis_gui.h"
24#include "qgis_sip.h"
26#include "qgslinesymbol.h"
27#include "qgsmaplayer.h"
28#include "qgsplotcanvas.h"
29#include "qgsprofilepoint.h"
30
31class QgsElevationProfilePlotItem;
32class QgsElevationProfileCrossHairsItem;
35class QgsCurve;
36class Qgs2DXyPlot;
40class QgsScreenHelper;
41
49{
50 Q_OBJECT
51
52 public:
53
57 QgsElevationProfileCanvas( QWidget *parent SIP_TRANSFERTHIS = nullptr );
58
60 QgsCoordinateReferenceSystem crs() const override;
61 QgsPoint toMapCoordinates( const QgsPointXY &point ) const override;
62 QgsPointXY toCanvasCoordinates( const QgsPoint &point ) const override;
63 void resizeEvent( QResizeEvent *event ) override;
64 void paintEvent( QPaintEvent *event ) override;
65 void cancelJobs() override SIP_SKIP;
66 void panContentsBy( double dx, double dy ) override;
67 void centerPlotOn( double x, double y ) override;
68 void scalePlot( double factor ) override;
69 QgsPointXY snapToPlot( QPoint point ) override;
70
74 void scalePlot( double xFactor, double yFactor );
75
76 void zoomToRect( const QRectF &rect ) override;
77 void wheelZoom( QWheelEvent *event ) override;
78 void mouseMoveEvent( QMouseEvent *e ) override;
79
83 QRectF plotArea() const;
84
89 void refresh() override;
90
96
103 void setProject( QgsProject *project );
104
110 void setLayers( const QList<QgsMapLayer *> &layers );
111
117 QList<QgsMapLayer *> layers() const;
118
124 void setSources( const QList<QgsAbstractProfileSource *> &sources );
125
133 QList<QgsAbstractProfileSource *> sources() const;
134
141
152
160 QgsCurve *profileCurve() const;
161
171 void setTolerance( double tolerance );
172
182 double tolerance() const { return mTolerance; }
183
190 void setVisiblePlotRange( double minimumDistance, double maximumDistance, double minimumElevation, double maximumElevation );
191
198 QgsDoubleRange visibleDistanceRange() const;
199
206 QgsDoubleRange visibleElevationRange() const;
207
213 const Qgs2DXyPlot &plot() const SIP_SKIP;
214
218 void render( QgsRenderContext &context, double width, double height, const Qgs2DXyPlot &plotSettings );
219
223 QVector<QgsProfileIdentifyResults> identify( QPointF point );
224
228 QVector<QgsProfileIdentifyResults> identify( const QRectF &rect );
229
235 QgsProfilePoint canvasPointToPlotPoint( QPointF point ) const;
236
242 QgsPointXY plotPointToCanvasPoint( const QgsProfilePoint &point ) const;
243
250 bool lockAxisScales() const;
251
258 void setLockAxisScales( bool lock );
259
267 double axisScaleRatio() const;
268
281 void setAxisScaleRatio( double scale );
282
289 Qgis::DistanceUnit distanceUnit() const;
290
297 void setDistanceUnit( Qgis::DistanceUnit unit );
298
307 void setBackgroundColor( const QColor &color );
308
316 {
317 return mSubsectionsSymbol.get();
318 }
319
327 void setSubsectionsSymbol( QgsLineSymbol *symbol SIP_TRANSFER );
328
329 signals:
330
334 void activeJobCountChanged( int count );
335
341 void canvasPointHovered( const QgsPointXY &point, const QgsProfilePoint &profilePoint );
342
349
350 public slots:
351
355 void zoomFull();
356
360 void clear();
361
365 void setSnappingEnabled( bool enabled );
366
367 private slots:
368
369 void generationFinished();
370 void onLayerProfileGenerationPropertyChanged();
371 void onLayerProfileRendererPropertyChanged();
372 void regenerateResultsForLayer();
373 void scheduleDeferredRegeneration();
374 void scheduleDeferredRedraw();
375 void startDeferredRegeneration();
376 void startDeferredRedraw();
377 void refineResults();
378 void setSourcesPrivate();
379
380 private:
381 void updateChartFromPalette();
382 QgsProfileSnapContext snapContext() const;
383 QgsProfileIdentifyContext identifyContext() const;
384
385 void setupLayerConnections( QgsMapLayer *layer, bool isDisconnect );
386
387 void adjustRangeForAxisScaleLock( double &xMinimum, double &xMaximum, double &yMinimum, double &yMaximum ) const;
388
389 QgsScreenHelper *mScreenHelper = nullptr;
390
391 bool mLockAxisScales = false;
392 double mLockedAxisScale = 1;
393
395 QgsProject *mProject = nullptr;
397
399 QList< QgsAbstractProfileSource * > mSources;
400
401 QgsElevationProfilePlotItem *mPlotItem = nullptr;
402 QgsElevationProfileCrossHairsItem *mCrossHairsItem = nullptr;
403
404 QgsProfilePlotRenderer *mCurrentJob = nullptr;
405 QTimer *mDeferredRegenerationTimer = nullptr;
406 bool mDeferredRegenerationScheduled = false;
407 QTimer *mDeferredRedrawTimer = nullptr;
408 bool mDeferredRedrawScheduled = false;
409
410 std::unique_ptr<QgsCurve> mProfileCurve;
411 double mTolerance = 0;
412
413 bool mFirstDrawOccurred = false;
414
415 bool mSnappingEnabled = true;
416
417 bool mZoomFullWhenJobFinished = true;
418
419 bool mForceRegenerationAfterCurrentJobCompletes = false;
420
421 static constexpr double MAX_ERROR_PIXELS = 2;
422
423 std::unique_ptr<QgsLineSymbol> mSubsectionsSymbol;
424};
425
426#endif // QGSELEVATIONPROFILECANVAS_H
Provides global constants and enumerations for use throughout the application.
Definition qgis.h:56
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
Abstract base class for storage of elevation profiles.
Represents a coordinate reference system (CRS).
Abstract base class for curved geometry type.
Definition qgscurve.h:36
QgsRange which stores a range of double values.
Definition qgsrange.h:233
QgsCurve * profileCurve() const
Returns the profile curve.
void setTolerance(double tolerance)
Sets the profile tolerance (in crs() units).
void setSources(const QList< QgsAbstractProfileSource * > &sources)
Sets the list of sources to include in the profile.
void setProfileCurve(QgsCurve *curve)
Sets the profile curve.
void activeJobCountChanged(int count)
Emitted when the number of active background jobs changes.
QgsElevationProfileCanvas(QWidget *parent=nullptr)
Constructor for QgsElevationProfileCanvas, with the specified parent widget.
void paintEvent(QPaintEvent *event) override
QgsCoordinateReferenceSystem crs() const override
Returns the coordinate reference system (CRS) for map coordinates used by the canvas.
void clear()
Clears the current profile.
void canvasPointHovered(const QgsPointXY &point, const QgsProfilePoint &profilePoint)
Emitted when the mouse hovers over the specified point (in canvas coordinates).
void setProject(QgsProject *project)
Sets the project associated with the profile.
QList< QgsMapLayer * > layers() const
Returns the list of layers included in the profile.
double tolerance() const
Returns the tolerance of the profile (in crs() units).
void invalidateCurrentPlotExtent()
Invalidates the current plot extent, which means that the visible plot area will be recalculated and ...
void setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the crs associated with the canvas' map coordinates.
QList< QgsAbstractProfileSource * > sources() const
Returns the list of sources included in the profile.
void setLayers(const QList< QgsMapLayer * > &layers)
Sets the list of layers to include in the profile.
void zoomFull()
Zooms to the full extent of the profile.
void scaleChanged()
Emitted when the plot scale is changed.
QgsLineSymbol * subsectionsSymbol()
Returns the symbol used to draw the subsections.
void setSnappingEnabled(bool enabled)
Sets whether snapping of cursor points is enabled.
QRectF plotArea() const
Returns the interior rectangle representing the surface of the plot, in canvas coordinates.
A line symbol type, for rendering LineString and MultiLineString geometries.
Base class for all map layer types.
Definition qgsmaplayer.h:80
bool event(QEvent *e) override
virtual void cancelJobs()
Cancel any rendering job, in a blocking way.
QgsPlotCanvas(QWidget *parent=nullptr)
Constructor for QgsPlotCanvas, with the specified parent widget.
virtual void refresh()
Updates and redraws the plot.
virtual void zoomToRect(const QRectF &rect)
Zooms the plot to the specified rect in canvas units.
virtual void panContentsBy(double dx, double dy)
Pans the plot contents by dx, dy in canvas units.
virtual QgsPointXY toCanvasCoordinates(const QgsPoint &point) const
Converts a point in map coordinates to the associated canvas point.
void mouseMoveEvent(QMouseEvent *e) override
void resizeEvent(QResizeEvent *e) override
virtual void scalePlot(double factor)
Scales the plot by a specified scale factor.
virtual QgsCoordinateReferenceSystem crs() const
Returns the coordinate reference system (CRS) for map coordinates used by the canvas.
virtual void wheelZoom(QWheelEvent *event)
Zoom plot from a mouse wheel event.
virtual QgsPoint toMapCoordinates(const QgsPointXY &point) const
Converts a point on the canvas to the associated map coordinate.
virtual QgsPointXY snapToPlot(QPoint point)
Snap a canvas point to the plot.
virtual void centerPlotOn(double x, double y)
Centers the plot on the plot point corresponding to x, y in canvas units.
Represents a 2D point.
Definition qgspointxy.h:60
Point geometry type, with support for z-dimension and m-values.
Definition qgspoint.h:49
Encapsulates the context of identifying profile results.
Stores identify results generated by a QgsAbstractProfileResults object.
Generates and renders elevation profile plots.
Encapsulates a point on a distance-elevation profile.
Encapsulates the context of snapping a profile point.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
Definition qgsproject.h:109
Contains information about the context of a rendering operation.
A utility class for dynamic handling of changes to screen properties.
#define SIP_TRANSFERTHIS
Definition qgis_sip.h:53
#define SIP_SKIP
Definition qgis_sip.h:134
#define SIP_TRANSFER
Definition qgis_sip.h:36
QList< QgsWeakMapLayerPointer > QgsWeakMapLayerPointerList
A list of weak pointers to QgsMapLayers.