QGIS API Documentation 3.37.0-Master (fdefdf9c27f)
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
26 : Qgs3DRendererAbstractMetadata( QStringLiteral( "mesh" ) )
27{
28}
29
31{
33 r->readXml( elem, context );
34 return r;
35}
36
37// ---------
38
39
41 : mSymbol( s )
42{
43}
44
46{
47 QgsMeshLayer3DRenderer *r = new QgsMeshLayer3DRenderer( mSymbol ? ( QgsMesh3DSymbol * )mSymbol->clone() : nullptr );
48 r->mLayerRef = mLayerRef;
49 return r;
50}
51
53{
54 mLayerRef = QgsMapLayerRef( layer );
55}
56
58{
59 return qobject_cast<QgsMeshLayer *>( mLayerRef.layer );
60}
61
63{
64 mSymbol.reset( symbol );
65}
66
68{
69 return mSymbol.get();
70}
71
72Qt3DCore::QEntity *QgsMeshLayer3DRenderer::createEntity( const Qgs3DMapSettings &map ) const
73{
74 QgsMeshLayer *meshLayer = layer();
75
76 if ( !meshLayer || !meshLayer->dataProvider() )
77 return nullptr;
78
79 if ( meshLayer->dataProvider()->contains( QgsMesh::ElementType::Edge ) ||
80 !mSymbol->isEnabled() )
81 {
82 // 3D not implemented for 1D meshes
83 return nullptr;
84 }
85
86 if ( mSymbol->verticalDatasetGroupIndex() < 0 )
87 return nullptr;
88
89 Qt3DCore::QEntity *entity = nullptr;
90
91 const QgsCoordinateTransform coordTrans( meshLayer->crs(), map.crs(), map.transformContext() );
92 meshLayer->updateTriangularMesh( coordTrans );
93 const QgsTriangularMesh triangularMesh = *meshLayer->triangularMeshByLodIndex( mSymbol->levelOfDetailIndex() );
94 QgsMeshDataset3DEntity *meshEntity = new QgsMeshDataset3DEntity( map, triangularMesh, meshLayer, mSymbol.get() );
95 meshEntity->build();
96 entity = meshEntity;
97
98 return entity;
99}
100
101void QgsMeshLayer3DRenderer::writeXml( QDomElement &elem, const QgsReadWriteContext &context ) const
102{
103 QDomDocument doc = elem.ownerDocument();
104
105 elem.setAttribute( QStringLiteral( "layer" ), mLayerRef.layerId );
106
107 QDomElement elemSymbol = doc.createElement( QStringLiteral( "symbol" ) );
108 if ( mSymbol )
109 {
110 elemSymbol.setAttribute( QStringLiteral( "type" ), mSymbol->type() );
111 mSymbol->writeXml( elemSymbol, context );
112 }
113 elem.appendChild( elemSymbol );
114}
115
116void QgsMeshLayer3DRenderer::readXml( const QDomElement &elem, const QgsReadWriteContext &context )
117{
118 mLayerRef = QgsMapLayerRef( elem.attribute( QStringLiteral( "layer" ) ) );
119
120 const QDomElement elemSymbol = elem.firstChildElement( QStringLiteral( "symbol" ) );
122 symbol->readXml( elemSymbol, context );
123 mSymbol.reset( symbol );
124}
125
127{
128 mLayerRef.setLayer( project.mapLayer( mLayerRef.layerId ) );
129}
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...
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:81
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(const 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.
Definition: qgsmeshlayer.h:101
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.