QGIS API Documentation 3.35.0-Master (ffb31addd7f)
Loading...
Searching...
No Matches
qgspointcloudlayerrenderer.h
Go to the documentation of this file.
1/***************************************************************************
2 qgspointcloudlayerrenderer.h
3 --------------------
4 begin : October 2020
5 copyright : (C) 2020 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 QGSPOINTCLOUDLAYERRENDERER_H
19#define QGSPOINTCLOUDLAYERRENDERER_H
20
21#include "qgis_core.h"
22#include "qgscolorramp.h"
23#include "qgsmaplayerrenderer.h"
24#include "qgsreadwritecontext.h"
25#include "qgspointcloudindex.h"
26#include "qgsgeometry.h"
27
28#include "qgserror.h"
29#include "qgspointcloudindex.h"
30#include "qgsidentifycontext.h"
34#include "qgsrasterinterface.h"
35
36#include <QDomElement>
37#include <QString>
38#include <QPainter>
39#include <QElapsedTimer>
40
45class QgsPointCloudSubIndex;
46
47#define SIP_NO_FILE
48
60{
61 public:
62
66
67 bool render() override;
68 bool forceRasterRender() const override;
69 void setLayerRenderingTimeHint( int time ) override;
70
71 QgsFeedback *feedback() const override { return mFeedback.get(); }
72
73 private:
74 QVector<IndexedPointCloudNode> traverseTree( const QgsPointCloudIndex *pc, const QgsRenderContext &context, IndexedPointCloudNode n, double maxErrorPixels, double nodeErrorPixels );
75 int renderNodesSync( const QVector<IndexedPointCloudNode> &nodes, QgsPointCloudIndex *pc, QgsPointCloudRenderContext &context, QgsPointCloudRequest &request, bool &canceled );
76 int renderNodesAsync( const QVector<IndexedPointCloudNode> &nodes, QgsPointCloudIndex *pc, QgsPointCloudRenderContext &context, QgsPointCloudRequest &request, bool &canceled );
77 int renderNodesSorted( const QVector<IndexedPointCloudNode> &nodes, QgsPointCloudIndex *pc, QgsPointCloudRenderContext &context, QgsPointCloudRequest &request, bool &canceled, Qgis::PointCloudDrawOrder order );
78 void renderTriangulatedSurface( QgsPointCloudRenderContext &context );
79 bool renderIndex( QgsPointCloudIndex *pc );
80
81 QgsPointCloudLayer *mLayer = nullptr;
82 QString mLayerName;
83
84 std::unique_ptr< QgsPointCloudRenderer > mRenderer;
85 std::unique_ptr< QgsPointCloudExtentRenderer > mSubIndexExtentRenderer;
86
87 QgsVector3D mScale;
88 QgsVector3D mOffset;
89 double mZOffset = 0;
90 double mZScale = 1.0;
91
92 QgsPointCloudAttributeCollection mLayerAttributes;
94 QgsGeometry mCloudExtent;
95 QList< QgsMapClippingRegion > mClippingRegions;
96 const QVector< QgsPointCloudSubIndex > mSubIndexes;
97
98 int mRenderTimeHint = 0;
99 bool mBlockRenderUpdates = false;
100 QElapsedTimer mElapsedTimer;
101
102 std::unique_ptr<QgsFeedback> mFeedback = nullptr;
103
104 bool mEnableProfile = false;
105 quint64 mPreparationTime = 0;
106};
107
108#endif // QGSPOINTCLOUDLAYERRENDERER_H
Represents a indexed point cloud node in octree.
PointCloudDrawOrder
Pointcloud rendering order for 2d views.
Definition qgis.h:2918
Base class for feedback objects to be used for cancellation of something running in a worker thread.
Definition qgsfeedback.h:45
A geometry is the spatial representation of a feature.
Base class for utility classes that encapsulate information necessary for rendering of map layers.
virtual bool render()=0
Do the rendering (based on data stored in the class).
virtual bool forceRasterRender() const
Returns true if the renderer must be rendered to a raster paint device (e.g.
virtual void setLayerRenderingTimeHint(int time)
Sets approximate render time (in ms) for the layer to render.
Collection of point cloud attributes.
Represents a indexed point clouds data in octree.
Implementation of threaded rendering for point cloud layers.
QgsFeedback * feedback() const override
Access to feedback object of the layer renderer (may be nullptr)
Represents a map layer supporting display of point clouds.
Encapsulates the render context for a 2D point cloud rendering operation.
Abstract base class for 2d point cloud renderers.
Point cloud data request.
Contains information about the context of a rendering operation.
Class for storage of 3D vectors similar to QVector3D, with the difference that it uses double precisi...
Definition qgsvector3d.h:32