QGIS API Documentation 3.99.0-Master (a5475b57e34)
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.h"
21#include "qgsrectangle.h"
22#include "qgsterraingenerator.h"
23#include "qgstiledsceneindex.h"
24#include "qgstiledscenelayer.h"
25#include "qgstiles.h"
26
27#include <QPointer>
28
29#define SIP_NO_FILE
30
31class QgsTerrainEntity;
32
33
40{
41 Q_OBJECT
42 public:
47
49
50 void setTerrain( QgsTerrainEntity *t ) override;
51 QgsTerrainGenerator *clone() const override SIP_FACTORY;
52 QgsTerrainGenerator::Type type() const override;
53 void setExtent( const QgsRectangle &extent ) override;
54 QgsRectangle rootChunkExtent() const override;
55 float rootChunkError( const Qgs3DMapSettings &map ) const override;
56 void rootChunkHeightRange( float &hMin, float &hMax ) const override;
57 float heightAt( double x, double y, const Qgs3DRenderContext &context ) const override;
58 QgsChunkLoader *createChunkLoader( QgsChunkNode *node ) const override;
59 // Root node has zoom=0, x=0, y=0.
60 // It corresponds to a fake zoom=-1 tile for QgsTileMatrix
61 QgsChunkNode *createRootNode() const override;
62 QVector<QgsChunkNode *> createChildren( QgsChunkNode *node ) const override;
63
68 bool setLayer( QgsTiledSceneLayer *layer );
70 QgsTiledSceneLayer *layer() const;
71
72 private:
73 QPointer<QgsTiledSceneLayer> mLayer;
74 std::optional<QgsQuantizedMeshMetadata> mMetadata;
75 QgsCoordinateTransform mTileCrsToMapCrs;
76 QgsTiledSceneIndex mIndex;
77 QgsRectangle mMapExtent;
78 QgsTileXYZ nodeIdToTile( QgsChunkNodeId nodeId ) const;
79};
Definition of the world.
Rendering context for preparation of 3D entities.
Handles coordinate transforms between two coordinate systems.
static QgsTerrainGenerator * create()
Creates a new instance of a QgsQuantizedMeshTerrainGenerator object.
A rectangle specified with double values.
Base class for generators of terrain.
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:43
An index for tiled scene data providers.
Represents a map layer supporting display of tiled scene objects.
#define SIP_FACTORY
Definition qgis_sip.h:83