QGIS API Documentation 3.99.0-Master (2fe06baccd8)
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 "qgsterrainentity.h"
23#include "qgsterraingenerator.h"
24#include "qgstiledsceneindex.h"
25#include "qgstiledscenelayer.h"
26#include "qgstiles.h"
27
28#include <QPointer>
29
30#define SIP_NO_FILE
31
38{
39 Q_OBJECT
40 public:
45
47
48 void setTerrain( QgsTerrainEntity *t ) override;
49 QgsTerrainGenerator *clone() const override SIP_FACTORY;
50 QgsTerrainGenerator::Type type() const override;
51 void setExtent( const QgsRectangle &extent ) override;
52 QgsRectangle rootChunkExtent() const override;
53 float rootChunkError( const Qgs3DMapSettings &map ) const override;
54 void rootChunkHeightRange( float &hMin, float &hMax ) const override;
55 float heightAt( double x, double y, const Qgs3DRenderContext &context ) const override;
56 QgsChunkLoader *createChunkLoader( QgsChunkNode *node ) const override;
57 // Root node has zoom=0, x=0, y=0.
58 // It corresponds to a fake zoom=-1 tile for QgsTileMatrix
59 QgsChunkNode *createRootNode() const override;
60 QVector<QgsChunkNode *> createChildren( QgsChunkNode *node ) const override;
61
66 bool setLayer( QgsTiledSceneLayer *layer );
68 QgsTiledSceneLayer *layer() const;
69
70 private:
71 QPointer<QgsTiledSceneLayer> mLayer;
72 std::optional<QgsQuantizedMeshMetadata> mMetadata;
73 QgsCoordinateTransform mTileCrsToMapCrs;
74 QgsTiledSceneIndex mIndex;
75 QgsRectangle mMapExtent;
76 QgsTileXYZ nodeIdToTile( QgsChunkNodeId nodeId ) const;
77};
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:39
An index for tiled scene data providers.
Represents a map layer supporting display of tiled scene objects.
#define SIP_FACTORY
Definition qgis_sip.h:84