QGIS API Documentation 3.39.0-Master (7b5d8bea57d)
Loading...
Searching...
No Matches
qgspointcloudlayerchunkloader_p.h
Go to the documentation of this file.
1/***************************************************************************
2 qgspointcloudlayerchunkloader_p.h
3 --------------------------------------
4 Date : October 2020
5 Copyright : (C) 2020 by Peter Petrik
6 Email : zilolv 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 QGSPOINTCLOUDLAYERCHUNKLOADER_P_H
17#define QGSPOINTCLOUDLAYERCHUNKLOADER_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 "qgschunkloader_p.h"
31#include "qgschunkedentity_p.h"
35
36#include <memory>
37
38#include <QFutureWatcher>
39#if QT_VERSION < QT_VERSION_CHECK(6, 0, 0)
40#include <Qt3DRender/QGeometry>
41#include <Qt3DRender/QBuffer>
42#else
43#include <Qt3DCore/QGeometry>
44#include <Qt3DCore/QBuffer>
45#endif
46#include <Qt3DRender/QMaterial>
47#include <QVector3D>
48
49#define SIP_NO_FILE
50
58class QgsPointCloudLayerChunkLoaderFactory : public QgsChunkLoaderFactory
59{
60 Q_OBJECT
61
62 public:
63
68 QgsPointCloudLayerChunkLoaderFactory( const Qgs3DRenderContext &context, const QgsCoordinateTransform &coordinateTransform, QgsPointCloudIndex *pc, QgsPointCloud3DSymbol *symbol,
69 double zValueScale, double zValueOffset, int pointBudget );
70
72 virtual QgsChunkLoader *createChunkLoader( QgsChunkNode *node ) const override;
73 virtual QgsChunkNode *createRootNode() const override;
74 virtual QVector<QgsChunkNode *> createChildren( QgsChunkNode *node ) const override;
75 virtual int primitivesCount( QgsChunkNode *node ) const override;
76 Qgs3DRenderContext mRenderContext;
77 QgsCoordinateTransform mCoordinateTransform;
78 QgsPointCloudIndex *mPointCloudIndex;
79 std::unique_ptr< QgsPointCloud3DSymbol > mSymbol;
80 double mZValueScale = 1.0;
81 double mZValueOffset = 0;
82 int mPointBudget = 1000000;
83 bool mTriangulate = false;
84 QgsRectangle mExtent;
85};
86
87
96class QgsPointCloudLayerChunkLoader : public QgsChunkLoader
97{
98 Q_OBJECT
99
100 public:
101
106 QgsPointCloudLayerChunkLoader( const QgsPointCloudLayerChunkLoaderFactory *factory, QgsChunkNode *node, std::unique_ptr< QgsPointCloud3DSymbol > symbol,
107 const QgsCoordinateTransform &coordinateTransform, double zValueScale, double zValueOffset );
108 ~QgsPointCloudLayerChunkLoader() override;
109
110 virtual void cancel() override;
111 virtual Qt3DCore::QEntity *createEntity( Qt3DCore::QEntity *parent ) override;
112
113 private:
114 const QgsPointCloudLayerChunkLoaderFactory *mFactory;
115 std::unique_ptr<QgsPointCloud3DSymbolHandler> mHandler;
117 QFutureWatcher<void> *mFutureWatcher = nullptr;
118};
119
120
131class QgsPointCloudLayerChunkedEntity : public QgsChunkedEntity
132{
133 Q_OBJECT
134 public:
135 explicit QgsPointCloudLayerChunkedEntity( Qgs3DMapSettings *map, QgsPointCloudIndex *pc, const QgsCoordinateTransform &coordinateTransform, QgsPointCloud3DSymbol *symbol, float maxScreenError, bool showBoundingBoxes,
136 double zValueScale, double zValueOffset, int pointBudget );
137
138 QVector<QgsRayCastingUtils::RayHit> rayIntersection( const QgsRayCastingUtils::Ray3D &ray, const QgsRayCastingUtils::RayCastContext &context ) const override;
139
140 ~QgsPointCloudLayerChunkedEntity();
141};
142
144
145#endif // QGSPOINTCLOUDLAYERCHUNKLOADER_P_H
Class for doing transforms between two map coordinate systems.
Encapsulates the render context for a 3D point cloud rendering operation.
Represents a indexed point clouds data in octree.
A rectangle specified with double values.
Helper struct to store ray casting parameters.