QGIS API Documentation 3.99.0-Master (2fe06baccd8)
Loading...
Searching...
No Matches
qgsrendercontext.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsrendercontext.cpp
3 --------------------
4 begin : March 16, 2008
5 copyright : (C) 2008 by Marco Hugentobler
6 email : marco dot hugentobler at karto dot baug dot ethz dot ch
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
19#include "qgsrendercontext.h"
20
21#include "qgselevationmap.h"
24#include "qgslogger.h"
25#include "qgsmapsettings.h"
26#include "qgssymbollayer.h"
27#include "qgsunittypes.h"
28
29#define POINTS_TO_MM 2.83464567
30#define INCH_TO_MM 25.4
31
33 : mFlags( Qgis::RenderContextFlag::DrawEditingInfo | Qgis::RenderContextFlag::UseAdvancedEffects | Qgis::RenderContextFlag::DrawSelection | Qgis::RenderContextFlag::UseRenderingOptimization )
34{
35 mVectorSimplifyMethod.setSimplifyHints( Qgis::VectorRenderingSimplificationFlag::NoSimplification );
36 // For RenderMetersInMapUnits support, when rendering in Degrees, the Ellipsoid must be set
37 // - for Previews/Icons the default Extent can be used
38 mDistanceArea.setEllipsoid( mDistanceArea.sourceCrs().ellipsoidAcronym() );
39}
40
42
45 //****** IMPORTANT! editing this? make sure you update the move constructor too! *****
46 , mFlags( rh.mFlags )
47 , mRasterizedRenderingPolicy( rh.mRasterizedRenderingPolicy )
48 , mPainter( rh.mPainter )
49 , mPreviewRenderPainter( rh.mPreviewRenderPainter )
50 , mMaskPainter( rh.mMaskPainter )
51
52 // TODO -- these were NOT being copied, but it's unclear if that was intentional or a bug??
53 , mMaskIdProvider( nullptr )
54 , mCurrentMaskId( -1 )
55
56 , mIsGuiPreview( rh.mIsGuiPreview )
57 , mCoordTransform( rh.mCoordTransform )
58 , mDistanceArea( rh.mDistanceArea )
59 , mExtent( rh.mExtent )
60 , mOriginalMapExtent( rh.mOriginalMapExtent )
61 , mMapToPixel( rh.mMapToPixel )
62 , mRenderingStopped( rh.mRenderingStopped )
63 , mFeedback( rh.mFeedback )
64 , mScaleFactor( rh.mScaleFactor )
65 , mDpiTarget( rh.mDpiTarget )
66 , mRendererScale( rh.mRendererScale )
67 , mSymbologyReferenceScale( rh.mSymbologyReferenceScale )
68 , mLabelingEngine( rh.mLabelingEngine )
69 , mLabelSink( rh.mLabelSink )
70 , mSelectionColor( rh.mSelectionColor )
71 , mVectorSimplifyMethod( rh.mVectorSimplifyMethod )
72 , mExpressionContext( rh.mExpressionContext )
73 //****** IMPORTANT! editing this? make sure you update the move constructor too! *****
74 , mGeometry( rh.mGeometry )
75 , mFeatureFilterProvider( rh.mFeatureFilterProvider ? rh.mFeatureFilterProvider->clone() : nullptr )
76 , mSegmentationTolerance( rh.mSegmentationTolerance )
77 , mSegmentationToleranceType( rh.mSegmentationToleranceType )
78 , mTransformContext( rh.mTransformContext )
79 , mPathResolver( rh.mPathResolver )
80 , mTextRenderFormat( rh.mTextRenderFormat )
81 , mRenderedFeatureHandlers( rh.mRenderedFeatureHandlers )
82 , mHasRenderedFeatureHandlers( rh.mHasRenderedFeatureHandlers )
83 , mCustomProperties( rh.mCustomProperties )
84 , mDisabledSymbolLayers()
85 , mClippingRegions( rh.mClippingRegions )
86 , mFeatureClipGeometry( rh.mFeatureClipGeometry )
87 , mTextureOrigin( rh.mTextureOrigin )
88 , mZRange( rh.mZRange )
89 , mSize( rh.mSize )
90 , mDevicePixelRatio( rh.mDevicePixelRatio )
91 , mImageFormat( rh.mImageFormat )
92 , mRendererUsage( rh.mRendererUsage )
93 , mFrameRate( rh.mFrameRate )
94 , mCurrentFrame( rh.mCurrentFrame )
95 , mSymbolLayerClippingGeometries( rh.mSymbolLayerClippingGeometries )
96 , mMaskRenderSettings( rh.mMaskRenderSettings )
97#ifdef QGISDEBUG
98 , mHasTransformContext( rh.mHasTransformContext )
99#endif
100 , mElevationMap( rh.mElevationMap )
101 //****** IMPORTANT! editing this? make sure you update the move constructor too! *****
102{
103}
104
107 , mFlags( rh.mFlags )
108 , mRasterizedRenderingPolicy( rh.mRasterizedRenderingPolicy )
109 , mPainter( rh.mPainter )
110 , mPreviewRenderPainter( rh.mPreviewRenderPainter )
111 , mMaskPainter( std::move( rh.mMaskPainter ) )
112 , mMaskIdProvider( rh.mMaskIdProvider )
113 , mCurrentMaskId( rh.mCurrentMaskId )
114 , mIsGuiPreview( rh.mIsGuiPreview )
115 , mCoordTransform( std::move( rh.mCoordTransform ) )
116 , mDistanceArea( std::move( rh.mDistanceArea ) )
117 , mExtent( std::move( rh.mExtent ) )
118 , mOriginalMapExtent( std::move( rh.mOriginalMapExtent ) )
119 , mMapToPixel( std::move( rh.mMapToPixel ) )
120 , mRenderingStopped( rh.mRenderingStopped )
121 , mFeedback( rh.mFeedback )
122 , mScaleFactor( rh.mScaleFactor )
123 , mDpiTarget( rh.mDpiTarget )
124 , mRendererScale( rh.mRendererScale )
125 , mSymbologyReferenceScale( rh.mSymbologyReferenceScale )
126 , mLabelingEngine( rh.mLabelingEngine )
127 , mLabelSink( rh.mLabelSink )
128 , mSelectionColor( std::move( rh.mSelectionColor ) )
129 , mVectorSimplifyMethod( std::move( rh.mVectorSimplifyMethod ) )
130 , mExpressionContext( std::move( rh.mExpressionContext ) )
131 , mGeometry( std::move( rh.mGeometry ) )
132 , mFeatureFilterProvider( std::move( rh.mFeatureFilterProvider ) )
133 , mSegmentationTolerance( rh.mSegmentationTolerance )
134 , mSegmentationToleranceType( rh.mSegmentationToleranceType )
135 , mTransformContext( std::move( rh.mTransformContext ) )
136 , mPathResolver( std::move( rh.mPathResolver ) )
137 , mTextRenderFormat( rh.mTextRenderFormat )
138 , mRenderedFeatureHandlers( std::move( rh.mRenderedFeatureHandlers ) )
139 , mHasRenderedFeatureHandlers( rh.mHasRenderedFeatureHandlers )
140 , mCustomProperties( std::move( rh.mCustomProperties ) )
141 , mDisabledSymbolLayers( std::move( rh.mDisabledSymbolLayers ) )
142 , mClippingRegions( std::move( rh.mClippingRegions ) )
143 , mFeatureClipGeometry( std::move( rh.mFeatureClipGeometry ) )
144 , mTextureOrigin( std::move( rh.mTextureOrigin ) )
145 , mZRange( std::move( rh.mZRange ) )
146 , mSize( std::move( rh.mSize ) )
147 , mDevicePixelRatio( rh.mDevicePixelRatio )
148 , mImageFormat( rh.mImageFormat )
149 , mRendererUsage( rh.mRendererUsage )
150 , mFrameRate( rh.mFrameRate )
151 , mCurrentFrame( rh.mCurrentFrame )
152 , mSymbolLayerClippingGeometries( std::move( rh.mSymbolLayerClippingGeometries ) )
153 , mMaskRenderSettings( std::move( rh.mMaskRenderSettings ) )
154#ifdef QGISDEBUG
155 , mHasTransformContext( rh.mHasTransformContext )
156#endif
157 , mElevationMap( rh.mElevationMap )
158{
159
160}
161
163{
164 if ( &rh == this )
165 return *this;
166
167 //****** IMPORTANT! editing this? make sure you update the move assignment operator too! *****
168 mFlags = rh.mFlags;
169 mRasterizedRenderingPolicy = rh.mRasterizedRenderingPolicy;
170 mPainter = rh.mPainter;
171 mPreviewRenderPainter = rh.mPreviewRenderPainter;
172 mMaskPainter = rh.mMaskPainter;
173 // TODO -- these were NOT being copied, but it's unclear if that was intentional or a bug??
174 // mMaskIdProvider
175 // mCurrentMaskId
176 mIsGuiPreview = rh.mIsGuiPreview;
177 mCoordTransform = rh.mCoordTransform;
178 mExtent = rh.mExtent;
179 mOriginalMapExtent = rh.mOriginalMapExtent;
180 mMapToPixel = rh.mMapToPixel;
181 mRenderingStopped = rh.mRenderingStopped;
182 mFeedback = rh.mFeedback;
183 mScaleFactor = rh.mScaleFactor;
184 mDpiTarget = rh.mDpiTarget;
185 mRendererScale = rh.mRendererScale;
186 mSymbologyReferenceScale = rh.mSymbologyReferenceScale;
187 mLabelingEngine = rh.mLabelingEngine;
188 mLabelSink = rh.mLabelSink;
189 mSelectionColor = rh.mSelectionColor;
190 mVectorSimplifyMethod = rh.mVectorSimplifyMethod;
191 mExpressionContext = rh.mExpressionContext;
192 mGeometry = rh.mGeometry;
193 mFeatureFilterProvider.reset( rh.mFeatureFilterProvider ? rh.mFeatureFilterProvider->clone() : nullptr );
194 mSegmentationTolerance = rh.mSegmentationTolerance;
195 //****** IMPORTANT! editing this? make sure you update the move assignment operator too! *****
196 mSegmentationToleranceType = rh.mSegmentationToleranceType;
197 mDistanceArea = rh.mDistanceArea;
198 mTransformContext = rh.mTransformContext;
199 mPathResolver = rh.mPathResolver;
200 mTextRenderFormat = rh.mTextRenderFormat;
201 mRenderedFeatureHandlers = rh.mRenderedFeatureHandlers;
202 mHasRenderedFeatureHandlers = rh.mHasRenderedFeatureHandlers;
203 mCustomProperties = rh.mCustomProperties;
204 mClippingRegions = rh.mClippingRegions;
205 mFeatureClipGeometry = rh.mFeatureClipGeometry;
206 mTextureOrigin = rh.mTextureOrigin;
207 mZRange = rh.mZRange;
208 mSize = rh.mSize;
209 mDevicePixelRatio = rh.mDevicePixelRatio;
210 mImageFormat = rh.mImageFormat;
212 mRendererUsage = rh.mRendererUsage;
213 mFrameRate = rh.mFrameRate;
214 mCurrentFrame = rh.mCurrentFrame;
215 mSymbolLayerClippingGeometries = rh.mSymbolLayerClippingGeometries;
216 mMaskRenderSettings = rh.mMaskRenderSettings;
217 if ( isTemporal() )
219#ifdef QGISDEBUG
220 mHasTransformContext = rh.mHasTransformContext;
221#endif
222 mElevationMap = rh.elevationMap();
223 //****** IMPORTANT! editing this? make sure you update the move assignment operator too! *****
224 return *this;
225}
226
228{
229 if ( &rh == this )
230 return *this;
231
232 mFlags = rh.mFlags;
233 mRasterizedRenderingPolicy = rh.mRasterizedRenderingPolicy;
234 mPainter = rh.mPainter;
235 mPreviewRenderPainter = rh.mPreviewRenderPainter;
236 mMaskPainter = std::move( rh.mMaskPainter );
237 mMaskIdProvider = rh.mMaskIdProvider;
238 mCurrentMaskId = rh.mCurrentMaskId;
239 mIsGuiPreview = rh.mIsGuiPreview;
240 mCoordTransform = std::move( rh.mCoordTransform );
241 mExtent = std::move( rh.mExtent );
242 mOriginalMapExtent = std::move( rh.mOriginalMapExtent );
243 mMapToPixel = std::move( rh.mMapToPixel );
244 mRenderingStopped = rh.mRenderingStopped;
245 mFeedback = rh.mFeedback;
246 mScaleFactor = rh.mScaleFactor;
247 mDpiTarget = rh.mDpiTarget;
248 mRendererScale = rh.mRendererScale;
249 mSymbologyReferenceScale = rh.mSymbologyReferenceScale;
250 mLabelingEngine = rh.mLabelingEngine;
251 mLabelSink = rh.mLabelSink;
252 mSelectionColor = rh.mSelectionColor;
253 mVectorSimplifyMethod = std::move( rh.mVectorSimplifyMethod );
254 mExpressionContext = std::move( rh.mExpressionContext );
255 mGeometry = rh.mGeometry;
256 mFeatureFilterProvider = std::move( rh.mFeatureFilterProvider );
257 mSegmentationTolerance = rh.mSegmentationTolerance;
258 mSegmentationToleranceType = rh.mSegmentationToleranceType;
259 mDistanceArea = std::move( rh.mDistanceArea );
260 mTransformContext = std::move( rh.mTransformContext );
261 mPathResolver = std::move( rh.mPathResolver );
262 mTextRenderFormat = rh.mTextRenderFormat;
263 mRenderedFeatureHandlers = std::move( rh.mRenderedFeatureHandlers );
264 mHasRenderedFeatureHandlers = rh.mHasRenderedFeatureHandlers;
265 mCustomProperties = std::move( rh.mCustomProperties );
266 mClippingRegions = std::move( rh.mClippingRegions );
267 mFeatureClipGeometry = std::move( rh.mFeatureClipGeometry );
268 mTextureOrigin = std::move( rh.mTextureOrigin );
269 mZRange = std::move( rh.mZRange );
270 mSize = std::move( rh.mSize );
271 mDevicePixelRatio = rh.mDevicePixelRatio;
272 mImageFormat = rh.mImageFormat;
273 setIsTemporal( rh.isTemporal() );
274 mRendererUsage = rh.mRendererUsage;
275 mFrameRate = rh.mFrameRate;
276 mCurrentFrame = rh.mCurrentFrame;
277 mSymbolLayerClippingGeometries = std::move( rh.mSymbolLayerClippingGeometries );
278 mMaskRenderSettings = std::move( rh.mMaskRenderSettings );
279 if ( isTemporal() )
280 setTemporalRange( rh.temporalRange() );
281#ifdef QGISDEBUG
282 mHasTransformContext = rh.mHasTransformContext;
283#endif
284 mElevationMap = rh.mElevationMap;
285
286 return *this;
287}
288
290{
291 QgsRenderContext context;
292 context.setPainter( painter );
293 if ( painter && painter->device() )
294 {
295 context.setScaleFactor( painter->device()->physicalDpiX() / 25.4 );
296 }
297 else
298 {
299 context.setScaleFactor( 3.465 ); //assume 88 dpi as standard value
300 }
301
302 if ( painter && painter->renderHints() & QPainter::Antialiasing )
304 if ( painter && painter->renderHints() & QPainter::SmoothPixmapTransform )
306 if ( painter && painter->renderHints() & QPainter::LosslessImageRendering )
308
309 return context;
310}
311
313{
314 if ( !painter )
315 painter = mPainter;
316
317 if ( !painter )
318 return;
319
320 painter->setRenderHint( QPainter::Antialiasing, mFlags & Qgis::RenderContextFlag::Antialiasing );
321 painter->setRenderHint( QPainter::LosslessImageRendering, mFlags & Qgis::RenderContextFlag::LosslessImageRendering );
322 painter->setRenderHint( QPainter::SmoothPixmapTransform, mFlags & Qgis::RenderContextFlag::HighQualityImageTransforms );
323}
324
326{
327#ifdef QGISDEBUG
328 if ( !mHasTransformContext )
329 QgsDebugMsgLevel( QStringLiteral( "No QgsCoordinateTransformContext context set for transform" ), 4 );
330#endif
331 return mTransformContext;
332}
333
335{
336 mTransformContext = context;
337#ifdef QGISDEBUG
338 mHasTransformContext = true;
339#endif
340}
341
343{
344 mFeedback = feedback;
345}
346
348{
349 return mFeedback;
350}
351
353{
354 mFlags = flags;
355 matchRasterizedRenderingPolicyToFlags();
356}
357
359{
360 if ( on )
361 mFlags |= flag;
362 else
363 mFlags &= ~( static_cast< int >( flag ) );
364 matchRasterizedRenderingPolicyToFlags();
365}
366
368{
369 return mFlags;
370}
371
373{
374 return mFlags.testFlag( flag );
375}
376
378{
380 QgsRectangle extent = mapSettings.visibleExtent();
381 extent.grow( mapSettings.extentBuffer() );
382 ctx.setMapToPixel( mapSettings.mapToPixel() );
383 ctx.setExtent( extent );
384 ctx.setMapExtent( mapSettings.visibleExtent() );
390 ctx.setSelectionColor( mapSettings.selectionColor() );
404
406
407 ctx.setScaleFactor( mapSettings.outputDpi() / 25.4 ); // = pixels per mm
408 ctx.setDpiTarget( mapSettings.dpiTarget() >= 0.0 ? mapSettings.dpiTarget() : -1.0 );
409 ctx.setRendererScale( mapSettings.scale() );
410 ctx.setExpressionContext( mapSettings.expressionContext() );
413 ctx.mDistanceArea.setSourceCrs( mapSettings.destinationCrs(), mapSettings.transformContext() );
414 ctx.mDistanceArea.setEllipsoid( mapSettings.ellipsoid() );
415 ctx.setTransformContext( mapSettings.transformContext() );
416 ctx.setPathResolver( mapSettings.pathResolver() );
417 ctx.setTextRenderFormat( mapSettings.textRenderFormat() );
418 ctx.setVectorSimplifyMethod( mapSettings.simplifyMethod() );
419 ctx.mRenderedFeatureHandlers = mapSettings.renderedFeatureHandlers();
420 ctx.mHasRenderedFeatureHandlers = !mapSettings.renderedFeatureHandlers().isEmpty();
421 //this flag is only for stopping during the current rendering progress,
422 //so must be false at every new render operation
423 ctx.setRenderingStopped( false );
424 ctx.mCustomProperties = mapSettings.customRenderingFlags();
425 ctx.setIsTemporal( mapSettings.isTemporal() );
426 if ( ctx.isTemporal() )
427 ctx.setTemporalRange( mapSettings.temporalRange() );
428
429 ctx.setZRange( mapSettings.zRange() );
430 ctx.setOutputSize( mapSettings.outputSize() );
431 ctx.setDevicePixelRatio( mapSettings.devicePixelRatio() );
432 ctx.setImageFormat( mapSettings.outputImageFormat() );
433
434 ctx.mClippingRegions = mapSettings.clippingRegions();
435
436 ctx.setMaskSettings( mapSettings.maskSettings() );
437
438 ctx.mRendererUsage = mapSettings.rendererUsage();
439 ctx.mFrameRate = mapSettings.frameRate();
440 ctx.mCurrentFrame = mapSettings.currentFrame();
441
442 const QStringList layerIds = mapSettings.layerIds( true );
443 if ( !layerIds.empty() )
444 ctx.setCustomProperty( QStringLiteral( "visible_layer_ids" ), layerIds );
445
446 return ctx;
447}
448
450{
451 return mRasterizedRenderingPolicy != Qgis::RasterizedRenderingPolicy::Default;
452}
453
455{
456 return mRasterizedRenderingPolicy != Qgis::RasterizedRenderingPolicy::ForceVector;
457}
458
460{
462
463 if ( enabled && mRasterizedRenderingPolicy == Qgis::RasterizedRenderingPolicy::ForceVector )
464 {
465 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::PreferVector;
466 }
467 else if ( !enabled )
468 {
469 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::ForceVector;
470 }
471}
472
474{
475 return mFlags.testFlag( Qgis::RenderContextFlag::DrawEditingInfo );
476}
477
479{
480 return mFlags.testFlag( Qgis::RenderContextFlag::DrawSelection );
481}
482
484{
485 mCoordTransform = t;
486}
487
492
494{
496 if ( force && mRasterizedRenderingPolicy == Qgis::RasterizedRenderingPolicy::Default )
497 {
498 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::PreferVector;
499 }
500 else if ( !force )
501 {
502 switch ( mRasterizedRenderingPolicy )
503 {
505 break;
506
509 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::Default;
510 break;
511 }
512 }
513}
514
519
524
529
531{
532 if ( ffp )
533 {
534 mFeatureFilterProvider.reset( ffp->clone() );
535 }
536 else
537 {
538 mFeatureFilterProvider.reset( nullptr );
539 }
540}
541
543{
544 return mFeatureFilterProvider.get();
545}
546
548{
549 double conversionFactor = 1.0;
550 bool isMapUnitHack = false;
551 switch ( unit )
552 {
554 conversionFactor = mScaleFactor;
555 break;
556
558 conversionFactor = mScaleFactor / POINTS_TO_MM;
559 break;
560
562 conversionFactor = mScaleFactor * INCH_TO_MM;
563 break;
564
566 {
567 if ( mMapToPixel.isValid() )
568 size = convertMetersToMapUnits( size );
570 // Fall through to RenderMapUnits with size in meters converted to size in MapUnits
571 [[fallthrough]];
572 }
574 {
575 if ( mMapToPixel.isValid() )
576 {
577 const double mup = scale.computeMapUnitsPerPixel( *this );
578 if ( mup > 0 )
579 {
580 conversionFactor = 1.0 / mup;
581 }
582 else
583 {
584 conversionFactor = 1.0;
585 }
586 }
587 else
588 {
589 // invalid map to pixel. A size in map units can't be calculated, so treat the size as points
590 // and clamp it to a reasonable range. It's the best we can do in this situation!
591 isMapUnitHack = true;
592 conversionFactor = mScaleFactor / POINTS_TO_MM;
593 }
594 break;
595 }
597 conversionFactor = 1.0;
598 break;
599
602 //no sensible value
603 conversionFactor = 1.0;
604 break;
605 }
606
607 double convertedSize = size * conversionFactor;
608
609 if ( unit == Qgis::RenderUnit::MapUnits )
610 {
611 //check max/min size
612 if ( scale.minSizeMMEnabled )
613 convertedSize = std::max( convertedSize, scale.minSizeMM * mScaleFactor );
614 if ( scale.maxSizeMMEnabled )
615 convertedSize = std::min( convertedSize, scale.maxSizeMM * mScaleFactor );
616 }
617
618 if ( isMapUnitHack )
619 {
620 // since we are arbitrarily treating map units as mm, we need to clamp to an (arbitrary!) reasonable range.
621 convertedSize = std::clamp( convertedSize, 10.0, 100.0 );
622 }
623 else
624 {
625 const double symbologyReferenceScaleFactor = mSymbologyReferenceScale > 0 ? mSymbologyReferenceScale / mRendererScale : 1;
626 convertedSize *= symbologyReferenceScaleFactor;
627 }
628
630 {
631 // apply property based constraints in order to optimise symbol preview rendering
632 switch ( property )
633 {
635 break;
636
638 // excessively large shadow offset in symbol preview icons is undesirable -- it pushes the shadow outside of view
639 convertedSize = std::min( convertedSize, 100.0 );
640 break;
642 // excessively large blur in symbol preview icons is too slow to calculate
643 convertedSize = std::min<double>( convertedSize, 30 );
644 break;
646 // excessively large glow spread in symbol preview icons is too slow to calculate
647 convertedSize = std::min<double>( convertedSize, 50 );
648 break;
649 }
650 }
651
652 return convertedSize;
653}
654
656{
657 double conversionFactor = 1.0;
658 // NOLINTBEGIN(bugprone-branch-clone)
659 switch ( unit )
660 {
662 conversionFactor = 1 / mScaleFactor;
663 break;
664
666 conversionFactor = POINTS_TO_MM / mScaleFactor;
667 break;
668
670 conversionFactor = 1 / ( mScaleFactor * INCH_TO_MM );
671 break;
672
674 {
675 if ( mMapToPixel.isValid() )
676 size = size / convertMetersToMapUnits( 1 );
677 // Fall through to RenderMapUnits with size in meters converted to size in MapUnits
678 [[fallthrough]];
679 }
681 {
682 if ( mMapToPixel.isValid() )
683 {
684 const double mup = mapToPixel().mapUnitsPerPixel();;
685 if ( mup > 0 )
686 {
687 conversionFactor = mup / 1.0;
688 }
689 else
690 {
691 conversionFactor = 1.0;
692 }
693 }
694 else
695 {
696 // invalid map to pixel. A size in map units can't be calculated, so treat the size as points.
697 // It's the best we can do in this situation!
698 conversionFactor = POINTS_TO_MM / mScaleFactor;
699 }
700 break;
701 }
703 conversionFactor = 1.0;
704 break;
705
708 //no sensible value
709 conversionFactor = 1.0;
710 break;
711 }
712 // NOLINTEND(bugprone-branch-clone)
713
714 return size * conversionFactor;
715}
716
717double QgsRenderContext::convertToMapUnits( double size, Qgis::RenderUnit unit, const QgsMapUnitScale &scale ) const
718{
719 const double mup = mMapToPixel.mapUnitsPerPixel();
720
721 const double symbologyReferenceScaleFactor = mSymbologyReferenceScale > 0 ? mSymbologyReferenceScale / mRendererScale : 1;
722
723 switch ( unit )
724 {
726 {
727 size = convertMetersToMapUnits( size );
728 // Fall through to RenderMapUnits with values of meters converted to MapUnits
729 [[fallthrough]];
730 }
732 {
733 // check scale
734 double minSizeMU = std::numeric_limits<double>::lowest();
735 if ( scale.minSizeMMEnabled )
736 {
737 minSizeMU = scale.minSizeMM * mScaleFactor * mup;
738 }
739 if ( !qgsDoubleNear( scale.minScale, 0.0 ) )
740 {
741 minSizeMU = std::max( minSizeMU, size * ( mRendererScale / scale.minScale ) );
742 }
743 size = std::max( size, minSizeMU );
744
745 double maxSizeMU = std::numeric_limits<double>::max();
746 if ( scale.maxSizeMMEnabled )
747 {
748 maxSizeMU = scale.maxSizeMM * mScaleFactor * mup;
749 }
750 if ( !qgsDoubleNear( scale.maxScale, 0.0 ) )
751 {
752 maxSizeMU = std::min( maxSizeMU, size * ( mRendererScale / scale.maxScale ) );
753 }
754 size = std::min( size, maxSizeMU );
755
756 return size;
757 }
759 {
760 return size * mScaleFactor * mup / symbologyReferenceScaleFactor;
761 }
763 {
764 return size * mScaleFactor * mup / POINTS_TO_MM / symbologyReferenceScaleFactor;
765 }
767 {
768 return size * mScaleFactor * mup * INCH_TO_MM / symbologyReferenceScaleFactor;
769 }
771 {
772 return size * mup / symbologyReferenceScaleFactor;
773 }
774
777 //no sensible value
778 return 0.0;
779 }
780 return 0.0;
781}
782
783double QgsRenderContext::convertFromMapUnits( double sizeInMapUnits, Qgis::RenderUnit outputUnit ) const
784{
785 const double mup = mMapToPixel.mapUnitsPerPixel();
786 const double symbologyReferenceScaleFactor = mSymbologyReferenceScale > 0 ? mSymbologyReferenceScale / mRendererScale : 1;
787
788 switch ( outputUnit )
789 {
791 {
792 return sizeInMapUnits / convertMetersToMapUnits( 1.0 );
793 }
795 {
796 return sizeInMapUnits;
797 }
799 {
800 return sizeInMapUnits / ( mScaleFactor * mup ) * symbologyReferenceScaleFactor;
801 }
803 {
804 return sizeInMapUnits / ( mScaleFactor * mup / POINTS_TO_MM ) * symbologyReferenceScaleFactor;
805 }
807 {
808 return sizeInMapUnits / ( mScaleFactor * mup * INCH_TO_MM ) * symbologyReferenceScaleFactor;
809 }
811 {
812 return sizeInMapUnits / mup * symbologyReferenceScaleFactor;
813 }
814
817 //no sensible value
818 return 0.0;
819 }
820 return 0.0;
821}
822
823double QgsRenderContext::convertMetersToMapUnits( double meters ) const
824{
825 switch ( mDistanceArea.sourceCrs().mapUnits() )
826 {
828 return meters;
830 {
831 if ( mExtent.isNull() )
832 {
833 // we don't have an extent to calculate exactly -- so just use a very rough approximation
835 }
836
837 QgsPointXY pointCenter = mExtent.center();
838 // The Extent is in the sourceCrs(), when different from destinationCrs()
839 // - the point must be transformed, since DistanceArea uses the destinationCrs()
840 // Note: the default QgsCoordinateTransform() : authid() will return an empty String
841 if ( !mCoordTransform.isShortCircuited() )
842 {
843 try
844 {
845 pointCenter = mCoordTransform.transform( pointCenter );
846 }
847 catch ( const QgsCsException & )
848 {
849 QgsDebugError( QStringLiteral( "QgsRenderContext::convertMetersToMapUnits(): failed to reproject pointCenter" ) );
850 // what should we return;.. ?
851 return meters;
852 }
853 }
854
855 const int multiplier = meters < 0 ? -1 : 1;
856 return multiplier * mDistanceArea.measureLineProjected( pointCenter, std::fabs( meters ) );
857 }
906 return ( meters * QgsUnitTypes::fromUnitToUnitFactor( Qgis::DistanceUnit::Meters, mDistanceArea.sourceCrs().mapUnits() ) );
907 }
908 return meters;
909}
910
911QList<QgsRenderedFeatureHandlerInterface *> QgsRenderContext::renderedFeatureHandlers() const
912{
913 return mRenderedFeatureHandlers;
914}
915
916QList<QgsMapClippingRegion> QgsRenderContext::clippingRegions() const
917{
918 return mClippingRegions;
919}
920
922{
923 return mFeatureClipGeometry;
924}
925
927{
928 mFeatureClipGeometry = geometry;
929}
930
932{
933 return mTextureOrigin;
934}
935
936void QgsRenderContext::setTextureOrigin( const QPointF &origin )
937{
938 mTextureOrigin = origin;
939}
940
942{
943 mMaskRenderSettings = settings;
944}
945
947{
948 return mZRange;
949}
950
952{
953 mZRange = range;
954}
955
957{
958 return mSize;
959}
960
962{
963 mSize = size;
964}
965
967{
968 return mDevicePixelRatio;
969}
970
972{
973 mDevicePixelRatio = ratio;
974}
975
977{
978 return outputSize() * mDevicePixelRatio;
979}
980
982{
983 return mRasterizedRenderingPolicy;
984}
985
987{
988 mRasterizedRenderingPolicy = policy;
989 switch ( mRasterizedRenderingPolicy )
990 {
992 mFlags.setFlag( Qgis::RenderContextFlag::ForceVectorOutput, false );
993 mFlags.setFlag( Qgis::RenderContextFlag::UseAdvancedEffects, true );
994 break;
996 mFlags.setFlag( Qgis::RenderContextFlag::ForceVectorOutput, true );
997 mFlags.setFlag( Qgis::RenderContextFlag::UseAdvancedEffects, true );
998 break;
1000 mFlags.setFlag( Qgis::RenderContextFlag::ForceVectorOutput, true );
1001 mFlags.setFlag( Qgis::RenderContextFlag::UseAdvancedEffects, false );
1002 break;
1003 }
1004}
1005
1007{
1008 return mFrameRate;
1009}
1010
1012{
1013 mFrameRate = rate;
1014}
1015
1017{
1018 return mCurrentFrame;
1019}
1020
1022{
1023 mCurrentFrame = frame;
1024}
1025
1027{
1028 return mElevationMap;
1029}
1030
1032{
1033 mElevationMap = map;
1034}
1035
1036void QgsRenderContext::matchRasterizedRenderingPolicyToFlags()
1037{
1038 if ( !mFlags.testFlag( Qgis::RenderContextFlag::ForceVectorOutput )
1039 && mFlags.testFlag( Qgis::RenderContextFlag::UseAdvancedEffects ) )
1040 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::Default;
1041 else if ( mFlags.testFlag( Qgis::RenderContextFlag::ForceVectorOutput )
1042 && mFlags.testFlag( Qgis::RenderContextFlag::UseAdvancedEffects ) )
1043 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::PreferVector;
1044 else if ( mFlags.testFlag( Qgis::RenderContextFlag::ForceVectorOutput )
1045 && !mFlags.testFlag( Qgis::RenderContextFlag::UseAdvancedEffects ) )
1046 mRasterizedRenderingPolicy = Qgis::RasterizedRenderingPolicy::ForceVector;
1047}
1048
1049void QgsRenderContext::addSymbolLayerClipPath( const QString &symbolLayerId, QPainterPath path )
1050{
1052 if ( !geometry.isEmpty() )
1053 addSymbolLayerClipGeometry( symbolLayerId, geometry );
1054}
1055
1056QList<QPainterPath> QgsRenderContext::symbolLayerClipPaths( const QString &symbolLayerId ) const
1057{
1058 const QVector<QgsGeometry> geometries = symbolLayerClipGeometries( symbolLayerId );
1059 QList<QPainterPath> res;
1060 res.reserve( geometries.size() );
1061 for ( const QgsGeometry &geometry : geometries )
1062 {
1063 res << geometry.constGet()->asQPainterPath();
1064 }
1065 return res;
1066}
1067
1068void QgsRenderContext::addSymbolLayerClipGeometry( const QString &symbolLayerId, const QgsGeometry &geometry )
1069{
1070 if ( geometry.isMultipart() )
1071 {
1072 mSymbolLayerClippingGeometries[ symbolLayerId ].append( geometry.asGeometryCollection() );
1073 }
1074 else
1075 {
1076 mSymbolLayerClippingGeometries[ symbolLayerId ].append( geometry );
1077 }
1078}
1079
1080bool QgsRenderContext::symbolLayerHasClipGeometries( const QString &symbolLayerId ) const
1081{
1082 auto it = mSymbolLayerClippingGeometries.constFind( symbolLayerId );
1083 if ( it == mSymbolLayerClippingGeometries.constEnd() )
1084 return false;
1085 return !it.value().isEmpty();
1086}
1087
1088QVector<QgsGeometry> QgsRenderContext::symbolLayerClipGeometries( const QString &symbolLayerId ) const
1089{
1090 return mSymbolLayerClippingGeometries[ symbolLayerId ];
1091}
1092
1093void QgsRenderContext::setDisabledSymbolLayers( const QSet<const QgsSymbolLayer *> &symbolLayers )
1094{
1095 mDisabledSymbolLayers.clear();
1096 for ( const QgsSymbolLayer *symbolLayer : symbolLayers )
1097 mDisabledSymbolLayers << symbolLayer->id();
1098}
1099
1100void QgsRenderContext::setDisabledSymbolLayersV2( const QSet<QString> &symbolLayers )
1101{
1102 mDisabledSymbolLayers = symbolLayers;
1103}
1104
1105QSet<const QgsSymbolLayer *> QgsRenderContext::disabledSymbolLayers() const
1106{
1107 return QSet<const QgsSymbolLayer *>();
1108}
1109
1111{
1112 return mDisabledSymbolLayers;
1113}
1114
1116{
1117 return !mDisabledSymbolLayers.contains( layer->id() );
1118}
Provides global constants and enumerations for use throughout the application.
Definition qgis.h:56
RasterizedRenderingPolicy
Policies controlling when rasterisation of content during renders is permitted.
Definition qgis.h:2703
@ Default
Allow raster-based rendering in situations where it is required for correct rendering or where it wil...
Definition qgis.h:2704
@ PreferVector
Prefer vector-based rendering, when the result will still be visually near-identical to a raster-base...
Definition qgis.h:2705
@ ForceVector
Always force vector-based rendering, even when the result will be visually different to a raster-base...
Definition qgis.h:2706
RenderSubcomponentProperty
Rendering subcomponent properties.
Definition qgis.h:3053
@ ShadowOffset
Shadow offset.
Definition qgis.h:3055
@ GlowSpread
Glow spread size.
Definition qgis.h:3057
@ Generic
Generic subcomponent property.
Definition qgis.h:3054
@ NoSimplification
No simplification can be applied.
Definition qgis.h:3030
@ YardsBritishSears1922Truncated
British yards (Sears 1922 truncated).
Definition qgis.h:5053
@ Feet
Imperial feet.
Definition qgis.h:5016
@ MilesUSSurvey
US Survey miles.
Definition qgis.h:5060
@ LinksBritishSears1922
British links (Sears 1922).
Definition qgis.h:5048
@ YardsBritishBenoit1895A
British yards (Benoit 1895 A).
Definition qgis.h:5051
@ LinksBritishBenoit1895A
British links (Benoit 1895 A).
Definition qgis.h:5045
@ Centimeters
Centimeters.
Definition qgis.h:5021
@ YardsIndian1975
Indian yards (1975).
Definition qgis.h:5059
@ FeetUSSurvey
US Survey feet.
Definition qgis.h:5043
@ Millimeters
Millimeters.
Definition qgis.h:5022
@ FeetBritishSears1922
British feet (Sears 1922).
Definition qgis.h:5036
@ YardsClarkes
Clarke's yards.
Definition qgis.h:5055
@ YardsIndian
Indian yards.
Definition qgis.h:5056
@ FeetBritishBenoit1895B
British feet (Benoit 1895 B).
Definition qgis.h:5034
@ Miles
Terrestrial miles.
Definition qgis.h:5019
@ LinksUSSurvey
US Survey links.
Definition qgis.h:5050
@ Meters
Meters.
Definition qgis.h:5014
@ ChainsUSSurvey
US Survey chains.
Definition qgis.h:5030
@ FeetClarkes
Clarke's feet.
Definition qgis.h:5037
@ Unknown
Unknown distance unit.
Definition qgis.h:5063
@ Yards
Imperial yards.
Definition qgis.h:5018
@ FeetBritish1936
British feet (1936).
Definition qgis.h:5032
@ FeetIndian1962
Indian feet (1962).
Definition qgis.h:5041
@ YardsBritishSears1922
British yards (Sears 1922).
Definition qgis.h:5054
@ FeetIndian1937
Indian feet (1937).
Definition qgis.h:5040
@ YardsIndian1937
Indian yards (1937).
Definition qgis.h:5057
@ Degrees
Degrees, for planar geographic CRS distance measurements.
Definition qgis.h:5020
@ ChainsBritishBenoit1895B
British chains (Benoit 1895 B).
Definition qgis.h:5026
@ LinksBritishSears1922Truncated
British links (Sears 1922 truncated).
Definition qgis.h:5047
@ ChainsBritishBenoit1895A
British chains (Benoit 1895 A).
Definition qgis.h:5025
@ YardsBritishBenoit1895B
British yards (Benoit 1895 B).
Definition qgis.h:5052
@ FeetBritish1865
British feet (1865).
Definition qgis.h:5031
@ YardsIndian1962
Indian yards (1962).
Definition qgis.h:5058
@ FeetBritishSears1922Truncated
British feet (Sears 1922 truncated).
Definition qgis.h:5035
@ MetersGermanLegal
German legal meter.
Definition qgis.h:5062
@ LinksBritishBenoit1895B
British links (Benoit 1895 B).
Definition qgis.h:5046
@ ChainsInternational
International chains.
Definition qgis.h:5024
@ Inches
Inches.
Definition qgis.h:5023
@ Fathoms
Fathoms.
Definition qgis.h:5061
@ LinksInternational
International links.
Definition qgis.h:5044
@ ChainsBritishSears1922Truncated
British chains (Sears 1922 truncated).
Definition qgis.h:5027
@ FeetIndian
Indian (geodetic) feet.
Definition qgis.h:5039
@ NauticalMiles
Nautical miles.
Definition qgis.h:5017
@ ChainsClarkes
Clarke's chains.
Definition qgis.h:5029
@ LinksClarkes
Clarke's links.
Definition qgis.h:5049
@ ChainsBritishSears1922
British chains (Sears 1922).
Definition qgis.h:5028
@ Kilometers
Kilometers.
Definition qgis.h:5015
@ FeetIndian1975
Indian feet (1975).
Definition qgis.h:5042
@ FeetGoldCoast
Gold Coast feet.
Definition qgis.h:5038
@ FeetBritishBenoit1895A
British feet (Benoit 1895 A).
Definition qgis.h:5033
QFlags< RenderContextFlag > RenderContextFlags
Render context flags.
Definition qgis.h:2774
RenderUnit
Rendering size units.
Definition qgis.h:5183
@ Percentage
Percentage of another measurement (e.g., canvas size, feature size).
Definition qgis.h:5187
@ Millimeters
Millimeters.
Definition qgis.h:5184
@ Points
Points (e.g., for font sizes).
Definition qgis.h:5188
@ Unknown
Mixed or unknown units.
Definition qgis.h:5190
@ MapUnits
Map units.
Definition qgis.h:5185
@ Pixels
Pixels.
Definition qgis.h:5186
@ Inches
Inches.
Definition qgis.h:5189
@ MetersInMapUnits
Meters value as Map units.
Definition qgis.h:5191
RenderContextFlag
Flags which affect rendering operations.
Definition qgis.h:2748
@ DrawEditingInfo
Enable drawing of vertex markers for layers in editing mode.
Definition qgis.h:2749
@ RenderSymbolPreview
The render is for a symbol preview only and map based properties may not be available,...
Definition qgis.h:2760
@ DrawSymbolBounds
Draw bounds of symbols (for debugging/testing).
Definition qgis.h:2754
@ RenderPreviewJob
Render is a 'canvas preview' render, and shortcuts should be taken to ensure fast rendering.
Definition qgis.h:2758
@ RenderMapTile
Draw map such that there are no problems between adjacent tiles.
Definition qgis.h:2755
@ RecordProfile
Enable run-time profiling while rendering.
Definition qgis.h:2768
@ RenderLayerTree
The render is for a layer tree display where map based properties are not available and where avoidan...
Definition qgis.h:2771
@ UseRenderingOptimization
Enable vector simplification and other rendering optimizations.
Definition qgis.h:2752
@ ForceVectorOutput
Vector graphics should not be cached and drawn as raster images.
Definition qgis.h:2750
@ RenderPartialOutput
Whether to make extra effort to update map image with partially rendered layers (better for interacti...
Definition qgis.h:2757
@ LosslessImageRendering
Render images losslessly whenever possible, instead of the default lossy jpeg rendering used for some...
Definition qgis.h:2761
@ AlwaysUseGlobalMasks
When applying clipping paths for selective masking, always use global ("entire map") paths,...
Definition qgis.h:2769
@ DrawSelection
Whether vector selections should be shown in the rendered map.
Definition qgis.h:2753
@ Antialiasing
Use antialiasing while drawing.
Definition qgis.h:2756
@ SkipSymbolRendering
Disable symbol rendering while still drawing labels if enabled.
Definition qgis.h:2767
@ Render3DMap
Render is for a 3D map.
Definition qgis.h:2763
@ UseAdvancedEffects
Enable layer opacity and blending effects.
Definition qgis.h:2751
@ HighQualityImageTransforms
Enable high quality image transformations, which results in better appearance of scaled or rotated ra...
Definition qgis.h:2766
@ RenderBlocking
Render and load remote sources in the same thread to ensure rendering remote sources (svg and images)...
Definition qgis.h:2759
@ DrawEditingInfo
Enable drawing of vertex markers for layers in editing mode.
Definition qgis.h:2718
@ DrawSymbolBounds
Draw bounds of symbols (for debugging/testing).
Definition qgis.h:2724
@ RenderPreviewJob
Render is a 'canvas preview' render, and shortcuts should be taken to ensure fast rendering.
Definition qgis.h:2727
@ RenderMapTile
Draw map such that there are no problems between adjacent tiles.
Definition qgis.h:2725
@ RecordProfile
Enable run-time profiling while rendering.
Definition qgis.h:2734
@ UseRenderingOptimization
Enable vector simplification and other rendering optimizations.
Definition qgis.h:2722
@ ForceVectorOutput
Vector graphics should not be cached and drawn as raster images.
Definition qgis.h:2719
@ RenderPartialOutput
Whether to make extra effort to update map image with partially rendered layers (better for interacti...
Definition qgis.h:2726
@ LosslessImageRendering
Render images losslessly whenever possible, instead of the default lossy jpeg rendering used for some...
Definition qgis.h:2729
@ AlwaysUseGlobalMasks
When applying clipping paths for selective masking, always use global ("entire map") paths,...
Definition qgis.h:2735
@ DrawSelection
Whether vector selections should be shown in the rendered map.
Definition qgis.h:2723
@ Antialiasing
Enable anti-aliasing for map rendering.
Definition qgis.h:2717
@ SkipSymbolRendering
Disable symbol rendering while still drawing labels if enabled.
Definition qgis.h:2732
@ Render3DMap
Render is for a 3D map.
Definition qgis.h:2730
@ UseAdvancedEffects
Enable layer opacity and blending effects.
Definition qgis.h:2720
@ HighQualityImageTransforms
Enable high quality image transformations, which results in better appearance of scaled or rotated ra...
Definition qgis.h:2731
@ RenderBlocking
Render and load remote sources in the same thread to ensure rendering remote sources (svg and images)...
Definition qgis.h:2728
Contains information about the context in which a coordinate transform is executed.
Handles coordinate transforms between two coordinate systems.
Custom exception class for Coordinate Reference System related exceptions.
void setSourceCrs(const QgsCoordinateReferenceSystem &crs, const QgsCoordinateTransformContext &context)
Sets source spatial reference system crs.
bool setEllipsoid(const QString &ellipsoid)
Sets the ellipsoid by its acronym.
QgsRange which stores a range of double values.
Definition qgsrange.h:233
Stores a digital elevation model in a raster image which may get updated as a part of the map layer r...
Abstract interface for use by classes that filter the features or attributes of a layer.
virtual QgsFeatureFilterProvider * clone() const =0
Create a clone of the feature filter provider.
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
static QgsGeometry painterPathToGeometry(const QPainterPath &path)
Converts a painter path to a QgsGeometry.
A geometry is the spatial representation of a feature.
Contains configuration for rendering maps.
Qgis::RendererUsage rendererUsage() const
Returns the rendering usage.
double scale() const
Returns the calculated map scale.
double segmentationTolerance() const
Gets the segmentation tolerance applied when rendering curved geometries.
QgsDoubleRange zRange() const
Returns the range of z-values which will be visible in the map.
const QgsVectorSimplifyMethod & simplifyMethod() const
Returns the simplification settings to use when rendering vector layers.
QList< QgsRenderedFeatureHandlerInterface * > renderedFeatureHandlers() const
Returns the list of rendered feature handlers to use while rendering the map settings.
QStringList layerIds(bool expandGroupLayers=false) const
Returns the list of layer IDs which will be rendered in the map.
double dpiTarget() const
Returns the target DPI (dots per inch) to be taken into consideration when rendering.
long long currentFrame() const
Returns the current frame number of the map, for maps which are part of an animation.
const QgsMapToPixel & mapToPixel() const
float devicePixelRatio() const
Returns the device pixel ratio.
QSize outputSize() const
Returns the size of the resulting map image, in pixels.
QImage::Format outputImageFormat() const
format of internal QImage, default QImage::Format_ARGB32_Premultiplied
double extentBuffer() const
Returns the buffer in map units to use around the visible extent for rendering symbols whose correspo...
double frameRate() const
Returns the frame rate of the map (in frames per second), for maps which are part of an animation.
QColor selectionColor() const
Returns the color that is used for drawing of selected vector features.
QgsAbstractGeometry::SegmentationToleranceType segmentationToleranceType() const
Gets segmentation tolerance type (maximum angle or maximum difference between curve and approximation...
QgsRectangle visibleExtent() const
Returns the actual extent derived from requested extent that takes output image size into account.
QVariantMap customRenderingFlags() const
Returns any custom rendering flags.
QString ellipsoid() const
Returns ellipsoid's acronym.
Qgis::TextRenderFormat textRenderFormat() const
Returns the text render format, which dictates how text is rendered (e.g.
double outputDpi() const
Returns the DPI (dots per inch) used for conversion between real world units (e.g.
bool testFlag(Qgis::MapSettingsFlag flag) const
Check whether a particular flag is enabled.
QList< QgsMapClippingRegion > clippingRegions() const
Returns the list of clipping regions to apply to the map.
Qgis::RasterizedRenderingPolicy rasterizedRenderingPolicy() const
Returns the policy controlling when rasterisation of content during renders is permitted.
const QgsPathResolver & pathResolver() const
Returns the path resolver for conversion between relative and absolute paths during rendering operati...
QgsCoordinateReferenceSystem destinationCrs() const
Returns the destination coordinate reference system for the map render.
const QgsExpressionContext & expressionContext() const
Gets the expression context.
const QgsMaskRenderSettings & maskSettings() const
Returns a reference to the mask render settings, which control how masks are drawn and behave during ...
QgsCoordinateTransformContext transformContext() const
Returns the coordinate transform context, which stores various information regarding which datum tran...
double mapUnitsPerPixel() const
Returns the current map units per pixel.
Struct for storing maximum and minimum scales for measurements in map units.
double computeMapUnitsPerPixel(const QgsRenderContext &c) const
Computes a map units per pixel scaling factor, respecting the minimum and maximum scales set for the ...
bool minSizeMMEnabled
Whether the minimum size in mm should be respected.
double maxScale
The maximum scale, or 0.0 if unset.
double minScale
The minimum scale, or 0.0 if unset.
double maxSizeMM
The maximum size in millimeters, or 0.0 if unset.
bool maxSizeMMEnabled
Whether the maximum size in mm should be respected.
double minSizeMM
The minimum size in millimeters, or 0.0 if unset.
Contains settings regarding how masks are calculated and handled during a map render.
Represents a 2D point.
Definition qgspointxy.h:60
A rectangle specified with double values.
Q_DECL_DEPRECATED void setForceVectorOutput(bool force)
Sets whether rendering operations should use vector operations instead of any faster raster shortcuts...
void setMapExtent(const QgsRectangle &extent)
Sets the original extent of the map being rendered.
void setTextureOrigin(const QPointF &origin)
Sets the texture origin, which should be used as a brush transform when rendering using QBrush object...
bool symbolLayerHasClipGeometries(const QString &symbolLayerId) const
Returns true if the symbol layer with matching ID has any associated clip geometries.
void setRenderingStopped(bool stopped)
Sets whether the rendering operation has been stopped and any ongoing rendering should be canceled im...
void setCoordinateTransform(const QgsCoordinateTransform &t)
Sets the current coordinate transform for the context.
double convertToMapUnits(double size, Qgis::RenderUnit unit, const QgsMapUnitScale &scale=QgsMapUnitScale()) const
Converts a size from the specified units to map units.
void setShowSelection(bool showSelection)
Sets whether vector selections should be shown in the rendered map.
void setDrawEditingInformation(bool b)
Sets whether edit markers should be drawn during the render operation.
Q_DECL_DEPRECATED bool useAdvancedEffects() const
Returns true if advanced effects such as blend modes such be used.
void setScaleFactor(double factor)
Sets the scaling factor for the render to convert painter units to physical sizes.
void setImageFormat(QImage::Format format)
Sets QImage format which should be used for QImages created during rendering.
double convertFromPainterUnits(double size, Qgis::RenderUnit unit) const
Converts a size from painter units (pixels) to the specified render unit.
void setSegmentationToleranceType(QgsAbstractGeometry::SegmentationToleranceType type)
Sets segmentation tolerance type (maximum angle or maximum difference between curve and approximation...
QSet< QString > disabledSymbolLayersV2() const
When rendering a map layer in a second pass (for selective masking), some symbol layers may be disabl...
void setDevicePixelRatio(float ratio)
Sets the device pixel ratio.
Q_DECL_DEPRECATED void setUseAdvancedEffects(bool enabled)
Used to enable or disable advanced effects such as blend modes.
void setCurrentFrame(long long frame)
Sets the current frame of the map, for maps which are part of an animation.
double convertToPainterUnits(double size, Qgis::RenderUnit unit, const QgsMapUnitScale &scale=QgsMapUnitScale(), Qgis::RenderSubcomponentProperty property=Qgis::RenderSubcomponentProperty::Generic) const
Converts a size from the specified units to painter units (pixels).
QPainter * painter()
Returns the destination QPainter for the render operation.
void setMaskSettings(const QgsMaskRenderSettings &settings)
Sets the mask render settings, which control how masks are drawn and behave during render operations.
void setPainterFlagsUsingContext(QPainter *painter=nullptr) const
Sets relevant flags on a destination painter, using the flags and settings currently defined for the ...
void setTextRenderFormat(Qgis::TextRenderFormat format)
Sets the text render format, which dictates how text is rendered (e.g.
void setVectorSimplifyMethod(const QgsVectorSimplifyMethod &simplifyMethod)
Sets the simplification setting to use when rendering vector layers.
double convertFromMapUnits(double sizeInMapUnits, Qgis::RenderUnit outputUnit) const
Converts a size from map units to the specified units.
QgsCoordinateTransformContext transformContext() const
Returns the context's coordinate transform context, which stores various information regarding which ...
QSize outputSize() const
Returns the size of the resulting rendered image, in pixels.
QgsGeometry featureClipGeometry() const
Returns the geometry to use to clip features at render time.
QgsElevationMap * elevationMap() const
Returns the destination elevation map for the render operation.
const QgsRectangle & extent() const
When rendering a map layer, calling this method returns the "clipping" extent for the layer (in the l...
bool testFlag(Qgis::RenderContextFlag flag) const
Check whether a particular flag is enabled.
Q_DECL_DEPRECATED bool forceVectorOutput() const
Returns true if rendering operations should use vector operations instead of any faster raster shortc...
Q_DECL_DEPRECATED void setDisabledSymbolLayers(const QSet< const QgsSymbolLayer * > &symbolLayers)
When rendering a map layer in a second pass (for selective masking), some symbol layers may be disabl...
long long currentFrame() const
Returns the current frame number of the map (in frames per second), for maps which are part of an ani...
void setDpiTarget(double dpi)
Sets the targeted dpi for rendering.
~QgsRenderContext() override
void setPathResolver(const QgsPathResolver &resolver)
Sets the path resolver for conversion between relative and absolute paths during rendering operations...
float devicePixelRatio() const
Returns the device pixel ratio.
void setFeedback(QgsFeedback *feedback)
Attach a feedback object that can be queried regularly during rendering to check if rendering should ...
Q_DECL_DEPRECATED void addSymbolLayerClipPath(const QString &symbolLayerId, QPainterPath path)
Add a clip path to be applied to the symbolLayer before rendering.
void setFeatureClipGeometry(const QgsGeometry &geometry)
Sets a geometry to use to clip features at render time.
void setDisabledSymbolLayersV2(const QSet< QString > &symbolLayers)
When rendering a map layer in a second pass (for selective masking), some symbol layers may be disabl...
const QgsFeatureFilterProvider * featureFilterProvider() const
Gets the filter feature provider used for additional filtering of rendered features.
void setRasterizedRenderingPolicy(Qgis::RasterizedRenderingPolicy policy)
Sets the policy controlling when rasterisation of content during renders is permitted.
QList< QgsRenderedFeatureHandlerInterface * > renderedFeatureHandlers() const
Returns the list of rendered feature handlers to use while rendering map layers.
void setFlag(Qgis::RenderContextFlag flag, bool on=true)
Enable or disable a particular flag (other flags are not affected).
double frameRate() const
Returns the frame rate of the map, for maps which are part of an animation.
bool showSelection() const
Returns true if vector selections should be shown in the rendered map.
QList< QgsMapClippingRegion > clippingRegions() const
Returns the list of clipping regions to apply during the render.
void setFrameRate(double rate)
Sets the frame rate of the map (in frames per second), for maps which are part of an animation.
const QgsMapToPixel & mapToPixel() const
Returns the context's map to pixel transform, which transforms between map coordinates and device coo...
void setTransformContext(const QgsCoordinateTransformContext &context)
Sets the context's coordinate transform context, which stores various information regarding which dat...
void setFlags(Qgis::RenderContextFlags flags)
Set combination of flags that will be used for rendering.
void setExtent(const QgsRectangle &extent)
When rendering a map layer, calling this method sets the "clipping" extent for the layer (in the laye...
void setMapToPixel(const QgsMapToPixel &mtp)
Sets the context's map to pixel transform, which transforms between map coordinates and device coordi...
Q_DECL_DEPRECATED QSet< const QgsSymbolLayer * > disabledSymbolLayers() const
When rendering a map layer in a second pass (for selective masking), some symbol layers may be disabl...
void setOutputSize(QSize size)
Sets the size of the resulting rendered image, in pixels.
void setCustomProperty(const QString &property, const QVariant &value)
Sets a custom rendering property.
QgsFeedback * feedback() const
Returns the feedback object that can be queried regularly during rendering to check if rendering shou...
QPointF textureOrigin() const
Returns the texture origin, which should be used as a brush transform when rendering using QBrush obj...
Qgis::RasterizedRenderingPolicy rasterizedRenderingPolicy() const
Returns the policy controlling when rasterisation of content during renders is permitted.
void setPainter(QPainter *p)
Sets the destination QPainter for the render operation.
QgsDoubleRange zRange() const
Returns the range of z-values which should be rendered.
bool isSymbolLayerEnabled(const QgsSymbolLayer *layer) const
When rendering a map layer in a second pass (for selective masking), some symbol layers may be disabl...
QSize deviceOutputSize() const
Returns the device output size of the render.
QVector< QgsGeometry > symbolLayerClipGeometries(const QString &symbolLayerId) const
Returns clipping geometries to be applied to the symbolLayer before rendering.
static QgsRenderContext fromMapSettings(const QgsMapSettings &mapSettings)
create initialized QgsRenderContext instance from given QgsMapSettings
bool drawEditingInformation() const
Returns true if edit markers should be drawn during the render operation.
static QgsRenderContext fromQPainter(QPainter *painter)
Creates a default render context given a pixel based QPainter destination.
void setExpressionContext(const QgsExpressionContext &context)
Sets the expression context.
void setUseRenderingOptimization(bool enabled)
Sets whether the rendering optimization (geometry simplification) should be executed.
void setRendererScale(double scale)
Sets the renderer map scale.
void setZRange(const QgsDoubleRange &range)
Sets the range of z-values which should be rendered.
double convertMetersToMapUnits(double meters) const
Convert meter distances to active MapUnit values for QgsUnitTypes::RenderMetersInMapUnits.
void addSymbolLayerClipGeometry(const QString &symbolLayerId, const QgsGeometry &geometry)
Add a clip geometry to be applied to the symbolLayer before rendering.
Qgis::RenderContextFlags flags() const
Returns combination of flags used for rendering.
Q_DECL_DEPRECATED QList< QPainterPath > symbolLayerClipPaths(const QString &symbolLayerId) const
Returns clip paths to be applied to the symbolLayer before rendering.
const QgsAbstractGeometry * geometry() const
Returns pointer to the unsegmentized geometry.
void setElevationMap(QgsElevationMap *map)
Sets the destination elevation map for the render operation.
QgsRenderContext & operator=(const QgsRenderContext &rh)
bool useRenderingOptimization() const
Returns true if the rendering optimization (geometry simplification) can be executed.
void setSelectionColor(const QColor &color)
Sets the color to use when rendering selected features.
void setSegmentationTolerance(double tolerance)
Sets the segmentation tolerance applied when rendering curved geometries.
void setFeatureFilterProvider(const QgsFeatureFilterProvider *ffp)
Set a filter feature provider used for additional filtering of rendered features.
Abstract base class for symbol layers.
QString id() const
Returns symbol layer identifier This id is unique in the whole project.
const QgsDateTimeRange & temporalRange() const
Returns the datetime range for the object.
QgsTemporalRangeObject(bool enabled=false)
Constructor QgsTemporalRangeObject.
bool isTemporal() const
Returns true if the object's temporal range is enabled, and the object will be filtered when renderin...
void setIsTemporal(bool enabled)
Sets whether the temporal range is enabled (i.e.
void setTemporalRange(const QgsDateTimeRange &range)
Sets the temporal range for the object.
static Q_INVOKABLE double fromUnitToUnitFactor(Qgis::DistanceUnit fromUnit, Qgis::DistanceUnit toUnit)
Returns the conversion factor between the specified distance units.
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference).
Definition qgis.h:6607
#define QgsDebugMsgLevel(str, level)
Definition qgslogger.h:61
#define QgsDebugError(str)
Definition qgslogger.h:57
#define INCH_TO_MM
#define POINTS_TO_MM