24#include <Qt3DRender/QGeometryRenderer>
26#include "moc_qgsflatterraingenerator.cpp"
34FlatTerrainChunkLoader::FlatTerrainChunkLoader( QgsTerrainEntity *terrain, QgsChunkNode *node )
35 : QgsTerrainTileLoader( terrain, node )
38void FlatTerrainChunkLoader::start()
44Qt3DCore::QEntity *FlatTerrainChunkLoader::createEntity( Qt3DCore::QEntity *parent )
46 QgsTerrainTileEntity *entity =
new QgsTerrainTileEntity( mNode->tileId() );
53 mTileGeometry =
new Qt3DExtras::QPlaneGeometry;
55 Qt3DRender::QGeometryRenderer *mesh =
new Qt3DRender::QGeometryRenderer;
56 mesh->setGeometry( mTileGeometry );
57 entity->addComponent( mesh );
65 QgsGeoTransform *transform =
nullptr;
66 transform =
new QgsGeoTransform();
67 entity->addComponent( transform );
70 const QgsBox3D box3D = mNode->box3D();
73 const QgsBox3D commonExtent( std::max( box3D.
xMinimum(), mapFullBox3D.xMinimum() ), std::max( box3D.
yMinimum(), mapFullBox3D.yMinimum() ), box3D.
zMinimum(), std::min( box3D.
xMaximum(), mapFullBox3D.xMaximum() ), std::min( box3D.
yMaximum(), mapFullBox3D.yMaximum() ), box3D.
zMaximum() );
74 const double xSide = commonExtent.width();
75 const double ySide = commonExtent.height();
76 const double xMin = commonExtent.xMinimum();
77 const double yMin = commonExtent.yMinimum();
79 transform->setRotation( QQuaternion::fromAxisAndAngle( QVector3D( 1, 0, 0 ), 90 ) );
80 transform->setScale3D( QVector3D(
static_cast<float>( xSide ), 1,
static_cast<float>( ySide ) ) );
81 transform->setGeoTranslation(
QgsVector3D( xMin + xSide / 2, yMin + ySide / 2, 0 ) );
85 entity->setParent( parent );
100 return new FlatTerrainChunkLoader(
mTerrain, node );
108 cloned->updateTilingScheme();
131 updateTilingScheme();
140 updateTilingScheme();
143void QgsFlatTerrainGenerator::updateTilingScheme()
QgsRectangle extent() const
Returns the 3D scene's 2D extent in the 3D scene's CRS.
bool isTerrainShadingEnabled() const
Returns whether terrain shading is enabled.
QgsPhongMaterialSettings terrainShadingMaterial() const
Returns terrain shading material.
QList< QgsMapLayer * > layers() const
Returns the list of 3D map layers to be rendered in the scene.
A 3-dimensional box composed of x, y, z coordinates.
double yMaximum() const
Returns the maximum y value.
double xMinimum() const
Returns the minimum x value.
double zMaximum() const
Returns the maximum z value.
double xMaximum() const
Returns the maximum x value.
double zMinimum() const
Returns the minimum z value.
double yMinimum() const
Returns the minimum y value.
Represents a coordinate reference system (CRS).
Contains information about the context in which a coordinate transform is executed.
Type type() const override
What texture generator implementation is this.
QgsRectangle rootChunkExtent() const override
extent of the terrain's root chunk in terrain's CRS
void rootChunkHeightRange(float &hMin, float &hMax) const override
Returns height range of the root chunk in world coordinates.
static QgsTerrainGenerator * create()
Creates a new instance of a QgsFlatTerrainGenerator object.
QgsChunkLoader * createChunkLoader(QgsChunkNode *node) const override
QgsFlatTerrainGenerator()=default
void setExtent(const QgsRectangle &extent) override
sets the extent of the terrain in terrain's CRS
QgsCoordinateReferenceSystem crs() const override
Returns CRS of the terrain.
QgsTerrainGenerator * clone() const override
Makes a copy of the current instance.
void setCrs(const QgsCoordinateReferenceSystem &crs, const QgsCoordinateTransformContext &context) override
Sets the CRS associated with the terrain.
A rectangle specified with double values.
Base class for generators of terrain.
Type
Enumeration of the available terrain generators.
@ Flat
The whole terrain is flat area.
QgsTilingScheme mTerrainTilingScheme
Tiling scheme of the terrain.
QgsTerrainEntity * mTerrain
Encapsulates tiling schemes (just like with WMTS / TMS / XYZ layers).
A 3D vector (similar to QVector3D) with the difference that it uses double precision instead of singl...