QGIS API Documentation 3.99.0-Master (b927df884fe)
qgstiledscenelayer.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgstiledscenelayer.cpp
3 --------------------
4 begin : June 2023
5 copyright : (C) 2023 by Nyall Dawson
6 email : nyall dot dawson at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
18#include "qgstiledscenelayer.h"
19#include "moc_qgstiledscenelayer.cpp"
20#include "qgsthreadingutils.h"
21#include "qgsmaplayerfactory.h"
22#include "qgspainting.h"
23#include "qgsproviderregistry.h"
26#include "qgsxmlutils.h"
27#include "qgsruntimeprofiler.h"
28#include "qgsapplication.h"
32
34 const QString &baseName,
35 const QString &provider,
37 : QgsMapLayer( Qgis::LayerType::TiledScene, baseName, uri )
38 , mElevationProperties( new QgsTiledSceneLayerElevationProperties( this ) )
39 , mLayerOptions( options )
40{
41 if ( !uri.isEmpty() && !provider.isEmpty() )
42 {
43 const QgsDataProvider::ProviderOptions providerOptions { options.transformContext };
44 Qgis::DataProviderReadFlags providerFlags;
45 if ( options.loadDefaultStyle )
46 {
48 }
49 setDataSource( uri, baseName, provider, providerOptions, providerFlags );
50 }
51
52 // TODO: temporary, for removal
53 if ( provider == QLatin1String( "test_tiled_scene_provider" ) )
54 mValid = true;
55
56#if 0
57 setLegend( QgsMapLayerLegend::defaultTiledSceneLegend( this ) );
58#endif
59}
60
62
64{
66
67 QgsTiledSceneLayer *layer = new QgsTiledSceneLayer( source(), name(), mProviderKey, mLayerOptions );
68 QgsMapLayer::clone( layer );
69
70 if ( mRenderer )
71 layer->setRenderer( mRenderer->clone() );
72
73 layer->mElevationProperties = mElevationProperties->clone();
74 layer->mElevationProperties->setParent( layer );
75
76 layer->mLayerOptions = mLayerOptions;
77
78 return layer;
79}
80
82{
84
85 if ( !mDataProvider )
86 return QgsRectangle();
87
88 return mDataProvider->extent();
89}
90
91QString QgsTiledSceneLayer::loadDefaultMetadata( bool &resultFlag )
92{
94
95 resultFlag = false;
96 if ( !mDataProvider || !mDataProvider->isValid() )
97 return QString();
98
99 if ( qgis::down_cast< QgsTiledSceneDataProvider * >( mDataProvider.get() )->capabilities() & Qgis::TiledSceneProviderCapability::ReadLayerMetadata )
100 {
101 setMetadata( mDataProvider->layerMetadata() );
102 }
103 else
104 {
106 }
107 resultFlag = true;
108 return QString();
109}
110
117
119{
121
123 if ( mDataProvider && ( mDataProvider->flags() & Qgis::DataProviderFlag::IsBasemapSource ) )
124 {
126 }
127 if ( mDataProvider && ( mDataProvider->flags() & Qgis::DataProviderFlag::Is3DBasemapSource ) )
128 {
130 }
131 return res;
132}
133
140
147
149{
151
152 return mRenderer.get();
153}
154
156{
158
159 if ( renderer == mRenderer.get() )
160 return;
161
162 mRenderer.reset( renderer );
163 emit rendererChanged();
165}
166
173
175{
177
178 return mDataProvider.get();
179}
180
181bool QgsTiledSceneLayer::readXml( const QDomNode &layerNode, QgsReadWriteContext &context )
182{
184
185 // create provider
186 const QDomNode pkeyNode = layerNode.namedItem( QStringLiteral( "provider" ) );
187 mProviderKey = pkeyNode.toElement().text();
188
190 {
191 const QgsDataProvider::ProviderOptions providerOptions { context.transformContext() };
193 // read extent
195 {
196 const QDomNode extentNode = layerNode.namedItem( QStringLiteral( "extent" ) );
197 if ( !extentNode.isNull() )
198 {
199 // get the extent
200 const QgsRectangle mbr = QgsXmlUtils::readRectangle( extentNode.toElement() );
201
202 // store the extent
203 setExtent( mbr );
204 }
205 }
206
208 }
209
210 QString errorMsg;
211 if ( !readSymbology( layerNode, errorMsg, context ) )
212 return false;
213
214 readStyleManager( layerNode );
215
216 return isValid();
217}
218
219bool QgsTiledSceneLayer::writeXml( QDomNode &layerNode, QDomDocument &doc, const QgsReadWriteContext &context ) const
220{
222
223 QDomElement mapLayerNode = layerNode.toElement();
224 mapLayerNode.setAttribute( QStringLiteral( "type" ), QgsMapLayerFactory::typeToString( Qgis::LayerType::TiledScene ) );
225
226 {
227 QDomElement provider = doc.createElement( QStringLiteral( "provider" ) );
228 const QDomText providerText = doc.createTextNode( providerType() );
229 provider.appendChild( providerText );
230 layerNode.appendChild( provider );
231 }
232
233 writeStyleManager( layerNode, doc );
234
235 QString errorMsg;
236 return writeSymbology( layerNode, doc, errorMsg, context );
237}
238
239bool QgsTiledSceneLayer::readSymbology( const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories )
240{
242
243 const QDomElement elem = node.toElement();
244
245 readCommonStyle( elem, context, categories );
246
247 readStyle( node, errorMessage, context, categories );
248
249 if ( categories.testFlag( CustomProperties ) )
250 readCustomProperties( node, QStringLiteral( "variable" ) );
251
252 return true;
253}
254
255bool QgsTiledSceneLayer::readStyle( const QDomNode &node, QString &, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories )
256{
258
259 bool result = true;
260
261 if ( categories.testFlag( Symbology ) )
262 {
263 // get and set the blend mode if it exists
264 const QDomNode blendModeNode = node.namedItem( QStringLiteral( "blendMode" ) );
265 if ( !blendModeNode.isNull() )
266 {
267 const QDomElement e = blendModeNode.toElement();
268 setBlendMode( QgsPainting::getCompositionMode( static_cast< Qgis::BlendMode >( e.text().toInt() ) ) );
269 }
270
271 QDomElement rendererElement = node.firstChildElement( QStringLiteral( "renderer" ) );
272 if ( !rendererElement.isNull() )
273 {
274 std::unique_ptr< QgsTiledSceneRenderer > r( QgsTiledSceneRenderer::load( rendererElement, context ) );
275 if ( r )
276 {
277 setRenderer( r.release() );
278 }
279 else
280 {
281 result = false;
282 }
283 }
284 // make sure layer has a renderer - if none exists, fallback to a default renderer
285 if ( !mRenderer )
286 {
288 }
289 }
290
291 // get and set the layer transparency and scale visibility if they exists
292 if ( categories.testFlag( Rendering ) )
293 {
294 const QDomNode layerOpacityNode = node.namedItem( QStringLiteral( "layerOpacity" ) );
295 if ( !layerOpacityNode.isNull() )
296 {
297 const QDomElement e = layerOpacityNode.toElement();
298 setOpacity( e.text().toDouble() );
299 }
300
301 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( QStringLiteral( "hasScaleBasedVisibilityFlag" ) ).nodeValue() == '1' };
302 setScaleBasedVisibility( hasScaleBasedVisibiliy );
303 bool ok;
304 const double maxScale { node.attributes().namedItem( QStringLiteral( "maxScale" ) ).nodeValue().toDouble( &ok ) };
305 if ( ok )
306 {
307 setMaximumScale( maxScale );
308 }
309 const double minScale { node.attributes().namedItem( QStringLiteral( "minScale" ) ).nodeValue().toDouble( &ok ) };
310 if ( ok )
311 {
312 setMinimumScale( minScale );
313 }
314 }
315 return result;
316}
317
318bool QgsTiledSceneLayer::writeSymbology( QDomNode &node, QDomDocument &doc, QString &errorMessage,
319 const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories ) const
320{
322
323 Q_UNUSED( errorMessage )
324
325 QDomElement elem = node.toElement();
326 writeCommonStyle( elem, doc, context, categories );
327
328 ( void )writeStyle( node, doc, errorMessage, context, categories );
329
330 return true;
331}
332
333bool QgsTiledSceneLayer::writeStyle( QDomNode &node, QDomDocument &doc, QString &, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories ) const
334{
336
337 QDomElement mapLayerNode = node.toElement();
338
339 //save custom properties
340 if ( categories.testFlag( CustomProperties ) )
341 {
342 writeCustomProperties( node, doc );
343 }
344
345 if ( categories.testFlag( Symbology ) )
346 {
347 // add the blend mode field
348 QDomElement blendModeElem = doc.createElement( QStringLiteral( "blendMode" ) );
349 const QDomText blendModeText = doc.createTextNode( QString::number( static_cast< int >( QgsPainting::getBlendModeEnum( blendMode() ) ) ) );
350 blendModeElem.appendChild( blendModeText );
351 node.appendChild( blendModeElem );
352
353 if ( mRenderer )
354 {
355 const QDomElement rendererElement = mRenderer->save( doc, context );
356 node.appendChild( rendererElement );
357 }
358 }
359
360 // add the layer opacity and scale visibility
361 if ( categories.testFlag( Rendering ) )
362 {
363 QDomElement layerOpacityElem = doc.createElement( QStringLiteral( "layerOpacity" ) );
364 const QDomText layerOpacityText = doc.createTextNode( QString::number( opacity() ) );
365 layerOpacityElem.appendChild( layerOpacityText );
366 node.appendChild( layerOpacityElem );
367
368 mapLayerNode.setAttribute( QStringLiteral( "hasScaleBasedVisibilityFlag" ), hasScaleBasedVisibility() ? 1 : 0 );
369 mapLayerNode.setAttribute( QStringLiteral( "maxScale" ), maximumScale() );
370 mapLayerNode.setAttribute( QStringLiteral( "minScale" ), minimumScale() );
371 }
372 return true;
373}
374
376{
378
379 if ( mDataProvider )
380 mDataProvider->setTransformContext( transformContext );
382}
383
384void QgsTiledSceneLayer::setDataSourcePrivate( const QString &dataSource, const QString &baseName, const QString &provider,
386{
388
389 setName( baseName );
390 mProviderKey = provider;
391 mDataSource = dataSource;
392
393 if ( mPreloadedProvider )
394 {
395 mDataProvider.reset( qobject_cast< QgsTiledSceneDataProvider * >( mPreloadedProvider.release() ) );
396 }
397 else
398 {
399 std::unique_ptr< QgsScopedRuntimeProfile > profile;
400 if ( QgsApplication::profiler()->groupIsActive( QStringLiteral( "projectload" ) ) )
401 profile = std::make_unique< QgsScopedRuntimeProfile >( tr( "Create %1 provider" ).arg( provider ), QStringLiteral( "projectload" ) );
402 mDataProvider.reset( qobject_cast<QgsTiledSceneDataProvider *>( QgsProviderRegistry::instance()->createProvider( provider, dataSource, options, flags ) ) );
403 }
404
405 if ( !mDataProvider )
406 {
407 QgsDebugError( QStringLiteral( "Unable to get tiled scene data provider" ) );
408 setValid( false );
409 return;
410 }
411
412 mDataProvider->setParent( this );
413 QgsDebugMsgLevel( QStringLiteral( "Instantiated the tiled scene data provider plugin" ), 2 );
414
415 setValid( mDataProvider->isValid() );
416 if ( !isValid() )
417 {
418 QgsDebugError( QStringLiteral( "Invalid tiled scene provider plugin %1" ).arg( QString( mDataSource.toUtf8() ) ) );
419 setError( mDataProvider->error() );
420 return;
421 }
422
423 // Load initial extent, crs and renderer
424 setCrs( mDataProvider->crs() );
426 {
427 setExtent( mDataProvider->extent() );
428 }
429
430 bool loadDefaultStyleFlag = false;
432 {
433 loadDefaultStyleFlag = true;
434 }
435
436 if ( !mRenderer || loadDefaultStyleFlag )
437 {
438 std::unique_ptr< QgsScopedRuntimeProfile > profile;
439 if ( QgsApplication::profiler()->groupIsActive( QStringLiteral( "projectload" ) ) )
440 profile = std::make_unique< QgsScopedRuntimeProfile >( tr( "Load layer style" ), QStringLiteral( "projectload" ) );
441
442 bool defaultLoadedFlag = false;
443
444 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
445 {
446 loadDefaultStyle( defaultLoadedFlag );
447 }
448
449 if ( !defaultLoadedFlag )
450 {
451 // all else failed, create default renderer
453 }
454 }
455}
456
457QString QgsTiledSceneLayer::encodedSource( const QString &source, const QgsReadWriteContext &context ) const
458{
460
462}
463
464QString QgsTiledSceneLayer::decodedSource( const QString &source, const QString &dataProvider, const QgsReadWriteContext &context ) const
465{
467
469}
470
471QString QgsTiledSceneLayer::loadDefaultStyle( bool &resultFlag )
472{
474
475 return QgsMapLayer::loadDefaultStyle( resultFlag );
476}
477
479{
481
482 const QgsLayerMetadataFormatter htmlFormatter( metadata() );
483 QString myMetadata = QStringLiteral( "<html>\n<body>\n" );
484
485 myMetadata += generalHtmlMetadata();
486
487 // Begin Provider section
488 myMetadata += QStringLiteral( "<h1>" ) + tr( "Information from provider" ) + QStringLiteral( "</h1>\n<hr>\n" );
489 myMetadata += QLatin1String( "<table class=\"list-view\">\n" );
490
491 if ( mDataProvider )
492 myMetadata += mDataProvider->htmlMetadata();
493
494 // Extent
495 myMetadata += QStringLiteral( "<tr><td class=\"highlight\">" ) + tr( "Extent" ) + QStringLiteral( "</td><td>" ) + extent().toString() + QStringLiteral( "</td></tr>\n" );
496
497 myMetadata += QLatin1String( "</table>\n<br><br>" );
498
499 // CRS
500 myMetadata += crsHtmlMetadata();
501
502 // identification section
503 myMetadata += QStringLiteral( "<h1>" ) + tr( "Identification" ) + QStringLiteral( "</h1>\n<hr>\n" );
504 myMetadata += htmlFormatter.identificationSectionHtml( );
505 myMetadata += QLatin1String( "<br><br>\n" );
506
507 // extent section
508 myMetadata += QStringLiteral( "<h1>" ) + tr( "Extent" ) + QStringLiteral( "</h1>\n<hr>\n" );
509 myMetadata += htmlFormatter.extentSectionHtml( isSpatial() );
510 myMetadata += QLatin1String( "<br><br>\n" );
511
512 // Start the Access section
513 myMetadata += QStringLiteral( "<h1>" ) + tr( "Access" ) + QStringLiteral( "</h1>\n<hr>\n" );
514 myMetadata += htmlFormatter.accessSectionHtml( );
515 myMetadata += QLatin1String( "<br><br>\n" );
516
517 // Start the contacts section
518 myMetadata += QStringLiteral( "<h1>" ) + tr( "Contacts" ) + QStringLiteral( "</h1>\n<hr>\n" );
519 myMetadata += htmlFormatter.contactsSectionHtml( );
520 myMetadata += QLatin1String( "<br><br>\n" );
521
522 // Start the links section
523 myMetadata += QStringLiteral( "<h1>" ) + tr( "Links" ) + QStringLiteral( "</h1>\n<hr>\n" );
524 myMetadata += htmlFormatter.linksSectionHtml( );
525 myMetadata += QLatin1String( "<br><br>\n" );
526
527 // Start the history section
528 myMetadata += QStringLiteral( "<h1>" ) + tr( "History" ) + QStringLiteral( "</h1>\n<hr>\n" );
529 myMetadata += htmlFormatter.historySectionHtml( );
530 myMetadata += QLatin1String( "<br><br>\n" );
531
532 myMetadata += customPropertyHtmlMetadata();
533
534 myMetadata += QLatin1String( "\n</body>\n</html>\n" );
535 return myMetadata;
536}
537
538bool QgsTiledSceneLayer::isReadOnly() const
539{
540 return true;
541}
Provides global constants and enumerations for use throughout the application.
Definition qgis.h:54
@ Is3DBasemapLayer
Layer is considered a '3D basemap' layer. This flag is similar to IsBasemapLayer, but reserved for la...
@ IsBasemapLayer
Layer is considered a 'basemap' layer, and certain properties of the layer should be ignored when cal...
@ Is3DBasemapSource
Associated source should be considered a '3D basemap' layer. See Qgis::MapLayerProperty::Is3DBasemapL...
@ IsBasemapSource
Associated source should be considered a 'basemap' layer. See Qgis::MapLayerProperty::IsBasemapLayer.
BlendMode
Blending modes defining the available composition modes that can be used when painting.
Definition qgis.h:4811
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
Definition qgis.h:450
@ ReadLayerMetadata
Provider can read layer metadata from data store. See QgsDataProvider::layerMetadata()
@ TiledScene
Tiled scene layer. Added in QGIS 3.34.
QFlags< MapLayerProperty > MapLayerProperties
Map layer properties.
Definition qgis.h:2235
@ LoadDefaultStyle
Reset the layer's style to the default for the datasource.
@ SkipGetExtent
Skip the extent from provider.
static QgsRuntimeProfiler * profiler()
Returns the application runtime profiler.
Contains information about the context in which a coordinate transform is executed.
Formats layer metadata into HTML.
Base class for storage of map layer elevation properties.
static QString typeToString(Qgis::LayerType type)
Converts a map layer type to a string value.
Base class for utility classes that encapsulate information necessary for rendering of map layers.
Base class for all map layer types.
Definition qgsmaplayer.h:77
QString name
Definition qgsmaplayer.h:81
void readStyleManager(const QDomNode &layerNode)
Read style manager's configuration (if any). To be called by subclasses.
virtual bool isSpatial() const
Returns true if the layer is considered a spatial layer, ie it has some form of geometry associated w...
void setError(const QgsError &error)
Sets error message.
void writeStyleManager(QDomNode &layerNode, QDomDocument &doc) const
Write style manager's configuration (if exists). To be called by subclasses.
QString source() const
Returns the source for the layer.
QString providerType() const
Returns the provider type (provider key) for this layer.
void setBlendMode(QPainter::CompositionMode blendMode)
Set the blending mode used for rendering a layer.
void setMinimumScale(double scale)
Sets the minimum map scale (i.e.
static Qgis::DataProviderReadFlags providerReadFlags(const QDomNode &layerNode, QgsMapLayer::ReadFlags layerReadFlags)
Returns provider read flag deduced from layer read flags layerReadFlags and a dom node layerNode that...
QgsMapLayer::LayerFlags flags() const
Returns the flags for this layer.
void writeCustomProperties(QDomNode &layerNode, QDomDocument &doc) const
Write custom properties to project file.
virtual QString loadDefaultStyle(bool &resultFlag)
Retrieve the default style for this layer if one exists (either as a .qml file on disk or as a record...
void setDataSource(const QString &dataSource, const QString &baseName=QString(), const QString &provider=QString(), bool loadDefaultStyleFlag=false)
Updates the data source of the layer.
QString mLayerName
Name of the layer - used for display.
QString crsHtmlMetadata() const
Returns a HTML fragment containing the layer's CRS metadata, for use in the htmlMetadata() method.
void setMaximumScale(double scale)
Sets the maximum map scale (i.e.
QgsLayerMetadata metadata
Definition qgsmaplayer.h:83
QPainter::CompositionMode blendMode() const
Returns the current blending mode for a layer.
virtual void setOpacity(double opacity)
Sets the opacity for the layer, where opacity is a value between 0 (totally transparent) and 1....
void readCustomProperties(const QDomNode &layerNode, const QString &keyStartsWith=QString())
Read custom properties from project file.
virtual void setMetadata(const QgsLayerMetadata &metadata)
Sets the layer's metadata store.
QFlags< StyleCategory > StyleCategories
QString mProviderKey
Data provider key (name of the data provider)
QgsCoordinateTransformContext transformContext() const
Returns the layer data provider coordinate transform context or a default transform context if the la...
std::unique_ptr< QgsDataProvider > mPreloadedProvider
Optionally used when loading a project, it is released when the layer is effectively created.
void rendererChanged()
Signal emitted when renderer is changed.
void setScaleBasedVisibility(bool enabled)
Sets whether scale based visibility is enabled for the layer.
bool hasScaleBasedVisibility() const
Returns whether scale based visibility is enabled for the layer.
void emitStyleChanged()
Triggers an emission of the styleChanged() signal.
virtual QgsMapLayer * clone() const =0
Returns a new instance equivalent to this one except for the id which is still unique.
void setName(const QString &name)
Set the display name of the layer.
virtual void setExtent(const QgsRectangle &rect)
Sets the extent.
QString mDataSource
Data source description string, varies by layer type.
virtual QString loadDefaultMetadata(bool &resultFlag)
Retrieve the default metadata for this layer if one exists (either as a .qmd file on disk or as a rec...
@ FlagReadExtentFromXml
Read extent from xml and skip get extent from provider.
@ FlagDontResolveLayers
Don't resolve layer paths or create data providers for layers.
void setValid(bool valid)
Sets whether layer is valid or not.
void readCommonStyle(const QDomElement &layerElement, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories)
Read style data common to all layer types.
QgsMapLayer::ReadFlags mReadFlags
Read flags. It's up to the subclass to respect these when restoring state from XML.
double minimumScale() const
Returns the minimum map scale (i.e.
void setLegend(QgsMapLayerLegend *legend)
Assign a legend controller to the map layer.
double opacity
Definition qgsmaplayer.h:89
bool mValid
Indicates if the layer is valid and can be drawn.
@ Symbology
Symbology.
@ Rendering
Rendering: scale visibility, simplify method, opacity.
@ CustomProperties
Custom properties (by plugins for instance)
QString customPropertyHtmlMetadata() const
Returns an HTML fragment containing custom property information, for use in the htmlMetadata() method...
QString generalHtmlMetadata() const
Returns an HTML fragment containing general metadata information, for use in the htmlMetadata() metho...
void writeCommonStyle(QDomElement &layerElement, QDomDocument &document, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) const
Write style data common to all layer types.
double maximumScale() const
Returns the maximum map scale (i.e.
void invalidateWgs84Extent()
Invalidates the WGS84 extent.
void setCrs(const QgsCoordinateReferenceSystem &srs, bool emitSignal=true)
Sets layer's spatial reference system.
static Qgis::BlendMode getBlendModeEnum(QPainter::CompositionMode blendMode)
Returns a Qgis::BlendMode corresponding to a QPainter::CompositionMode.
static QPainter::CompositionMode getCompositionMode(Qgis::BlendMode blendMode)
Returns a QPainter::CompositionMode corresponding to a Qgis::BlendMode.
QString absoluteToRelativeUri(const QString &providerKey, const QString &uri, const QgsReadWriteContext &context) const
Converts absolute path(s) to relative path(s) in the given provider-specific URI.
static QgsProviderRegistry * instance(const QString &pluginPath=QString())
Means of accessing canonical single instance.
QString relativeToAbsoluteUri(const QString &providerKey, const QString &uri, const QgsReadWriteContext &context) const
Converts relative path(s) to absolute path(s) in the given provider-specific URI.
A container for the context for various read/write operations on objects.
QgsCoordinateTransformContext transformContext() const
Returns data provider coordinate transform context.
A rectangle specified with double values.
Q_INVOKABLE QString toString(int precision=16) const
Returns a string representation of form xmin,ymin : xmax,ymax Coordinates will be truncated to the sp...
Contains information about the context of a rendering operation.
Base class for data providers for QgsTiledSceneLayer.
Tiled scene layer specific subclass of QgsMapLayerElevationProperties.
QgsTiledSceneLayerElevationProperties * clone() const override
Creates a clone of the properties.
Implementation of threaded 2D rendering for tiled scene layers.
Represents a map layer supporting display of tiled scene objects.
Qgis::MapLayerProperties properties() const override
Returns the map layer properties of this layer.
QgsTiledSceneLayer * clone() const override
Returns a new instance equivalent to this one except for the id which is still unique.
void setTransformContext(const QgsCoordinateTransformContext &transformContext) override
Sets the coordinate transform context to transformContext.
bool readStyle(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) FINAL
Read the style for the current layer from the DOM node supplied.
QgsTiledSceneLayer(const QString &uri=QString(), const QString &baseName=QString(), const QString &provider=QString(), const QgsTiledSceneLayer::LayerOptions &options=QgsTiledSceneLayer::LayerOptions())
Constructor for QgsTiledSceneLayer.
QString htmlMetadata() const override
Obtain a formatted HTML string containing assorted metadata for this layer.
bool writeStyle(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) const FINAL
Write just the symbology information for the layer into the document.
bool readSymbology(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) override
Read the symbology for the current layer from the DOM node supplied.
QString loadDefaultStyle(bool &resultFlag) FINAL
Retrieve the default style for this layer if one exists (either as a .qml file on disk or as a record...
QgsRectangle extent() const override
Returns the extent of the layer.
QString decodedSource(const QString &source, const QString &dataProvider, const QgsReadWriteContext &context) const override
Called by readLayerXML(), used by derived classes to decode provider's specific data source from proj...
void setRenderer(QgsTiledSceneRenderer *renderer)
Sets the 2D renderer for the tiled scene.
QgsMapLayerElevationProperties * elevationProperties() override
Returns the layer's elevation properties.
QString loadDefaultMetadata(bool &resultFlag) override
Retrieve the default metadata for this layer if one exists (either as a .qmd file on disk or as a rec...
QgsTiledSceneDataProvider * dataProvider() override
Returns the layer's data provider, it may be nullptr.
bool writeSymbology(QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) const override
Write the style for the layer into the document provided.
QString encodedSource(const QString &source, const QgsReadWriteContext &context) const override
Called by writeLayerXML(), used by derived classes to encode provider's specific data source to proje...
~QgsTiledSceneLayer() override
QgsTiledSceneRenderer * renderer()
Returns the 2D renderer for the tiled scene.
bool writeXml(QDomNode &layerNode, QDomDocument &doc, const QgsReadWriteContext &context) const override
Called by writeLayerXML(), used by children to write state specific to them to project files.
bool readXml(const QDomNode &layerNode, QgsReadWriteContext &context) override
Called by readLayerXML(), used by children to read state specific to them from project files.
QgsMapLayerRenderer * createMapRenderer(QgsRenderContext &rendererContext) override
Returns new instance of QgsMapLayerRenderer that will be used for rendering of given context.
static QgsTiledSceneRenderer * defaultRenderer(const QgsTiledSceneLayer *layer)
Returns a new default tiled scene renderer for a specified layer.
Abstract base class for 2d tiled scene renderers.
static QgsTiledSceneRenderer * load(QDomElement &element, const QgsReadWriteContext &context)
Creates a renderer from an XML element.
static QgsRectangle readRectangle(const QDomElement &element)
#define QgsDebugMsgLevel(str, level)
Definition qgslogger.h:41
#define QgsDebugError(str)
Definition qgslogger.h:40
#define QGIS_PROTECT_QOBJECT_THREAD_ACCESS
Setting options for creating vector data providers.
Setting options for loading tiled scene layers.
bool loadDefaultStyle
Set to true if the default layer style should be loaded.
QgsCoordinateTransformContext transformContext
Coordinate transform context.