28#include "moc_qgsmaprendererstagedrenderjob.cpp"
44void QgsMapRendererStagedRenderJob::startPrivate()
49 QgsDebugMsgLevel( QStringLiteral(
"Preparing list of layer jobs for rendering" ), 5 );
50 QElapsedTimer prepareTime;
53 mLabelingEngineV2.reset();
58 mLabelingEngineV2 = std::make_unique<QgsStagedRenderLabelingEngine>( );
60 mLabelingEngineV2 = std::make_unique<QgsDefaultLabelingEngine>( );
61 mLabelingEngineV2->setMapSettings(
mSettings );
64 mLayerJobs =
prepareJobs(
nullptr, mLabelingEngineV2.get(),
true );
67 mJobIt = mLayerJobs.begin();
94 if ( mLabelingEngineV2 )
95 return mLabelingEngineV2->takeResults();
107 if ( mJobIt != mLayerJobs.end() )
109 LayerRenderJob &job = *mJobIt;
111 job.renderer->renderContext()->setPainter( painter );
117 painter->setCompositionMode( job.blendMode );
120 if ( job.previewRenderImage && !job.previewRenderImageInitialized )
122 job.previewRenderImage->fill( 0 );
123 job.previewRenderImageInitialized =
true;
129 job.imageInitialized =
true;
132 job.completed = job.renderer->render();
137 painter->setOpacity( job.opacity );
138 painter->drawImage( 0, 0, *job.img );
139 painter->setOpacity( 1.0 );
141 job.context()->setPainter(
nullptr );
147 if ( !mLabelingEngineV2 )
152 if ( !mPreparedStagedLabelJob || mLabelLayerIt == mLabelingLayers.end() )
155 mLabelJob.context.setPainter( painter );
158 painter->setCompositionMode( QPainter::CompositionMode_SourceOver );
163 mLabelJob.context.setPainter(
nullptr );
167 mLabelJob.context.setPainter( painter );
168 drawLabeling( mLabelJob.context, mLabelingEngineV2.get(), painter );
169 mLabelJob.complete =
true;
171 mLabelJob.context.setPainter(
nullptr );
182 if ( mJobIt != mLayerJobs.end() )
185 if ( mJobIt != mLayerJobs.end() )
189 if ( mLabelingEngineV2 )
193 if ( !mPreparedStagedLabelJob )
195 mLabelingEngineV2->run( mLabelJob.context );
196 mPreparedStagedLabelJob =
true;
197 mLabelingLayers = mLabelingEngineV2->participatingLayerIds();
198 mLabelLayerIt = mLabelingLayers.begin();
199 if ( mLabelLayerIt == mLabelingLayers.end() )
209 if ( mLabelLayerIt != mLabelingLayers.end() )
212 if ( mLabelLayerIt != mLabelingLayers.end() )
222 mExportedLabels =
true;
224 else if ( !mExportedLabels )
241 if ( mJobIt != mLayerJobs.end() )
243 const LayerRenderJob &job = *mJobIt;
248 if ( mLabelLayerIt != mLabelingLayers.end() )
249 return *mLabelLayerIt;
256 if ( mJobIt != mLayerJobs.end() )
258 const LayerRenderJob &job = *mJobIt;
266 if ( mJobIt != mLayerJobs.end() )
268 const LayerRenderJob &job = *mJobIt;
269 return job.blendMode;
271 return QPainter::CompositionMode_SourceOver;
276 if ( mJobIt != mLayerJobs.end() )
280 if ( !mPreparedStagedLabelJob )
282 if ( mLabelLayerIt != mLabelingLayers.end() )
285 else if ( mNextIsLabel && !mExportedLabels )
@ ForceVector
Always force vector-based rendering, even when the result will be visually different to a raster-base...
@ DrawLabeling
Enable drawing of labels on top of the map.
Stores computed placement from labeling engine.
void preparePainter(QPainter *painter, const QColor &backgroundColor=Qt::transparent)
Prepares the given painter ready for a map render.
QgsMapRendererAbstractCustomPainterJob(const QgsMapSettings &settings)
Constructor for QgsMapRendererAbstractCustomPainterJob, using the given map settings.
QList< QPointer< QgsMapLayer > > participatingLabelLayers(QgsLabelingEngine *engine)
Returns a list of the layers participating in the map labeling.
static Q_DECL_DEPRECATED void drawLabeling(const QgsMapSettings &settings, QgsRenderContext &renderContext, QgsLabelingEngine *labelingEngine2, QPainter *painter)
void layerRendered(const QString &layerId)
Emitted when a layer has completed rendering.
std::vector< LayerRenderJob > prepareJobs(QPainter *painter, QgsLabelingEngine *labelingEngine2, bool deferredPainterSet=false)
Creates a list of layer rendering jobs and prepares them for later render.
void cleanupJobs(std::vector< LayerRenderJob > &jobs)
QElapsedTimer mRenderingStart
void layerRenderingStarted(const QString &layerId)
Emitted just before rendering starts for a particular layer.
LabelRenderJob prepareLabelingJob(QPainter *painter, QgsLabelingEngine *labelingEngine2, bool canUseLabelCache=true)
Prepares a labeling job.
void cleanupLabelJob(LabelRenderJob &job)
Handles clean up tasks for a label job, including deletion of images and storing cached label results...
double currentLayerOpacity() const
Returns the opacity for the current layer about to be rendered in the next render operation.
void cancel() override
Stop the rendering job - does not return until the job has terminated.
~QgsMapRendererStagedRenderJob() override
@ RenderLabelsByMapLayer
Labels should be rendered in individual stages by map layer. This allows separation of labels belongi...
bool usedCachedLabels() const override
Returns true if the render job was able to use a cached labeling solution.
RenderStage currentStage() const
Returns the current stage which will be rendered in the next render operation.
void waitForFinished() override
Block until the job has finished.
QPainter::CompositionMode currentLayerCompositionMode() const
Returns the composition mode for the current layer about to be rendered in the next render operation.
QString currentLayerId() const
Returns the ID of the current layer about to be rendered in the next render operation.
QgsLabelingResults * takeLabelingResults() override
Gets pointer to internal labeling engine (in order to get access to the results).
bool isActive() const override
Tell whether the rendering job is currently running in background.
QgsMapRendererStagedRenderJob(const QgsMapSettings &settings, Flags flags=Flags())
Constructor for QgsMapRendererStagedRenderJob, using the given map settings.
bool isFinished() const
Returns true if the job is finished, and nothing remains to render.
RenderStage
Represents the stages of a rendering job.
@ Finished
Rendering is finished.
@ Symbology
Rendering layer symbology.
@ Labels
Rendering labels.
bool nextPart()
Iterates to the next part to render.
bool renderCurrentPart(QPainter *painter)
Renders the current part of the map to the specified painter.
void cancelWithoutBlocking() override
Triggers cancellation of the rendering job without blocking.
Contains configuration for rendering maps.
bool testFlag(Qgis::MapSettingsFlag flag) const
Check whether a particular flag is enabled.
A QgsLabelingEngine implementation, which only calculates the labeling solution during its run() meth...
void finalize()
Finalizes and cleans up the engine following the rendering of labels for the last layer to be labeled...
void renderLabelsForLayer(QgsRenderContext &context, const QString &layerId)
Renders all the labels which belong only to the layer with matching layerId to the specified render c...
#define QgsDebugMsgLevel(str, level)