QGIS API Documentation 3.41.0-Master (45a0abf3bec)
Loading...
Searching...
No Matches
qgslinevertexdata_p.h
Go to the documentation of this file.
1/***************************************************************************
2 qgslinevertexdata_p.h
3 --------------------------------------
4 Date : Apr 2019
5 Copyright : (C) 2019 by Martin Dobias
6 Email : wonder dot sk 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
16#ifndef QGSLINEVERTEXDATA_P_H
17#define QGSLINEVERTEXDATA_P_H
18
20
21//
22// W A R N I N G
23// -------------
24//
25// This file is not part of the QGIS API. It exists purely as an
26// implementation detail. This header file may change from version to
27// version without notice, or even be removed.
28//
29
30#include <QVector>
31#include <QVector3D>
32
33#define SIP_NO_FILE
34
35#include "qgis.h"
36#include "qgs3drendercontext.h"
37
38
39namespace Qt3DCore
40{
41 class QNode;
42#if QT_VERSION >= QT_VERSION_CHECK(6, 0, 0)
43 class QGeometry;
44#endif
45}
46
47#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
48namespace Qt3DRender
49{
50 class QGeometry;
51}
52#endif
53
54class QgsLineString;
55
56
71struct QgsLineVertexData
72{
73 QVector<QVector3D> vertices;
74 QVector<unsigned int> indexes;
75 QByteArray materialDataDefined;
76
77 bool withAdjacency = false;
78
79 // extra info to calculate elevation
82 float baseHeight = 0;
83 Qgs3DRenderContext renderContext; // used for altitude clamping
84 QgsVector3D origin; // all coordinates are relative to this origin (e.g. center of the chunk)
85
86 QgsLineVertexData();
87
88 void init( Qgis::AltitudeClamping clamping, Qgis::AltitudeBinding binding, float height, const Qgs3DRenderContext &renderContext, const QgsVector3D &chunkOrigin );
89
90 QByteArray createVertexBuffer();
91 QByteArray createIndexBuffer();
92#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
93 Qt3DRender::QGeometry *createGeometry( Qt3DCore::QNode *parent );
94#else
95 Qt3DCore::QGeometry *createGeometry( Qt3DCore::QNode *parent );
96#endif
97
98 void addLineString( const QgsLineString &lineString, float extraHeightOffset = 0 );
99 void addVerticalLines( const QgsLineString &lineString, float verticalLength, float extraHeightOffset = 0 );
100};
101
103
104#endif // QGSLINEVERTEXDATA_P_H
AltitudeClamping
Altitude clamping.
Definition qgis.h:3699
@ Relative
Elevation is relative to terrain height (final elevation = terrain elevation + feature elevation)
AltitudeBinding
Altitude binding.
Definition qgis.h:3712
@ Vertex
Clamp every vertex of feature.
Line string geometry type, with support for z-dimension and m-values.
Class for storage of 3D vectors similar to QVector3D, with the difference that it uses double precisi...
Definition qgsvector3d.h:31