QGIS API Documentation 3.40.0-Bratislava (b56115d8743)
Loading...
Searching...
No Matches
qgsmeshlayer3drenderer.cpp
Go to the documentation of this file.
1/***************************************************************************
2 qgsmeshlayer3drenderer.cpp
3 --------------------------
4 Date : January 2019
5 Copyright : (C) 2019 by Peter Petrik
6 Email : zilolv at gmail dot com
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
17
19#include "qgsmesh3dsymbol.h"
20
21#include "qgsmeshlayer.h"
22#include "qgsxmlutils.h"
23#include "qgsmesh3dentity_p.h"
24#include "qgs3drendercontext.h"
25#include "qgs3dmapsettings.h"
26
31
33{
35 r->readXml( elem, context );
36 return r;
37}
38
39// ---------
40
41
46
48{
49 QgsMeshLayer3DRenderer *r = new QgsMeshLayer3DRenderer( mSymbol ? ( QgsMesh3DSymbol * )mSymbol->clone() : nullptr );
50 r->mLayerRef = mLayerRef;
51 return r;
52}
53
55{
56 mLayerRef = QgsMapLayerRef( layer );
57}
58
60{
61 return qobject_cast<QgsMeshLayer *>( mLayerRef.layer );
62}
63
65{
66 mSymbol.reset( symbol );
67}
68
70{
71 return mSymbol.get();
72}
73
75{
76 QgsMeshLayer *meshLayer = layer();
77
78 if ( !meshLayer || !meshLayer->dataProvider() )
79 return nullptr;
80
81 if ( meshLayer->dataProvider()->contains( QgsMesh::ElementType::Edge ) ||
82 !mSymbol->isEnabled() )
83 {
84 // 3D not implemented for 1D meshes
85 return nullptr;
86 }
87
88 if ( mSymbol->verticalDatasetGroupIndex() < 0 )
89 return nullptr;
90
91 Qt3DCore::QEntity *entity = nullptr;
92
93 const QgsCoordinateTransform coordTrans( meshLayer->crs(), map->crs(), map->transformContext() );
94 meshLayer->updateTriangularMesh( coordTrans );
95 const QgsTriangularMesh triangularMesh = *meshLayer->triangularMeshByLodIndex( mSymbol->levelOfDetailIndex() );
96 QgsMeshDataset3DEntity *meshEntity = new QgsMeshDataset3DEntity( Qgs3DRenderContext::fromMapSettings( map ), triangularMesh, meshLayer, mSymbol.get() );
97 meshEntity->build();
98 entity = meshEntity;
99
100 return entity;
101}
102
103void QgsMeshLayer3DRenderer::writeXml( QDomElement &elem, const QgsReadWriteContext &context ) const
104{
105 QDomDocument doc = elem.ownerDocument();
106
107 elem.setAttribute( QStringLiteral( "layer" ), mLayerRef.layerId );
108
109 QDomElement elemSymbol = doc.createElement( QStringLiteral( "symbol" ) );
110 if ( mSymbol )
111 {
112 elemSymbol.setAttribute( QStringLiteral( "type" ), mSymbol->type() );
113 mSymbol->writeXml( elemSymbol, context );
114 }
115 elem.appendChild( elemSymbol );
116}
117
118void QgsMeshLayer3DRenderer::readXml( const QDomElement &elem, const QgsReadWriteContext &context )
119{
120 mLayerRef = QgsMapLayerRef( elem.attribute( QStringLiteral( "layer" ) ) );
121
122 const QDomElement elemSymbol = elem.firstChildElement( QStringLiteral( "symbol" ) );
124 symbol->readXml( elemSymbol, context );
125 mSymbol.reset( symbol );
126}
127
129{
130 mLayerRef.setLayer( project.mapLayer( mLayerRef.layerId ) );
131}
QgsCoordinateReferenceSystem crs() const
Returns coordinate reference system used in the 3D scene.
QgsCoordinateTransformContext transformContext() const
Returns the coordinate transform context, which stores various information regarding which datum tran...
static Qgs3DRenderContext fromMapSettings(const Qgs3DMapSettings *mapSettings)
Creates an initialized Qgs3DRenderContext instance from given Qgs3DMapSettings.
Base metadata class for 3D renderers.
Base class for all renderers that may to participate in 3D view.
Class for doing transforms between two map coordinate systems.
QgsCoordinateReferenceSystem crs
Definition qgsmaplayer.h:83
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads symbol configuration from the given DOM element.
bool contains(const QgsMesh::ElementType &type) const
Returns whether the mesh contains at mesh elements of given type.
QgsAbstract3DRenderer * createRenderer(QDomElement &elem, const QgsReadWriteContext &context) override
Creates an instance of a 3D renderer based on a DOM element with renderer configuration.
3D renderer that renders all mesh triangles of a mesh layer.
Qt3DCore::QEntity * createEntity(Qgs3DMapSettings *map) const override
Returns a 3D entity that will be used to show renderer's data in 3D scene.
void readXml(const QDomElement &elem, const QgsReadWriteContext &context) override
Reads renderer's properties from given XML element.
void setSymbol(QgsMesh3DSymbol *symbol)
Sets 3D symbol associated with the renderer.
const QgsMesh3DSymbol * symbol() const
Returns 3D symbol associated with the renderer.
QgsMeshLayer3DRenderer(QgsMesh3DSymbol *s=nullptr)
Takes ownership of the symbol object.
void setLayer(QgsMeshLayer *layer)
Sets vector layer associated with the renderer.
void writeXml(QDomElement &elem, const QgsReadWriteContext &context) const override
Writes renderer's properties to given XML element.
void resolveReferences(const QgsProject &project) override
Resolves references to other objects - second phase of loading - after readXml()
QgsMeshLayer * layer() const
Returns mesh layer associated with the renderer.
QgsMeshLayer3DRenderer * clone() const override
Returns a cloned instance.
Represents a mesh layer supporting display of data on structured or unstructured meshes.
void updateTriangularMesh(const QgsCoordinateTransform &transform=QgsCoordinateTransform())
Gets native mesh and updates (creates if it doesn't exist) the base triangular mesh.
QgsTriangularMesh * triangularMeshByLodIndex(int lodIndex) const
Returns triangular corresponding to the index of level of details.
QgsMeshDataProvider * dataProvider() override
Returns the layer's data provider, it may be nullptr.
Encapsulates a QGIS project, including sets of map layers and their styles, layouts,...
Definition qgsproject.h:107
Q_INVOKABLE QgsMapLayer * mapLayer(const QString &layerId) const
Retrieve a pointer to a registered layer by layer ID.
The class is used as a container of context for various read/write operations on other objects.
Triangular/Derived Mesh is mesh with vertices in map coordinates.
_LayerRef< QgsMapLayer > QgsMapLayerRef
QPointer< TYPE > layer
Weak pointer to map layer.
void setLayer(TYPE *l)
Sets the reference to point to a specified layer.
QString layerId
Original layer ID.