QGIS API Documentation 3.99.0-Master (2fe06baccd8)
Loading...
Searching...
No Matches
qgsmeshlayerrenderer.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsmeshlayerrenderer.h
3 ----------------------
4 begin : April 2018
5 copyright : (C) 2018 by Peter Petrik
6 email : zilolv at gmail dot com
7 ***************************************************************************/
8
9/***************************************************************************
10 * *
11 * This program is free software; you can redistribute it and/or modify *
12 * it under the terms of the GNU General Public License as published by *
13 * the Free Software Foundation; either version 2 of the License, or *
14 * (at your option) any later version. *
15 * *
16 ***************************************************************************/
17
18#ifndef QGSMESHLAYERRENDERER_H
19#define QGSMESHLAYERRENDERER_H
20
21class QgsMeshLayer;
22
23#define SIP_NO_FILE
24
25#include <limits>
26#include <memory>
27
28#include "qgis.h"
30#include "qgsmaplayerrenderer.h"
31#include "qgsmeshdataprovider.h"
32#include "qgsmeshlayer.h"
34#include "qgsrasterinterface.h"
35#include "qgstriangularmesh.h"
36
39
41
46class QgsMeshLayerRendererFeedback : public QgsRasterBlockFeedback
47{
48 Q_OBJECT
49};
50
51
55struct CORE_NO_EXPORT QgsMeshLayerRendererCache
56{
57 int mDatasetGroupsCount = 0;
58
59 // scalar dataset
60 QgsMeshDatasetIndex mActiveScalarDatasetIndex;
61 QVector<double> mScalarDatasetValues;
62 QgsMeshDataBlock mScalarActiveFaceFlagValues;
64 double mScalarDatasetMinimum = std::numeric_limits<double>::quiet_NaN();
65 double mScalarDatasetMaximum = std::numeric_limits<double>::quiet_NaN();
67 std::unique_ptr<QgsMesh3DAveragingMethod> mScalarAveragingMethod;
68
69 // vector dataset
70 QgsMeshDatasetIndex mActiveVectorDatasetIndex;
71 QgsMeshDataBlock mVectorDatasetValues;
72 QgsMeshDataBlock mVectorActiveFaceFlagValues;
73 QVector<double> mVectorDatasetValuesMag;
74 double mVectorDatasetMagMinimum = std::numeric_limits<double>::quiet_NaN();
75 double mVectorDatasetMagMaximum = std::numeric_limits<double>::quiet_NaN();
76 double mVectorDatasetGroupMagMinimum = std::numeric_limits<double>::quiet_NaN();
77 double mVectorDatasetGroupMagMaximum = std::numeric_limits<double>::quiet_NaN();
79 std::unique_ptr<QgsMesh3DAveragingMethod> mVectorAveragingMethod;
80};
81
82
84
93{
94 public:
97 ~QgsMeshLayerRenderer() override = default;
98 QgsFeedback *feedback() const override;
99 bool render() override;
100 bool forceRasterRender() const override;
101
102 private:
103 void prepareLabeling( QgsMeshLayer *layer, QSet<QString> &attributeNames );
104 void renderMesh();
105 void renderEdgeMesh( const QgsMeshRendererMeshSettings &settings, const QList<int> &edgesInExtent );
106 void renderFaceMesh( const QgsMeshRendererMeshSettings &settings, const QVector<QgsMeshFace> &faces, const QList<int> &facesInExtent );
107 void renderScalarDataset();
108 void renderScalarDatasetOnEdges( const QgsMeshRendererScalarSettings &scalarSettings );
109 void renderScalarDatasetOnFaces( const QgsMeshRendererScalarSettings &scalarSettings );
110 void registerLabelFeatures();
111
112 void renderVectorDataset();
113 void copyTriangularMeshes( QgsMeshLayer *layer, QgsRenderContext &context );
114 void copyScalarDatasetValues( QgsMeshLayer *layer );
115 void copyVectorDatasetValues( QgsMeshLayer *layer );
116 void calculateOutputSize();
117 QgsPointXY fractionPoint( const QgsPointXY &p1, const QgsPointXY &p2, double fraction ) const;
118 bool mIsMeshSimplificationActive = false;
119 QColor colorAt( QgsColorRampShader *shader, double val ) const;
120 bool mIsEditable = false;
121
126 QgsMeshLayerLabelProvider *mLabelProvider = nullptr;
127
128 protected:
129 QString mLayerName;
130
132 std::unique_ptr<QgsMeshLayerRendererFeedback> mFeedback;
133
134 // copy from mesh layer
136
137 // copy from mesh layer
139
140 // copy from mesh layer
142
143 // copy of the scalar dataset
144 QVector<double> mScalarDatasetValues;
147 double mScalarDatasetMinimum = std::numeric_limits<double>::quiet_NaN();
148 double mScalarDatasetMaximum = std::numeric_limits<double>::quiet_NaN();
149
150 // copy of the vector dataset
153 QVector<double> mVectorDatasetValuesMag;
154 double mVectorDatasetMagMinimum = std::numeric_limits<double>::quiet_NaN();
155 double mVectorDatasetMagMaximum = std::numeric_limits<double>::quiet_NaN();
156 double mVectorDatasetGroupMagMinimum = std::numeric_limits<double>::quiet_NaN();
157 double mVectorDatasetGroupMagMaximum = std::numeric_limits<double>::quiet_NaN();
159
160 // copy of rendering settings
162
163 QList< QgsMapClippingRegion > mClippingRegions;
164
165 // output screen size
167
168 double mElevationScale = 1.0;
169 double mElevationOffset = 0.0;
171
172 bool mEnableProfile = false;
173 quint64 mPreparationTime = 0;
174
175 private:
176
177 double mLayerOpacity = 1.0;
178};
179
180
181#endif // QGSMESHLAYERRENDERER_H
A ramp shader will color a raster pixel based on a list of values ranges in a ramp.
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:44
QgsMapLayerRenderer(const QString &layerID, QgsRenderContext *context=nullptr)
Constructor for QgsMapLayerRenderer, with the associated layerID and render context.
A block of integers/doubles from a mesh dataset.
DataType
Location of where data is specified for datasets in the dataset group.
@ DataOnVertices
Data is defined on vertices.
Implements a label provider for mesh layers.
QgsMeshDatasetGroupMetadata::DataType mScalarDataType
QgsTriangularMesh mTriangularMesh
QgsMeshLayerRenderer(QgsMeshLayer *layer, QgsRenderContext &context)
Ctor.
QVector< double > mScalarDatasetValues
std::unique_ptr< QgsMeshLayerRendererFeedback > mFeedback
feedback class for cancellation
~QgsMeshLayerRenderer() override=default
QgsMeshDataBlock mScalarActiveFaceFlagValues
bool render() override
Do the rendering (based on data stored in the class).
QVector< double > mVectorDatasetValuesMag
QgsMeshRendererSettings mRendererSettings
bool forceRasterRender() const override
Returns true if the renderer must be rendered to a raster paint device (e.g.
QgsMeshDatasetGroupMetadata::DataType mVectorDataType
QList< QgsMapClippingRegion > mClippingRegions
QgsFeedback * feedback() const override
Access to feedback object of the layer renderer (may be nullptr).
QgsMeshDataBlock mVectorActiveFaceFlagValues
QgsMeshDataBlock mVectorDatasetValues
Represents a mesh layer supporting display of data on structured or unstructured meshes.
Represents a mesh renderer settings for mesh objects.
Represents a mesh renderer settings for scalar datasets.
DataResamplingMethod
Resampling of value from dataset.
@ NoResampling
Does not use resampling.
Represents all mesh renderer settings.
Represents a 2D point.
Definition qgspointxy.h:60
Feedback object tailored for raster block reading.
A rectangle specified with double values.
Contains information about the context of a rendering operation.
A triangular/derived mesh with vertices in map coordinates.
Mesh - vertices, edges and faces.