QGIS API Documentation 3.99.0-Master (26c88405ac0)
Loading...
Searching...
No Matches
qgsabstractprofilegenerator.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsabstractprofilegenerator.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#ifndef QGSABSTRACTPROFILEGENERATOR_H
18#define QGSABSTRACTPROFILEGENERATOR_H
19
20#include "qgis_core.h"
21#include "qgis_sip.h"
22#include "qgsrendercontext.h"
23
24#include <QList>
25#include <QTransform>
26
29class QgsProfilePoint;
30class QgsGeometry;
31
38class CORE_EXPORT QgsProfileRenderContext
39{
40 public:
41
46
50 QgsRenderContext &renderContext() { return mRenderContext; }
51
59 const QTransform &worldTransform() const;
60
68 void setWorldTransform( const QTransform &transform );
69
77 QgsDoubleRange distanceRange() const;
78
86 void setDistanceRange( const QgsDoubleRange &range );
87
95 QgsDoubleRange elevationRange() const;
96
104 void setElevationRange( const QgsDoubleRange &range );
105
106 private:
107
108 QgsRenderContext mRenderContext;
109
110 QTransform mWorldTransform;
111
112 QgsDoubleRange mDistanceRange;
113 QgsDoubleRange mElevationRange;
114
115};
116
117
124{
125 public:
126
129
132
135
138
141
143 QgsProject *project = nullptr;
144
145};
146
147
149
157{
158 public:
159
163 QgsProfileIdentifyResults( QgsMapLayer *layer = nullptr, const QVector< QVariantMap> &results = QVector< QVariantMap>() );
164
168 QgsMapLayer *layer() const { return mLayer; }
169
175 QVector<QVariantMap> results() const { return mResults; }
176
177 private:
178
179 QPointer< QgsMapLayer > mLayer = nullptr;
180
181 QVector<QVariantMap> mResults;
182
183};
184
192{
193 public:
194
200 struct Feature
201 {
207 QVariantMap attributes;
208 };
209
211
215 virtual QString type() const = 0;
216
220 virtual QMap< double, double > distanceToHeightMap() const = 0;
221
226 virtual QgsPointSequence sampledPoints() const = 0;
227
231 virtual QVector< QgsGeometry > asGeometries() const = 0;
232
240 virtual QVector< QgsAbstractProfileResults::Feature > asFeatures( Qgis::ProfileExportType type, QgsFeedback *feedback = nullptr ) const;
241
245 virtual void renderResults( QgsProfileRenderContext &context ) = 0;
246
250 virtual QgsDoubleRange zRange() const = 0;
251
255 virtual QgsProfileSnapResult snapPoint( const QgsProfilePoint &point, const QgsProfileSnapContext &context );
256
260 virtual QVector<QgsProfileIdentifyResults> identify( const QgsProfilePoint &point, const QgsProfileIdentifyContext &context );
261
265 virtual QVector<QgsProfileIdentifyResults> identify( const QgsDoubleRange &distanceRange, const QgsDoubleRange &elevationRange, const QgsProfileIdentifyContext &context );
266
275 virtual void copyPropertiesFromGenerator( const QgsAbstractProfileGenerator *generator );
276};
277
285{
286 public:
287
296 double maximumErrorMapUnits() const { return mMaxErrorMapUnits; }
297
306 void setMaximumErrorMapUnits( double error ) { mMaxErrorMapUnits = error; }
307
313 double mapUnitsPerDistancePixel() const { return mMapUnitsPerDistancePixel; }
314
320 void setMapUnitsPerDistancePixel( double units ) { mMapUnitsPerDistancePixel = units; }
321
329 QgsDoubleRange distanceRange() const { return mDistanceRange; }
330
338 void setDistanceRange( const QgsDoubleRange &range ) { mDistanceRange = range; }
339
347 QgsDoubleRange elevationRange() const { return mElevationRange; }
348
356 void setElevationRange( const QgsDoubleRange &range ) { mElevationRange = range; }
357
363 void setDpi( double dpi ) { mDpi = dpi; }
364
370 double dpi() const { return mDpi; }
371
375 double convertDistanceToPixels( double size, Qgis::RenderUnit unit ) const;
376
377 bool operator==( const QgsProfileGenerationContext &other ) const;
378 bool operator!=( const QgsProfileGenerationContext &other ) const;
379
380 private:
381
382 double mMaxErrorMapUnits = std::numeric_limits< double >::quiet_NaN();
383 double mMapUnitsPerDistancePixel = 1;
384 QgsDoubleRange mDistanceRange;
385 QgsDoubleRange mElevationRange;
386 double mDpi = 96;
387};
388
415{
416
417 public:
418
420
427 virtual QString sourceId() const = 0;
428
432 virtual Qgis::ProfileGeneratorFlags flags() const;
433
441
445 virtual QgsFeedback *feedback() const = 0;
446
453
454};
455
456#endif // QGSABSTRACTPROFILEGENERATOR_H
QFlags< ProfileGeneratorFlag > ProfileGeneratorFlags
Definition qgis.h:4224
RenderUnit
Rendering size units.
Definition qgis.h:5183
ProfileExportType
Types of export for elevation profiles.
Definition qgis.h:4233
Abstract base class for objects which generate elevation profiles.
virtual QgsAbstractProfileResults * takeResults()=0
Takes results from the generator.
virtual QgsFeedback * feedback() const =0
Access to feedback object of the generator (may be nullptr).
virtual QString sourceId() const =0
Returns a unique identifier representing the source of the profile.
virtual Qgis::ProfileGeneratorFlags flags() const
Returns flags which reflect how the profile generator operates.
virtual ~QgsAbstractProfileGenerator()
virtual bool generateProfile(const QgsProfileGenerationContext &context=QgsProfileGenerationContext())=0
Generate the profile (based on data stored in the class).
Abstract base class for storage of elevation profiles.
virtual QgsDoubleRange zRange() const =0
Returns the range of the retrieved elevation values.
virtual void renderResults(QgsProfileRenderContext &context)=0
Renders the results to the specified context.
virtual QMap< double, double > distanceToHeightMap() const =0
Returns the map of distance (chainage) to height.
virtual QString type() const =0
Returns the unique string identifier for the results type.
virtual ~QgsAbstractProfileResults()
virtual QVector< QgsAbstractProfileResults::Feature > asFeatures(Qgis::ProfileExportType type, QgsFeedback *feedback=nullptr) const
Returns a list of features representing the calculated elevation results.
virtual QgsPointSequence sampledPoints() const =0
Returns a list of sampled points, with their calculated elevation as the point z value.
virtual QgsProfileSnapResult snapPoint(const QgsProfilePoint &point, const QgsProfileSnapContext &context)
Snaps a point to the generated elevation profile.
virtual QVector< QgsProfileIdentifyResults > identify(const QgsProfilePoint &point, const QgsProfileIdentifyContext &context)
Identify results visible at the specified profile point.
virtual QVector< QgsGeometry > asGeometries() const =0
Returns a list of geometries representing the calculated elevation results.
virtual void copyPropertiesFromGenerator(const QgsAbstractProfileGenerator *generator)
Copies properties from specified generator to the results object.
QgsRange which stores a range of double values.
Definition qgsrange.h:233
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
A geometry is the spatial representation of a feature.
Base class for all map layer types.
Definition qgsmaplayer.h:80
Encapsulates the context in which an elevation profile is to be generated.
double maximumErrorMapUnits() const
Returns the maximum allowed error in the generated result, in profile curve map units.
double dpi() const
Returns the DPI (dots per inch) for the profie, to be used in size conversions.
double mapUnitsPerDistancePixel() const
Returns the number of map units per pixel in the distance dimension.
void setDpi(double dpi)
Sets the dpi (dots per inch) for the profie, to be used in size conversions.
void setMaximumErrorMapUnits(double error)
Sets the maximum allowed error in the generated result, in profile curve map units.
QgsDoubleRange elevationRange() const
Returns the range of elevations to include in the generation.
void setDistanceRange(const QgsDoubleRange &range)
Sets the range of distances to include in the generation.
QgsDoubleRange distanceRange() const
Returns the range of distances to include in the generation.
void setElevationRange(const QgsDoubleRange &range)
Sets the range of elevations to include in the generation.
void setMapUnitsPerDistancePixel(double units)
Sets the number of map units per pixel in the distance dimension.
Encapsulates the context of identifying profile results.
double maximumPointElevationDelta
Maximum allowed snapping delta for the elevation values when identifying a point.
double maximumPointDistanceDelta
Maximum allowed snapping delta for the distance values when identifying a point.
QgsProject * project
Associated project.
double displayRatioElevationVsDistance
Display ratio of elevation vs distance units.
double maximumSurfaceDistanceDelta
Maximum allowed snapping delta for the distance values when identifying a continuous elevation surfac...
double maximumSurfaceElevationDelta
Maximum allowed snapping delta for the elevation values when identifying a continuous elevation surfa...
QgsProfileIdentifyResults(QgsMapLayer *layer=nullptr, const QVector< QVariantMap > &results=QVector< QVariantMap >())
Constructor for QgsProfileIdentifyResult, with the associated map layer.
QVector< QVariantMap > results() const
Returns a list of custom attributes representing the identify results.
QgsMapLayer * layer() const
Returns the associated map layer.
Encapsulates a point on a distance-elevation profile.
Abstract base class for storage of elevation profiles.
QgsRenderContext & renderContext()
Returns a reference to the component QgsRenderContext.
QgsProfileRenderContext(QgsRenderContext &context)
Constructor for QgsProfileRenderContext, with the specified embedded render context.
Encapsulates the context of snapping a profile point.
Encapsulates results 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.
#define SIP_TRANSFERBACK
Definition qgis_sip.h:48
QVector< QgsPoint > QgsPointSequence
bool operator==(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
bool operator!=(const QgsFeatureIterator &fi1, const QgsFeatureIterator &fi2)
Encapsulates information about a feature exported from the profile results.
QString layerIdentifier
Identifier for grouping output features.
QVariantMap attributes
Exported attributes.