QGIS API Documentation 3.39.0-Master (d85f3c2a281)
Loading...
Searching...
No Matches
qgsquantizedmeshterraingenerator.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsterraingenerator.h
3 --------------------------------------
4 Date : August 2024
5 Copyright : (C) 2024 by David Koňařík
6 Email : dvdkon at konarici dot cz
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#pragma once
17
18#include "qgschunknode_p.h"
20#include "qgsmaplayerref.h"
21#include "qgsterrainentity_p.h"
22#include "qgsterraingenerator.h"
24#include "qgstiledsceneindex.h"
25#include "qgstiledscenelayer.h"
26#include "qgstiles.h"
27
28#define SIP_NO_FILE
29
36{
37 Q_OBJECT
38 public:
39 QgsQuantizedMeshTerrainGenerator() { mIsValid = false; }
40
41 virtual void setTerrain( QgsTerrainEntity *t ) override;
42 virtual QgsTerrainGenerator *clone() const override SIP_FACTORY;
43 virtual QgsTerrainGenerator::Type type() const override;
44 virtual QgsRectangle rootChunkExtent() const override;
45 virtual float rootChunkError( const Qgs3DMapSettings &map ) const override;
46 virtual void rootChunkHeightRange( float &hMin, float &hMax ) const override;
47 virtual float heightAt( double x, double y, const Qgs3DRenderContext &context ) const override;
48 virtual void writeXml( QDomElement &elem ) const override;
49 virtual void readXml( const QDomElement &elem ) override;
50 virtual void resolveReferences( const QgsProject &project ) override;
51 virtual QgsChunkLoader *createChunkLoader( QgsChunkNode *node ) const override;
52 // Root node has zoom=0, x=0, y=0.
53 // It corresponds to a fake zoom=-1 tile for QgsTileMatrix
54 virtual QgsChunkNode *createRootNode() const override;
55 virtual QVector<QgsChunkNode *> createChildren( QgsChunkNode *node ) const override;
56
61 bool setLayer( QgsTiledSceneLayer *layer );
63 QgsTiledSceneLayer *layer() const;
64
65 private:
66 QgsMapLayerRef mLayerRef;
67 std::optional<QgsQuantizedMeshMetadata> mMetadata;
68 QgsCoordinateTransform mTileCrsToMapCrs;
69 QgsTiledSceneIndex mIndex;
70
71 QgsQuantizedMeshTerrainGenerator( QgsMapLayerRef layerRef, const QgsQuantizedMeshMetadata &metadata );
72 QgsTileXYZ nodeIdToTile( QgsChunkNodeId nodeId ) const;
73};
Class for doing transforms between two map coordinate systems.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
Definition qgsproject.h:107
A rectangle specified with double values.
virtual void setTerrain(QgsTerrainEntity *t)
Sets terrain entity for the generator (does not transfer ownership)
virtual QgsTerrainGenerator * clone() const =0SIP_FACTORY
Makes a copy of the current instance.
Stores coordinates of a tile in a tile matrix set.
Definition qgstiles.h:40
An index for tiled scene data providers.
Represents a map layer supporting display of tiled scene objects.
#define SIP_FACTORY
Definition qgis_sip.h:76