42#include "moc_qgslayoutitemelevationprofile.cpp"
44#define CACHE_SIZE_LIMIT 5000
47class QgsLayoutItemElevationProfilePlot :
public Qgs2DXyPlot
51 QgsLayoutItemElevationProfilePlot()
65 const double distanceMin =
xMinimum() * xScale;
66 const double distanceMax =
xMaximum() * xScale;
67 rc.
painter()->translate( plotArea.left(), plotArea.top() );
68 mRenderer->render( rc, plotArea.width(), plotArea.height(), distanceMin, distanceMax, yMinimum(),
yMaximum() );
69 rc.
painter()->translate( -plotArea.left(), -plotArea.top() );
70 mRenderer->renderSubsectionsIndicator( rc, plotArea, distanceMin, distanceMax,
yMinimum(),
yMaximum() );
85 , mPlot( std::make_unique< QgsLayoutItemElevationProfilePlot >() )
87 mBackgroundUpdateTimer =
new QTimer(
this );
88 mBackgroundUpdateTimer->setSingleShot(
true );
89 connect( mBackgroundUpdateTimer, &QTimer::timeout,
this, &QgsLayoutItemElevationProfile::recreateCachedImageInBackground );
91 setCacheMode( QGraphicsItem::NoCache );
118 mRenderJob->cancelGeneration();
142 bool forceUpdate =
false;
147 double value = mTolerance;
167 double value = mPlot->xMinimum();
178 mPlot->setXMinimum( value );
187 double value = mPlot->xMaximum();
198 mPlot->setXMaximum( value );
207 double value = mPlot->yMinimum();
218 mPlot->setYMinimum( value );
227 double value = mPlot->yMaximum();
238 mPlot->setYMaximum( value );
247 double value = mPlot->xAxis().gridIntervalMajor();
258 mPlot->xAxis().setGridIntervalMajor( value );
267 double value = mPlot->xAxis().gridIntervalMinor();
278 mPlot->xAxis().setGridIntervalMinor( value );
287 double value = mPlot->xAxis().labelInterval();
298 mPlot->xAxis().setLabelInterval( value );
307 double value = mPlot->yAxis().gridIntervalMajor();
318 mPlot->yAxis().setGridIntervalMajor( value );
327 double value = mPlot->yAxis().gridIntervalMinor();
338 mPlot->yAxis().setGridIntervalMinor( value );
347 double value = mPlot->yAxis().labelInterval();
358 mPlot->yAxis().setLabelInterval( value );
367 double value = mPlot->margins().left();
380 mPlot->setMargins( margins );
389 double value = mPlot->margins().right();
402 mPlot->setMargins( margins );
411 double value = mPlot->margins().top();
424 mPlot->setMargins( margins );
433 double value = mPlot->margins().bottom();
446 mPlot->setMargins( margins );
454 mCacheInvalidated =
true;
470 return blendMode() != QPainter::CompositionMode_SourceOver;
475 return mEvaluatedOpacity < 1.0;
490 return _qgis_listRefToRaw( mLayers );
495 if (
layers == _qgis_listRefToRaw( mLayers ) )
498 mLayers = _qgis_listRawToRef(
layers );
504 if ( mSources.isEmpty() && !mLayers.isEmpty() )
510 QList< QgsAbstractProfileSource * >
sources;
511 const QList<QgsMapLayer *> layersToGenerate =
layers();
512 sources.reserve( layersToGenerate.size() );
540 mCurve.reset( curve );
579 mAtlasDriven = enabled;
605 if ( !
mLayout || !painter || !painter->device() || !mUpdatesEnabled )
614 QRectF thisPaintRect = rect();
618 if (
mLayout->renderContext().isPreviewRender() )
624 painter->setClipRect( thisPaintRect );
625 if ( !mCacheFinalImage || mCacheFinalImage->isNull() )
628 painter->setBrush( QBrush( QColor( 125, 125, 125, 125 ) ) );
629 painter->drawRect( thisPaintRect );
630 painter->setBrush( Qt::NoBrush );
632 messageFont.setPointSize( 12 );
633 painter->setFont( messageFont );
634 painter->setPen( QColor( 255, 255, 255, 255 ) );
635 painter->drawText( thisPaintRect, Qt::AlignCenter | Qt::AlignHCenter, tr(
"Rendering profile" ) );
638 ( mRenderJob && mCacheInvalidated && !mDrawingPreview )
640 ( !mRenderJob && !mDrawingPreview )
645 mBackgroundUpdateTimer->start( 1 );
650 if ( mCacheInvalidated && !mDrawingPreview )
654 mBackgroundUpdateTimer->start( 1 );
659 double imagePixelWidth = mCacheFinalImage->width();
660 double scale = rect().width() / imagePixelWidth;
664 painter->scale( scale, scale );
665 painter->setCompositionMode( blendModeForRender() );
666 painter->drawImage( 0, 0, *mCacheFinalImage );
669 painter->setClipRect( thisPaintRect, Qt::NoClip );
682 QPaintDevice *paintDevice = painter->device();
689 painter->setRenderHint( QPainter::LosslessImageRendering,
true );
702 int widthInPixels =
static_cast< int >( std::round( boundingRect().width() * layoutUnitsInInches * destinationDpi ) );
703 int heightInPixels =
static_cast< int >( std::round( boundingRect().height() * layoutUnitsInInches * destinationDpi ) );
704 QImage image = QImage( widthInPixels, heightInPixels, QImage::Format_ARGB32 );
706 image.fill( Qt::transparent );
707 image.setDotsPerMeterX(
static_cast< int >( std::round( 1000 * destinationDpi / 25.4 ) ) );
708 image.setDotsPerMeterY(
static_cast< int >( std::round( 1000 * destinationDpi / 25.4 ) ) );
709 double dotsPerMM = destinationDpi / 25.4;
710 layoutSize *= dotsPerMM;
711 QPainter p( &image );
712 preparePainter( &p );
717 p.scale( dotsPerMM, dotsPerMM );
723 p.scale( 1.0 / dotsPerMM, 1.0 / dotsPerMM );
725 const double mapUnitsPerPixel =
static_cast<double>( mPlot->xMaximum() - mPlot->xMinimum() ) * mPlot->xScale / layoutSize.width();
728 QList< QgsAbstractProfileSource *> sourcesToRender =
sources();
729 std::reverse( sourcesToRender.begin(), sourcesToRender.end() );
736 mPlot->setRenderer( &renderer );
739 mPlot->setSize( layoutSize );
742 mPlot->render( rc, plotContext );
744 mPlot->setRenderer(
nullptr );
746 p.scale( dotsPerMM, dotsPerMM );
754 painter->setCompositionMode( blendModeForRender() );
755 painter->scale( 1 / dotsPerMM, 1 / dotsPerMM );
756 painter->drawImage( 0, 0, image );
757 painter->scale( dotsPerMM, dotsPerMM );
772 double dotsPerMM = paintDevice->logicalDpiX() / 25.4;
773 layoutSize *= dotsPerMM;
774 painter->scale( 1 / dotsPerMM, 1 / dotsPerMM );
776 const double mapUnitsPerPixel =
static_cast<double>( mPlot->xMaximum() - mPlot->xMinimum() ) * mPlot->xScale / layoutSize.width();
779 QList< QgsAbstractProfileSource *> sourcesToRender =
sources();
780 std::reverse( sourcesToRender.begin(), sourcesToRender.end() );
793 mPlot->setRenderer( &renderer );
796 mPlot->setSize( layoutSize );
799 mPlot->render( rc, plotContext );
801 mPlot->setRenderer(
nullptr );
803 painter->setClipRect( thisPaintRect, Qt::NoClip );
818 if ( mAtlasDriven &&
mLayout &&
mLayout->reportContext().layer() )
829 mCurve.reset( curve->clone() );
842 mCacheInvalidated =
true;
853 QDomElement plotElement = doc.createElement( QStringLiteral(
"plot" ) );
854 mPlot->writeXml( plotElement, doc, rwContext );
855 layoutProfileElem.appendChild( plotElement );
858 layoutProfileElem.setAttribute( QStringLiteral(
"distanceUnit" ),
qgsEnumValueToKey( mDistanceUnit ) );
860 layoutProfileElem.setAttribute( QStringLiteral(
"tolerance" ), mTolerance );
861 layoutProfileElem.setAttribute( QStringLiteral(
"atlasDriven" ), mAtlasDriven ? QStringLiteral(
"1" ) : QStringLiteral(
"0" ) );
862 if ( mCrs.isValid() )
864 QDomElement crsElem = doc.createElement( QStringLiteral(
"crs" ) );
865 mCrs.writeXml( crsElem, doc );
866 layoutProfileElem.appendChild( crsElem );
870 QDomElement curveElem = doc.createElement( QStringLiteral(
"curve" ) );
871 curveElem.appendChild( doc.createTextNode( mCurve->asWkt( ) ) );
872 layoutProfileElem.appendChild( curveElem );
876 QDomElement layersElement = doc.createElement( QStringLiteral(
"layers" ) );
879 QDomElement layerElement = doc.createElement( QStringLiteral(
"layer" ) );
880 layer.writeXml( layerElement, rwContext );
881 layersElement.appendChild( layerElement );
883 layoutProfileElem.appendChild( layersElement );
887 QDomElement sourcesElement = doc.createElement( QStringLiteral(
"profileSources" ) );
894 QDomElement sourceElement = doc.createElement( QStringLiteral(
"profileCustomSource" ) );
895 sourceElement.setAttribute( QStringLiteral(
"id" ), source->profileSourceId() );
896 sourcesElement.appendChild( sourceElement );
900 QDomElement sourceElement = doc.createElement( QStringLiteral(
"profileLayerSource" ) );
901 layer.writeXml( sourceElement, rwContext );
902 sourcesElement.appendChild( sourceElement );
906 layoutProfileElem.appendChild( sourcesElement );
909 if ( mSubsectionsSymbol )
911 QDomElement subsectionsElement = doc.createElement( QStringLiteral(
"subsections" ) );
913 subsectionsElement.appendChild( symbolElement );
914 layoutProfileElem.appendChild( subsectionsElement );
922 const QDomElement plotElement = itemElem.firstChildElement( QStringLiteral(
"plot" ) );
923 if ( !plotElement.isNull() )
925 mPlot->readXml( plotElement, context );
928 const QDomNodeList crsNodeList = itemElem.elementsByTagName( QStringLiteral(
"crs" ) );
930 if ( !crsNodeList.isEmpty() )
932 const QDomElement crsElem = crsNodeList.at( 0 ).toElement();
933 crs.readXml( crsElem );
939 const QDomNodeList curveNodeList = itemElem.elementsByTagName( QStringLiteral(
"curve" ) );
940 if ( !curveNodeList.isEmpty() )
942 const QDomElement curveElem = curveNodeList.at( 0 ).toElement();
946 mCurve.reset( curveGeom->clone() );
954 mTolerance = itemElem.attribute( QStringLiteral(
"tolerance" ) ).toDouble();
955 mAtlasDriven =
static_cast< bool >( itemElem.attribute( QStringLiteral(
"atlasDriven" ), QStringLiteral(
"0" ) ).toInt() );
959 const QDomElement layersElement = itemElem.firstChildElement( QStringLiteral(
"layers" ) );
960 QDomElement layerElement = layersElement.firstChildElement( QStringLiteral(
"layer" ) );
961 while ( !layerElement.isNull() )
964 ref.
readXml( layerElement, context );
966 mLayers.append( ref );
968 layerElement = layerElement.nextSiblingElement( QStringLiteral(
"layer" ) );
974 const QDomElement sourcesElement = itemElem.firstChildElement( QStringLiteral(
"profileSources" ) );
975 QDomElement sourceElement = sourcesElement.firstChildElement();
976 while ( !sourceElement.isNull() )
978 if ( sourceElement.tagName() == QLatin1String(
"profileCustomSource" ) )
980 const QString sourceId = sourceElement.attribute( QStringLiteral(
"id" ) );
983 mSources.append( profileSource );
986 else if ( sourceElement.tagName() == QLatin1String(
"profileLayerSource" ) )
989 ref.
readXml( sourceElement, context );
997 sourceElement = sourceElement.nextSiblingElement();
1001 const QDomElement subsectionsElement = itemElem.firstChildElement( QStringLiteral(
"subsections" ) );
1002 const QDomElement symbolsElement = subsectionsElement.firstChildElement( QStringLiteral(
"symbol" ) );
1003 if ( !symbolsElement.isNull() )
1006 if ( subSectionsSymbol )
1016void QgsLayoutItemElevationProfile::recreateCachedImageInBackground()
1022 QPainter *oldPainter = mPainter.release();
1023 QImage *oldImage = mCacheRenderingImage.release();
1026 oldJob->deleteLater();
1034 mCacheRenderingImage.reset(
nullptr );
1038 Q_ASSERT( !mRenderJob );
1039 Q_ASSERT( !mPainter );
1040 Q_ASSERT( !mCacheRenderingImage );
1043 double widthLayoutUnits = layoutSize.width();
1044 double heightLayoutUnits = layoutSize.height();
1046 int w =
static_cast< int >( std::round( widthLayoutUnits * mPreviewScaleFactor ) );
1047 int h =
static_cast< int >( std::round( heightLayoutUnits * mPreviewScaleFactor ) );
1050 if ( w > 5000 || h > 5000 )
1055 h =
static_cast< int>( std::round( w * heightLayoutUnits / widthLayoutUnits ) );
1060 w =
static_cast< int >( std::round( h * widthLayoutUnits / heightLayoutUnits ) );
1064 if ( w <= 0 || h <= 0 )
1067 mCacheRenderingImage = std::make_unique<QImage>( w, h, QImage::Format_ARGB32 );
1070 mCacheRenderingImage->setDotsPerMeterX(
static_cast< int >( std::round( 1000 * w / widthLayoutUnits ) ) );
1071 mCacheRenderingImage->setDotsPerMeterY(
static_cast< int >( std::round( 1000 * h / heightLayoutUnits ) ) );
1074 mCacheRenderingImage->fill( Qt::transparent );
1081 mCacheInvalidated =
false;
1082 mPainter = std::make_unique<QPainter>( mCacheRenderingImage.get() );
1084 QList< QgsAbstractProfileSource *> sourcesToRender =
sources();
1085 std::reverse( sourcesToRender.begin(), sourcesToRender.end() );
1087 mRenderJob = std::make_unique< QgsProfilePlotRenderer >( sourcesToRender,
profileRequest() );
1089 mRenderJob->setSubsectionsSymbol( rendererSubSectionsSymbol.release() );
1091 mRenderJob->startGeneration();
1093 mDrawingPreview =
false;
1096void QgsLayoutItemElevationProfile::profileGenerationFinished()
1098 mPlot->setRenderer( mRenderJob.get() );
1104 const double mapUnitsPerPixel =
static_cast< double >( mPlot->xMaximum() - mPlot->xMinimum() ) * mPlot->xScale /
1105 mCacheRenderingImage->size().width();
1109 mPlot->setSize( mCacheRenderingImage->size() );
1111 QgsPlotRenderContext plotContext;
1112 mPlot->render( rc, plotContext );
1114 mPlot->setRenderer(
nullptr );
1117 mRenderJob.reset(
nullptr );
1118 mPainter.reset(
nullptr );
1119 mCacheFinalImage = std::move( mCacheRenderingImage );
1127 return mDistanceUnit;
1132 mDistanceUnit = unit;
1134 switch ( mDistanceUnit )
1188 mPlot->xAxis().setLabelSuffix( QObject::tr(
"°" ) );
1192 mPlot->xAxis().setLabelSuffix( QString() );
1199 mSubsectionsSymbol.reset( symbol );
1202void QgsLayoutItemElevationProfile::setSourcesPrivate()
@ ForceVector
Always force vector-based rendering, even when the result will be visually different to a raster-base...
DistanceUnit
Units of distance.
@ YardsBritishSears1922Truncated
British yards (Sears 1922 truncated).
@ MilesUSSurvey
US Survey miles.
@ LinksBritishSears1922
British links (Sears 1922).
@ YardsBritishBenoit1895A
British yards (Benoit 1895 A).
@ LinksBritishBenoit1895A
British links (Benoit 1895 A).
@ Centimeters
Centimeters.
@ YardsIndian1975
Indian yards (1975).
@ FeetUSSurvey
US Survey feet.
@ Millimeters
Millimeters.
@ FeetBritishSears1922
British feet (Sears 1922).
@ YardsClarkes
Clarke's yards.
@ YardsIndian
Indian yards.
@ FeetBritishBenoit1895B
British feet (Benoit 1895 B).
@ Miles
Terrestrial miles.
@ LinksUSSurvey
US Survey links.
@ ChainsUSSurvey
US Survey chains.
@ FeetClarkes
Clarke's feet.
@ Unknown
Unknown distance unit.
@ FeetBritish1936
British feet (1936).
@ FeetIndian1962
Indian feet (1962).
@ YardsBritishSears1922
British yards (Sears 1922).
@ FeetIndian1937
Indian feet (1937).
@ YardsIndian1937
Indian yards (1937).
@ Degrees
Degrees, for planar geographic CRS distance measurements.
@ ChainsBritishBenoit1895B
British chains (Benoit 1895 B).
@ LinksBritishSears1922Truncated
British links (Sears 1922 truncated).
@ ChainsBritishBenoit1895A
British chains (Benoit 1895 A).
@ YardsBritishBenoit1895B
British yards (Benoit 1895 B).
@ FeetBritish1865
British feet (1865).
@ YardsIndian1962
Indian yards (1962).
@ FeetBritishSears1922Truncated
British feet (Sears 1922 truncated).
@ MetersGermanLegal
German legal meter.
@ LinksBritishBenoit1895B
British links (Benoit 1895 B).
@ ChainsInternational
International chains.
@ LinksInternational
International links.
@ ChainsBritishSears1922Truncated
British chains (Sears 1922 truncated).
@ FeetIndian
Indian (geodetic) feet.
@ NauticalMiles
Nautical miles.
@ ChainsClarkes
Clarke's chains.
@ LinksClarkes
Clarke's links.
@ ChainsBritishSears1922
British chains (Sears 1922).
@ FeetIndian1975
Indian feet (1975).
@ FeetGoldCoast
Gold Coast feet.
@ FeetBritishBenoit1895A
British feet (Benoit 1895 A).
@ LosslessImageRendering
Render images losslessly whenever possible, instead of the default lossy jpeg rendering used for some...
virtual void renderContent(QgsRenderContext &context, QgsPlotRenderContext &plotContext, const QRectF &plotArea, const QgsPlotData &plotData=QgsPlotData())
Renders the plot content.
Base class for 2-dimensional plot/chart/graphs with an X and Y axes.
double yMaximum() const
Returns the maximum value of the y axis.
double xMinimum() const
Returns the minimum value of the x axis.
double yMinimum() const
Returns the minimum value of the y axis.
double xMaximum() const
Returns the maximum value of the x axis.
Abstract base class for all geometries.
Interface for classes which can generate elevation profiles.
Abstract base class for terrain providers.
static QIcon getThemeIcon(const QString &name, const QColor &fillColor=QColor(), const QColor &strokeColor=QColor())
Helper to get a theme icon.
static QgsProfileSourceRegistry * profileSourceRegistry()
Returns registry of available profile source implementations.
Represents a coordinate reference system (CRS).
Abstract base class for curved geometry type.
Expression contexts are used to encapsulate the parameters around which a QgsExpression should be eva...
A geometry is the spatial representation of a feature.
const QgsAbstractGeometry * constGet() const
Returns a non-modifiable (const) reference to the underlying abstract geometry primitive.
static Q_INVOKABLE QgsGeometry fromWkt(const QString &wkt)
Creates a new geometry from a WKT string.
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.
~QgsLayoutItemElevationProfile() override
QgsCurve * profileCurve() const
Returns the cross section profile curve, which represents the line along which the profile should be ...
void refreshDataDefinedProperty(QgsLayoutObject::DataDefinedProperty property=QgsLayoutObject::DataDefinedProperty::AllProperties) override
Refreshes a data defined property for the item by reevaluating the property's value and redrawing the...
void setLayers(const QList< QgsMapLayer * > &layers)
Sets the list of map layers participating in the elevation profile.
void setSubsectionsSymbol(QgsLineSymbol *symbol)
Sets the symbol used to draw the subsections.
QList< QgsMapLayer * > layers() const
Returns the list of map layers participating in the elevation profile.
void invalidateCache() override
void setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the desired Coordinate Reference System (crs) for the profile.
bool writePropertiesToElement(QDomElement &element, QDomDocument &document, const QgsReadWriteContext &context) const override
Stores item state within an XML DOM element.
void draw(QgsLayoutItemRenderContext &context) override
Draws the item's contents using the specified item render context.
QgsLayoutItem::Flags itemFlags() const override
Returns the item's flags, which indicate how the item behaves.
QList< QgsAbstractProfileSource * > sources() const
Returns the list of sources participating in the elevation profile.
void setDistanceUnit(Qgis::DistanceUnit unit)
Sets the unit for the distance axis.
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.
void setAtlasDriven(bool enabled)
Sets whether the profile curve will follow the current atlas feature.
double tolerance() const
Returns the tolerance of the request (in crs() units).
QgsLineSymbol * subsectionsSymbol()
Returns the symbol used to draw the subsections.
Qgis::DistanceUnit distanceUnit() const
Returns the units for the distance axis.
bool requiresRasterization() const override
Returns true if the item is drawn in such a way that forces the whole layout to be rasterized when ex...
void setSources(const QList< QgsAbstractProfileSource * > &sources)
Sets the list of sources participating in the elevation profile.
bool containsAdvancedEffects() const override
Returns true if the item contains contents with blend modes or transparency effects which can only be...
void paint(QPainter *painter, const QStyleOptionGraphicsItem *itemStyle, QWidget *pWidget) override
QIcon icon() const override
Returns the item's icon.
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...
bool readPropertiesFromElement(const QDomElement &element, const QDomDocument &document, const QgsReadWriteContext &context) override
Sets item state from a DOM element.
QgsProfileRequest profileRequest() const
Returns the profile request used to generate the elevation profile.
int type() const override
@ LayoutElevationProfile
Elevation profile item.
Contains settings and helpers relating to a render of a QgsLayoutItem.
virtual void drawFrame(QgsRenderContext &context)
Draws the frame around the item.
QColor backgroundColor(bool useDataDefined=true) const
Returns the background color for this item.
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...
QgsLayoutSize sizeWithUnits() const
Returns the item's current size, including units.
QgsLayoutItem(QgsLayout *layout, bool manageZValue=true)
Constructor for QgsLayoutItem, with the specified parent layout.
void refreshItemSize()
Refreshes an item's size by rechecking it against any possible item fixed or minimum sizes.
QgsExpressionContext createExpressionContext() const override
This method needs to be reimplemented in all classes which implement this interface and return an exp...
virtual void drawBackground(QgsRenderContext &context)
Draws the background for the item.
bool shouldDrawItem() const
Returns whether the item should be drawn in the current context.
@ FlagOverridesPaint
Item overrides the default layout item painting method.
@ FlagDisableSceneCaching
Item should not have QGraphicsItem caching enabled.
void sizePositionChanged()
Emitted when the item's size or position changes.
bool frameEnabled() const
Returns true if the item includes a frame.
bool hasBackground() const
Returns true if the item has a background.
void refresh() override
Refreshes the item, causing a recalculation of any property overrides and recalculation of its positi...
friend class QgsLayoutItemElevationProfile
void setBackgroundEnabled(bool drawBackground)
Sets whether this item has a background drawn under it or not.
QPainter::CompositionMode blendMode() const
Returns the item's composition blending mode.
void backgroundTaskCountChanged(int count)
Emitted whenever the number of background tasks an item is executing changes.
QgsPropertyCollection mDataDefinedProperties
const QgsLayout * layout() const
Returns the layout the object is attached to.
QPointer< QgsLayout > mLayout
DataDefinedProperty
Data defined properties for different item types.
@ ElevationProfileMaximumDistance
Maximum distance value for elevation profile.
@ MarginBottom
Bottom margin.
@ ElevationProfileElevationMinorInterval
Minor grid line interval for elevation profile elevation axis.
@ ElevationProfileDistanceMinorInterval
Minor grid line interval for elevation profile distance axis.
@ ElevationProfileMinimumDistance
Minimum distance value for elevation profile.
@ ElevationProfileMaximumElevation
Maximum elevation value for elevation profile.
@ ElevationProfileDistanceLabelInterval
Label interval for elevation profile distance axis.
@ ElevationProfileTolerance
Tolerance distance for elevation profiles.
@ ElevationProfileMinimumElevation
Minimum elevation value for elevation profile.
@ MarginRight
Right margin.
@ ElevationProfileElevationLabelInterval
Label interval for elevation profile elevation axis.
@ ElevationProfileDistanceMajorInterval
Major grid line interval for elevation profile distance axis.
@ ElevationProfileElevationMajorInterval
Major grid line interval for elevation profile elevation axis.
@ AllProperties
All properties for item.
static QgsRenderContext createRenderContextForLayout(QgsLayout *layout, QPainter *painter, double dpi=-1)
Creates a render context suitable for the specified layout and painter destination.
static Q_DECL_DEPRECATED double scaleFactorFromItemStyle(const QStyleOptionGraphicsItem *style)
Extracts the scale factor from an item style.
void refreshed()
Emitted when the layout has been refreshed and items should also be refreshed and updated.
A line symbol type, for rendering LineString and MultiLineString geometries.
Base class for all map layer types.
virtual QgsAbstractProfileSource * profileSource()
Returns the layer's profile source if it has profile capabilities.
Perform transforms between map coordinates and device coordinates.
Defines the four margins of a rectangle.
void setBottom(double bottom)
Sets the bottom margin to bottom.
void setLeft(double left)
Sets the left margin to left.
void setRight(double right)
Sets the right margin to right.
void setTop(double top)
Sets the top margin to top.
static void logMessage(const QString &message, const QString &tag=QString(), Qgis::MessageLevel level=Qgis::MessageLevel::Warning, bool notifyUser=true, const char *file=__builtin_FILE(), const char *function=__builtin_FUNCTION(), int line=__builtin_LINE())
Adds a message to the log instance (and creates it if necessary).
Encapsulates one or more plot series.
Contains information about the context of a plot rendering operation.
Generates and renders elevation profile plots.
void setSubsectionsSymbol(QgsLineSymbol *symbol)
Sets the symbol used to draw the subsections.
void cancelGenerationWithoutBlocking()
Triggers cancellation of the generation job without blocking.
void generateSynchronously()
Generate the profile results synchronously in this thread.
void generationFinished()
Emitted when the profile generation is finished (or canceled).
Encapsulates properties and constraints relating to fetching elevation profiles from different source...
QgsProfileRequest & setExpressionContext(const QgsExpressionContext &context)
Sets the expression context used to evaluate expressions.
QgsProfileRequest & setTransformContext(const QgsCoordinateTransformContext &context)
Sets the transform context, for use when transforming coordinates from a source to the request's crs(...
QgsProfileRequest & setTerrainProvider(QgsAbstractTerrainProvider *provider)
Sets the terrain provider.
QgsProfileRequest & setTolerance(double tolerance)
Sets the tolerance of the request (in crs() units).
QgsProfileRequest & setCrs(const QgsCoordinateReferenceSystem &crs)
Sets the desired Coordinate Reference System (crs) for the profile.
void profileSourceUnregistered(const QString &sourceId)
Signal emitted once a profile source is unregistered.
QList< QgsAbstractProfileSource * > profileSources() const
Returns a list of registered profile sources.
void profileSourceRegistered(const QString &sourceId, const QString &sourceName)
Signal emitted once a profile source is registered.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
A container for the context for various read/write operations on objects.
Contains information about the context of a rendering operation.
QPainter * painter()
Returns the destination QPainter for the render operation.
void setMapToPixel(const QgsMapToPixel &mtp)
Sets the context's map to pixel transform, which transforms between map coordinates and device coordi...
void setExpressionContext(const QgsExpressionContext &context)
Sets the expression context.
Scoped object for saving and restoring a QPainter object's state.
static std::unique_ptr< QgsSymbol > loadSymbol(const QDomElement &element, const QgsReadWriteContext &context)
Attempts to load a symbol from a DOM element.
static QDomElement saveSymbol(const QString &symbolName, const QgsSymbol *symbol, QDomDocument &doc, const QgsReadWriteContext &context)
Writes a symbol definition to XML.
static Q_INVOKABLE double fromUnitToUnitFactor(Qgis::DistanceUnit fromUnit, Qgis::DistanceUnit toUnit)
Returns the conversion factor between the specified distance units.
static Q_INVOKABLE QString toAbbreviatedString(Qgis::DistanceUnit unit)
Returns a translated abbreviation representing a distance unit.
Represents a vector layer which manages a vector based dataset.
T qgsEnumKeyToValue(const QString &key, const T &defaultValue, bool tryValueAsKey=true, bool *returnOk=nullptr)
Returns the value corresponding to the given key of an enum.
QString qgsEnumValueToKey(const T &value, bool *returnOk=nullptr)
Returns the value for the given key of an enum.
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference).
T qgsgeometry_cast(QgsAbstractGeometry *geom)
_LayerRef< QgsMapLayer > QgsMapLayerRef
TYPE * resolveWeakly(const QgsProject *project, MatchType matchType=MatchType::All)
Resolves the map layer by attempting to find a matching layer in a project using a weak match.
TYPE * get() const
Returns a pointer to the layer, or nullptr if the reference has not yet been matched to a layer.
bool readXml(const QDomElement &element, const QgsReadWriteContext &context)
Reads the layer's properties from an XML element.