16#ifndef QGSPOINTCLOUDLAYERCHUNKLOADER_P_H
17#define QGSPOINTCLOUDLAYERCHUNKLOADER_P_H
38#include <QFutureWatcher>
40#if QT_VERSION < QT_VERSION_CHECK( 6, 0, 0 )
41#include <Qt3DRender/QGeometry>
42#include <Qt3DRender/QBuffer>
44#include <Qt3DCore/QGeometry>
45#include <Qt3DCore/QBuffer>
58class QgsPointCloudLayerChunkLoaderFactory :
public QgsChunkLoaderFactory
68 QgsPointCloudLayerChunkLoaderFactory(
const Qgs3DRenderContext &context,
const QgsCoordinateTransform &coordinateTransform, QgsPointCloudIndex pc, QgsPointCloud3DSymbol *symbol,
double zValueScale,
double zValueOffset,
int pointBudget );
71 QgsChunkLoader *createChunkLoader( QgsChunkNode *node )
const override;
72 QgsChunkNode *createRootNode()
const override;
73 QVector<QgsChunkNode *> createChildren( QgsChunkNode *node )
const override;
74 int primitivesCount( QgsChunkNode *node )
const override;
75 Qgs3DRenderContext mRenderContext;
76 QgsCoordinateTransform mCoordinateTransform;
77 QgsPointCloudIndex mPointCloudIndex;
78 std::unique_ptr<QgsPointCloud3DSymbol> mSymbol;
79 double mZValueScale = 1.0;
80 double mZValueOffset = 0;
81 int mPointBudget = 1000000;
82 bool mTriangulate =
false;
95class QgsPointCloudLayerChunkLoader :
public QgsChunkLoader
105 QgsPointCloudLayerChunkLoader(
const QgsPointCloudLayerChunkLoaderFactory *factory, QgsChunkNode *node, std::unique_ptr<QgsPointCloud3DSymbol> symbol,
const QgsCoordinateTransform &coordinateTransform,
double zValueScale,
double zValueOffset );
106 ~QgsPointCloudLayerChunkLoader()
override;
108 void start()
override;
109 void cancel()
override;
110 Qt3DCore::QEntity *createEntity( Qt3DCore::QEntity *parent )
override;
113 const QgsPointCloudLayerChunkLoaderFactory *mFactory;
114 std::unique_ptr<QgsPointCloud3DSymbolHandler> mHandler;
115 QgsPointCloud3DRenderContext mContext;
116 QFutureWatcher<void> *mFutureWatcher =
nullptr;
130class QgsPointCloudLayerChunkedEntity :
public QgsChunkedEntity
134 explicit QgsPointCloudLayerChunkedEntity( Qgs3DMapSettings *map, QgsPointCloudLayer *pcl, QgsPointCloudIndex index,
const QgsCoordinateTransform &coordinateTransform, QgsPointCloud3DSymbol *symbol,
float maxScreenError,
bool showBoundingBoxes,
double zValueScale,
double zValueOffset,
int pointBudget );
136 QList<QgsRayCastHit> rayIntersection(
const QgsRay3D &ray,
const QgsRayCastContext &context )
const override;
138 ~QgsPointCloudLayerChunkedEntity()
override;
144 QgsPointCloudLayer *mLayer =
nullptr;
145 std::unique_ptr<QgsChunkUpdaterFactory> mChunkUpdaterFactory;