QGIS API Documentation 4.0.0-Norrköping (1ddcee3d0e4)
Loading...
Searching...
No Matches
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
20#include "qgsapplication.h"
22#include "qgsmaplayerfactory.h"
23#include "qgspainting.h"
24#include "qgsproviderregistry.h"
25#include "qgsruntimeprofiler.h"
26#include "qgsthreadingutils.h"
31#include "qgsxmlutils.h"
32
33#include <QString>
34
35#include "moc_qgstiledscenelayer.cpp"
36
37using namespace Qt::StringLiterals;
38
39QgsTiledSceneLayer::QgsTiledSceneLayer( const QString &uri, const QString &baseName, const QString &provider, const QgsTiledSceneLayer::LayerOptions &options )
40 : QgsMapLayer( Qgis::LayerType::TiledScene, baseName, uri )
41 , mElevationProperties( new QgsTiledSceneLayerElevationProperties( this ) )
42 , mLayerOptions( options )
43{
44 if ( !uri.isEmpty() && !provider.isEmpty() )
45 {
46 const QgsDataProvider::ProviderOptions providerOptions { options.transformContext };
47 Qgis::DataProviderReadFlags providerFlags;
48 if ( options.loadDefaultStyle )
49 {
50 providerFlags |= Qgis::DataProviderReadFlag::LoadDefaultStyle;
51 }
52 setDataSource( uri, baseName, provider, providerOptions, providerFlags );
53 }
54
55 // TODO: temporary, for removal
56 if ( provider == "test_tiled_scene_provider"_L1 )
57 mValid = true;
58
59#if 0
60 setLegend( QgsMapLayerLegend::defaultTiledSceneLegend( this ) );
61#endif
62}
63
65
67{
69
70 QgsTiledSceneLayer *layer = new QgsTiledSceneLayer( source(), name(), mProviderKey, mLayerOptions );
71 QgsMapLayer::clone( layer );
72
73 if ( mRenderer )
74 layer->setRenderer( mRenderer->clone() );
75
76 layer->mElevationProperties = mElevationProperties->clone();
77 layer->mElevationProperties->setParent( layer );
78
79 layer->mLayerOptions = mLayerOptions;
80
81 return layer;
82}
83
85{
87
88 if ( !mDataProvider )
89 return QgsRectangle();
90
91 return mDataProvider->extent();
92}
93
94QString QgsTiledSceneLayer::loadDefaultMetadata( bool &resultFlag )
95{
97
98 resultFlag = false;
99 if ( !mDataProvider || !mDataProvider->isValid() )
100 return QString();
101
102 if ( qgis::down_cast< QgsTiledSceneDataProvider * >( mDataProvider.get() )->capabilities() & Qgis::TiledSceneProviderCapability::ReadLayerMetadata )
103 {
104 setMetadata( mDataProvider->layerMetadata() );
105 }
106 else
107 {
109 }
110 resultFlag = true;
111 return QString();
112}
113
120
122{
124
126 if ( mDataProvider && ( mDataProvider->flags() & Qgis::DataProviderFlag::IsBasemapSource ) )
127 {
129 }
130 if ( mDataProvider && ( mDataProvider->flags() & Qgis::DataProviderFlag::Is3DBasemapSource ) )
131 {
133 }
134 return res;
135}
136
143
150
152{
154
155 return mRenderer.get();
156}
157
159{
161
162 if ( renderer == mRenderer.get() )
163 return;
164
165 mRenderer.reset( renderer );
166 emit rendererChanged();
168}
169
176
178{
180
181 return mDataProvider.get();
182}
183
184bool QgsTiledSceneLayer::readXml( const QDomNode &layerNode, QgsReadWriteContext &context )
185{
187
188 // create provider
189 const QDomNode pkeyNode = layerNode.namedItem( u"provider"_s );
190 mProviderKey = pkeyNode.toElement().text();
191
193 {
194 const QgsDataProvider::ProviderOptions providerOptions { context.transformContext() };
196 // read extent
198 {
199 const QDomNode extentNode = layerNode.namedItem( u"extent"_s );
200 if ( !extentNode.isNull() )
201 {
202 // get the extent
203 const QgsRectangle mbr = QgsXmlUtils::readRectangle( extentNode.toElement() );
204
205 // store the extent
206 setExtent( mbr );
207 }
208 }
209
211 }
212
213 QString errorMsg;
214 if ( !readSymbology( layerNode, errorMsg, context ) )
215 return false;
216
217 readStyleManager( layerNode );
218
219 return isValid();
220}
221
222bool QgsTiledSceneLayer::writeXml( QDomNode &layerNode, QDomDocument &doc, const QgsReadWriteContext &context ) const
223{
225
226 QDomElement mapLayerNode = layerNode.toElement();
227 mapLayerNode.setAttribute( u"type"_s, QgsMapLayerFactory::typeToString( Qgis::LayerType::TiledScene ) );
228
229 {
230 QDomElement provider = doc.createElement( u"provider"_s );
231 const QDomText providerText = doc.createTextNode( providerType() );
232 provider.appendChild( providerText );
233 layerNode.appendChild( provider );
234 }
235
236 writeStyleManager( layerNode, doc );
237
238 QString errorMsg;
239 return writeSymbology( layerNode, doc, errorMsg, context );
240}
241
242bool QgsTiledSceneLayer::readSymbology( const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories )
243{
245
246 const QDomElement elem = node.toElement();
247
248 readCommonStyle( elem, context, categories );
249
250 readStyle( node, errorMessage, context, categories );
251
252 if ( categories.testFlag( CustomProperties ) )
253 readCustomProperties( node, u"variable"_s );
254
255 return true;
256}
257
258bool QgsTiledSceneLayer::readStyle( const QDomNode &node, QString &, QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories )
259{
261
262 bool result = true;
263
264 if ( categories.testFlag( Symbology ) )
265 {
266 // get and set the blend mode if it exists
267 const QDomNode blendModeNode = node.namedItem( u"blendMode"_s );
268 if ( !blendModeNode.isNull() )
269 {
270 const QDomElement e = blendModeNode.toElement();
271 setBlendMode( QgsPainting::getCompositionMode( static_cast< Qgis::BlendMode >( e.text().toInt() ) ) );
272 }
273
274 QDomElement rendererElement = node.firstChildElement( u"renderer"_s );
275 if ( !rendererElement.isNull() )
276 {
277 std::unique_ptr< QgsTiledSceneRenderer > r( QgsTiledSceneRenderer::load( rendererElement, context ) );
278 if ( r )
279 {
280 setRenderer( r.release() );
281 }
282 else
283 {
284 result = false;
285 }
286 }
287 // make sure layer has a renderer - if none exists, fallback to a default renderer
288 if ( !mRenderer )
289 {
291 }
292 }
293
294 // get and set the layer transparency and scale visibility if they exists
295 if ( categories.testFlag( Rendering ) )
296 {
297 const QDomNode layerOpacityNode = node.namedItem( u"layerOpacity"_s );
298 if ( !layerOpacityNode.isNull() )
299 {
300 const QDomElement e = layerOpacityNode.toElement();
301 setOpacity( e.text().toDouble() );
302 }
303
304 const bool hasScaleBasedVisibiliy { node.attributes().namedItem( u"hasScaleBasedVisibilityFlag"_s ).nodeValue() == '1' };
305 setScaleBasedVisibility( hasScaleBasedVisibiliy );
306 bool ok;
307 const double maxScale { node.attributes().namedItem( u"maxScale"_s ).nodeValue().toDouble( &ok ) };
308 if ( ok )
309 {
310 setMaximumScale( maxScale );
311 }
312 const double minScale { node.attributes().namedItem( u"minScale"_s ).nodeValue().toDouble( &ok ) };
313 if ( ok )
314 {
315 setMinimumScale( minScale );
316 }
317 }
318 return result;
319}
320
321bool QgsTiledSceneLayer::writeSymbology( QDomNode &node, QDomDocument &doc, QString &errorMessage, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories ) const
322{
324
325 Q_UNUSED( errorMessage )
326
327 QDomElement elem = node.toElement();
328 writeCommonStyle( elem, doc, context, categories );
329
330 ( void ) writeStyle( node, doc, errorMessage, context, categories );
331
332 return true;
333}
334
335bool QgsTiledSceneLayer::writeStyle( QDomNode &node, QDomDocument &doc, QString &, const QgsReadWriteContext &context, QgsMapLayer::StyleCategories categories ) const
336{
338
339 QDomElement mapLayerNode = node.toElement();
340
341 //save custom properties
342 if ( categories.testFlag( CustomProperties ) )
343 {
344 writeCustomProperties( node, doc );
345 }
346
347 if ( categories.testFlag( Symbology ) )
348 {
349 // add the blend mode field
350 QDomElement blendModeElem = doc.createElement( u"blendMode"_s );
351 const QDomText blendModeText = doc.createTextNode( QString::number( static_cast< int >( QgsPainting::getBlendModeEnum( blendMode() ) ) ) );
352 blendModeElem.appendChild( blendModeText );
353 node.appendChild( blendModeElem );
354
355 if ( mRenderer )
356 {
357 const QDomElement rendererElement = mRenderer->save( doc, context );
358 node.appendChild( rendererElement );
359 }
360 }
361
362 // add the layer opacity and scale visibility
363 if ( categories.testFlag( Rendering ) )
364 {
365 QDomElement layerOpacityElem = doc.createElement( u"layerOpacity"_s );
366 const QDomText layerOpacityText = doc.createTextNode( QString::number( opacity() ) );
367 layerOpacityElem.appendChild( layerOpacityText );
368 node.appendChild( layerOpacityElem );
369
370 mapLayerNode.setAttribute( u"hasScaleBasedVisibilityFlag"_s, hasScaleBasedVisibility() ? 1 : 0 );
371 mapLayerNode.setAttribute( u"maxScale"_s, maximumScale() );
372 mapLayerNode.setAttribute( u"minScale"_s, minimumScale() );
373 }
374 return true;
375}
376
378{
380
381 if ( mDataProvider )
382 mDataProvider->setTransformContext( transformContext );
384}
385
386void QgsTiledSceneLayer::setDataSourcePrivate( const QString &dataSource, const QString &baseName, const QString &provider, const QgsDataProvider::ProviderOptions &options, Qgis::DataProviderReadFlags flags )
387{
389
390 setName( baseName );
391 mProviderKey = provider;
392 mDataSource = dataSource;
393
394 if ( mPreloadedProvider )
395 {
396 mDataProvider.reset( qobject_cast< QgsTiledSceneDataProvider * >( mPreloadedProvider.release() ) );
397 }
398 else
399 {
400 std::unique_ptr< QgsScopedRuntimeProfile > profile;
401 if ( QgsApplication::profiler()->groupIsActive( u"projectload"_s ) )
402 profile = std::make_unique< QgsScopedRuntimeProfile >( tr( "Create %1 provider" ).arg( provider ), u"projectload"_s );
403 mDataProvider.reset( qobject_cast<QgsTiledSceneDataProvider *>( QgsProviderRegistry::instance()->createProvider( provider, dataSource, options, flags ) ) );
404 }
405
406 if ( !mDataProvider )
407 {
408 QgsDebugError( u"Unable to get tiled scene data provider"_s );
409 setValid( false );
410 return;
411 }
412
413 mDataProvider->setParent( this );
414 QgsDebugMsgLevel( u"Instantiated the tiled scene data provider plugin"_s, 2 );
415
416 setValid( mDataProvider->isValid() );
417 if ( !isValid() )
418 {
419 QgsDebugError( u"Invalid tiled scene provider plugin %1"_s.arg( QString( mDataSource.toUtf8() ) ) );
420 setError( mDataProvider->error() );
421 return;
422 }
423
424 // Load initial extent, crs and renderer
425 setCrs( mDataProvider->crs() );
427 {
428 setExtent( mDataProvider->extent() );
429 }
430
431 bool loadDefaultStyleFlag = false;
433 {
434 loadDefaultStyleFlag = true;
435 }
436
437 if ( !mRenderer || loadDefaultStyleFlag )
438 {
439 std::unique_ptr< QgsScopedRuntimeProfile > profile;
440 if ( QgsApplication::profiler()->groupIsActive( u"projectload"_s ) )
441 profile = std::make_unique< QgsScopedRuntimeProfile >( tr( "Load layer style" ), u"projectload"_s );
442
443 bool defaultLoadedFlag = false;
444
445 if ( !defaultLoadedFlag && loadDefaultStyleFlag )
446 {
447 loadDefaultStyle( defaultLoadedFlag );
448 }
449
450 if ( !defaultLoadedFlag )
451 {
452 // all else failed, create default renderer
454 }
455 }
456}
457
464
465QString QgsTiledSceneLayer::decodedSource( const QString &source, const QString &dataProvider, const QgsReadWriteContext &context ) const
466{
468
470}
471
472QString QgsTiledSceneLayer::loadDefaultStyle( bool &resultFlag )
473{
475
476 return QgsMapLayer::loadDefaultStyle( resultFlag );
477}
478
480{
482
483 const QgsLayerMetadataFormatter htmlFormatter( metadata() );
484 QString myMetadata = u"<html>\n<body>\n"_s;
485
486 myMetadata += generalHtmlMetadata();
487
488 // Begin Provider section
489 myMetadata += u"<h1>"_s + tr( "Information from provider" ) + u"</h1>\n<hr>\n"_s;
490 myMetadata += "<table class=\"list-view\">\n"_L1;
491
492 if ( mDataProvider )
493 myMetadata += mDataProvider->htmlMetadata();
494
495 // Extent
496 myMetadata += u"<tr><td class=\"highlight\">"_s + tr( "Extent" ) + u"</td><td>"_s + extent().toString() + u"</td></tr>\n"_s;
497
498 myMetadata += "</table>\n<br><br>"_L1;
499
500 // CRS
501 myMetadata += crsHtmlMetadata();
502
503 // identification section
504 myMetadata += u"<h1>"_s + tr( "Identification" ) + u"</h1>\n<hr>\n"_s;
505 myMetadata += htmlFormatter.identificationSectionHtml();
506 myMetadata += "<br><br>\n"_L1;
507
508 // extent section
509 myMetadata += u"<h1>"_s + tr( "Extent" ) + u"</h1>\n<hr>\n"_s;
510 myMetadata += htmlFormatter.extentSectionHtml( isSpatial() );
511 myMetadata += "<br><br>\n"_L1;
512
513 // Start the Access section
514 myMetadata += u"<h1>"_s + tr( "Access" ) + u"</h1>\n<hr>\n"_s;
515 myMetadata += htmlFormatter.accessSectionHtml();
516 myMetadata += "<br><br>\n"_L1;
517
518 // Start the contacts section
519 myMetadata += u"<h1>"_s + tr( "Contacts" ) + u"</h1>\n<hr>\n"_s;
520 myMetadata += htmlFormatter.contactsSectionHtml();
521 myMetadata += "<br><br>\n"_L1;
522
523 // Start the links section
524 myMetadata += u"<h1>"_s + tr( "Links" ) + u"</h1>\n<hr>\n"_s;
525 myMetadata += htmlFormatter.linksSectionHtml();
526 myMetadata += "<br><br>\n"_L1;
527
528 // Start the history section
529 myMetadata += u"<h1>"_s + tr( "History" ) + u"</h1>\n<hr>\n"_s;
530 myMetadata += htmlFormatter.historySectionHtml();
531 myMetadata += "<br><br>\n"_L1;
532
533 myMetadata += customPropertyHtmlMetadata();
534
535 myMetadata += "\n</body>\n</html>\n"_L1;
536 return myMetadata;
537}
538
539bool QgsTiledSceneLayer::isReadOnly() const
540{
541 return true;
542}
Provides global constants and enumerations for use throughout the application.
Definition qgis.h:62
@ Is3DBasemapLayer
Layer is considered a '3D basemap' layer. This flag is similar to IsBasemapLayer, but reserved for la...
Definition qgis.h:2364
@ IsBasemapLayer
Layer is considered a 'basemap' layer, and certain properties of the layer should be ignored when cal...
Definition qgis.h:2363
@ Is3DBasemapSource
Associated source should be considered a '3D basemap' layer. See Qgis::MapLayerProperty::Is3DBasemapL...
Definition qgis.h:2394
@ IsBasemapSource
Associated source should be considered a 'basemap' layer. See Qgis::MapLayerProperty::IsBasemapLayer.
Definition qgis.h:2391
BlendMode
Blending modes defining the available composition modes that can be used when painting.
Definition qgis.h:5087
QFlags< DataProviderReadFlag > DataProviderReadFlags
Flags which control data provider construction.
Definition qgis.h:512
@ ReadLayerMetadata
Provider can read layer metadata from data store. See QgsDataProvider::layerMetadata().
Definition qgis.h:5978
@ TiledScene
Tiled scene layer. Added in QGIS 3.34.
Definition qgis.h:215
QFlags< MapLayerProperty > MapLayerProperties
Map layer properties.
Definition qgis.h:2367
@ LoadDefaultStyle
Reset the layer's style to the default for the datasource.
Definition qgis.h:495
@ SkipGetExtent
Skip the extent from provider.
Definition qgis.h:496
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.
QString name
Definition qgsmaplayer.h:87
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...
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:89
QgsMapLayer(Qgis::LayerType type=Qgis::LayerType::Vector, const QString &name=QString(), const QString &source=QString())
Constructor for QgsMapLayer.
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.
QgsMapLayer::LayerFlags flags
Definition qgsmaplayer.h:99
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.
double opacity
Definition qgsmaplayer.h:95
@ 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 rounded to the spec...
Contains information about the context of a rendering operation.
Base class for data providers for QgsTiledSceneLayer.
Tiled scene layer specific subclass of QgsMapLayerElevationProperties.
Implementation of threaded 2D rendering for tiled scene layers.
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.
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 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 readStyle(const QDomNode &node, QString &errorMessage, QgsReadWriteContext &context, StyleCategories categories=AllStyleCategories) final
Read the style for the current layer from the DOM node supplied.
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...
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.
~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:63
#define QgsDebugError(str)
Definition qgslogger.h:59
#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.