31 , mLayerName( layer->name() )
32 , mLayerOpacity( layer->opacity() )
33 , mLayerBlendMode( layer->blendMode() )
37 if ( !context.customProperties().value( QStringLiteral(
"visible_layer_ids" ) ).toList().contains( linkedLayer->id() ) )
39 mReadyToCompose = true;
49 const QStringList itemsList = layer->queryIndex( context.extent() );
50 QSet< QString > items( itemsList.begin(), itemsList.end() );
57 items.unite( layer->mNonIndexedItems );
59 mItems.reserve( items.size() );
60 std::transform( items.begin(), items.end(), std::back_inserter( mItems ),
61 [layer](
const QString &
id ) ->std::pair< QString, std::unique_ptr< QgsAnnotationItem > >
63 return std::make_pair( id, std::unique_ptr< QgsAnnotationItem >( layer->item( id )->clone() ) );
66 std::sort( mItems.begin(), mItems.end(), [](
67 const std::pair< QString, std::unique_ptr< QgsAnnotationItem > > &a,
68 const std::pair< QString, std::unique_ptr< QgsAnnotationItem > > &b )
69 { return a.second->zIndex() < b.second->zIndex(); } );
71 if ( layer->paintEffect() && layer->paintEffect()->enabled() )
73 mPaintEffect.reset( layer->paintEffect()->clone() );
81 return mFeedback.get();
92 mPaintEffect->begin( context );
95 bool canceled =
false;
96 for (
const std::pair< QString, std::unique_ptr< QgsAnnotationItem > > &item : std::as_const( mItems ) )
98 if ( mFeedback->isCanceled() )
104 if ( !item.second->enabled() )
107 std::optional< QgsScopedRenderContextReferenceScaleOverride > referenceScaleOverride;
113 const QgsRectangle bounds = item.second->boundingBox( context );
116 item.second->render( context, mFeedback.get() );
117 auto details = std::make_unique< QgsRenderedAnnotationItemDetails >(
mLayerID, item.first );
118 details->setBoundingBox( bounds );
125 mPaintEffect->end( context );
146 if ( mLayerBlendMode != QPainter::CompositionMode_SourceOver )
@ Default
Allow raster-based rendering in situations where it is required for correct rendering or where it wil...
@ PreferVector
Prefer vector-based rendering, when the result will still be visually near-identical to a raster-base...
@ ForceVector
Always force vector-based rendering, even when the result will be visually different to a raster-base...
@ SupportsReferenceScale
Item supports reference scale based rendering.
bool forceRasterRender() const override
Returns true if the renderer must be rendered to a raster paint device (e.g.
~QgsAnnotationLayerRenderer() override
bool render() override
Do the rendering (based on data stored in the class).
QgsFeedback * feedback() const override
Access to feedback object of the layer renderer (may be nullptr).
QgsAnnotationLayerRenderer(QgsAnnotationLayer *layer, QgsRenderContext &context)
Constructor for a QgsAnnotationLayerRenderer, for the specified layer.
Represents a map layer containing a set of georeferenced annotations, e.g.
QgsMapLayer * linkedVisibilityLayer()
Returns a linked layer, where the items in this annotation layer will only be visible when the linked...
Base class for feedback objects to be used for cancellation of something running in a worker thread.
void appendRenderedItemDetails(QgsRenderedItemDetails *details)
Appends the details of a rendered item to the renderer.
QgsRenderContext * renderContext()
Returns the render context associated with the renderer.
QgsMapLayerRenderer(const QString &layerID, QgsRenderContext *context=nullptr)
Constructor for QgsMapLayerRenderer, with the associated layerID and render context.
Base class for all map layer types.
A rectangle specified with double values.
bool intersects(const QgsRectangle &rect) const
Returns true when rectangle intersects with other rectangle.
Contains information about the context of a rendering operation.
double symbologyReferenceScale() const
Returns the symbology reference scale.
const QgsRectangle & extent() const
When rendering a map layer, calling this method returns the "clipping" extent for the layer (in the l...
Scoped object for temporary override of the symbologyReferenceScale property of a QgsRenderContext.
Scoped object for setting the current thread name.
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference).