16#include <Qt3DCore/QAspectEngine>
17#include <Qt3DCore/QEntity>
18#if QT_VERSION >= QT_VERSION_CHECK( 6, 0, 0 )
19#include <Qt3DCore/QCoreAspect>
21#include <Qt3DExtras/QForwardRenderer>
22#include <Qt3DRender/QRenderSettings>
23#include <Qt3DRender/QRenderAspect>
24#include <Qt3DInput/QInputAspect>
25#include <Qt3DInput/QInputSettings>
26#include <Qt3DLogic/QLogicAspect>
27#include <Qt3DRender/QCamera>
28#include <Qt3DLogic/QFrameAction>
40#include "moc_qgs3dmapcanvas.cpp"
44 : m_aspectEngine( new
Qt3DCore::QAspectEngine )
45 , m_renderAspect( new
Qt3DRender::QRenderAspect )
46 , m_inputAspect( new
Qt3DInput::QInputAspect )
47 , m_logicAspect( new
Qt3DLogic::QLogicAspect )
48 , m_renderSettings( new
Qt3DRender::QRenderSettings )
50 , m_inputSettings( new
Qt3DInput::QInputSettings )
52 , m_userRoot( nullptr )
53 , m_initialized( false )
55 setSurfaceType( QSurface::OpenGLSurface );
58#if QT_VERSION >= QT_VERSION_CHECK( 6, 0, 0 )
59 m_aspectEngine->registerAspect(
new Qt3DCore::QCoreAspect );
61 m_aspectEngine->registerAspect( m_renderAspect );
62 m_aspectEngine->registerAspect( m_inputAspect );
63 m_aspectEngine->registerAspect( m_logicAspect );
65 m_defaultCamera->setParent( m_root );
66 m_inputSettings->setEventSource(
this );
72 image.save( mCaptureFileName, mCaptureFileFormat.toLocal8Bit().data() );
77 setCursor( Qt::OpenHandCursor );
78 installEventFilter(
this );
86 mScene->deleteLater();
88 mMapSettings->deleteLater();
89 mMapSettings =
nullptr;
90 qDeleteAll( mHighlights );
93 delete m_aspectEngine;
98 if ( m_userRoot != root )
101 m_userRoot->setParent(
static_cast<Qt3DCore::QNode *
>(
nullptr ) );
103 root->setParent( m_root );
115 return m_renderSettings->activeFrameGraph();
120 return m_defaultCamera;
125 return m_renderSettings;
130 if ( !m_initialized )
132 m_root->addComponent( m_renderSettings );
133 m_root->addComponent( m_inputSettings );
134 m_aspectEngine->setRootEntity( Qt3DCore::QEntityPtr( m_root ) );
136 m_initialized =
true;
138 QWindow::showEvent( e );
143 m_defaultCamera->setAspectRatio(
float( width() ) / std::max( 1.f,
static_cast<float>( height() ) ) );
151 Q_ASSERT( !mMapSettings );
161 mScene->deleteLater();
174 QCursor::setPos( mapToGlobal( point ) );
204 const float worldX = center.
x() - mMapSettings->
origin().
x();
205 const float worldY = center.
y() - mMapSettings->
origin().
y();
211 if ( !mScene || fileName.isEmpty() )
214 mCaptureFileName = fileName;
215 mCaptureFileFormat = fileFormat;
218 Qt3DLogic::QFrameAction *screenCaptureFrameAction =
new Qt3DLogic::QFrameAction;
219 mScene->addComponent( screenCaptureFrameAction );
221 connect( screenCaptureFrameAction, &Qt3DLogic::QFrameAction::triggered,
this, [=](
float ) {
223 mScene->removeComponent( screenCaptureFrameAction );
224 screenCaptureFrameAction->deleteLater();
228void Qgs3DMapCanvas::captureDepthBuffer()
234 Qt3DLogic::QFrameAction *screenCaptureFrameAction =
new Qt3DLogic::QFrameAction;
235 mScene->addComponent( screenCaptureFrameAction );
237 connect( screenCaptureFrameAction, &Qt3DLogic::QFrameAction::triggered,
this, [=](
float ) {
239 mScene->removeComponent( screenCaptureFrameAction );
240 screenCaptureFrameAction->deleteLater();
249 if ( tool == mMapTool )
253 if ( mMapTool && !tool )
256 setCursor( Qt::OpenHandCursor );
258 else if ( !mMapTool && tool )
271 setCursor( mMapTool->
cursor() );
277 if ( watched !=
this )
280 if ( event->type() == QEvent::ShortcutOverride )
296 switch ( event->type() )
298 case QEvent::MouseButtonPress:
301 case QEvent::MouseButtonRelease:
304 case QEvent::MouseMove:
307 case QEvent::KeyPress:
308 mMapTool->
keyPressEvent(
static_cast<QKeyEvent *
>( event ) );
318 if ( mTemporalController )
321 mTemporalController = temporalController;
325void Qgs3DMapCanvas::updateTemporalRange(
const QgsDateTimeRange &temporalrange )
361 if ( !mHighlights.contains( layer ) )
367 band->setColor( color );
368 band->setMarkerType( QgsRubberBand3D::MarkerType::Square );
371 band->setWidth( pcRenderer->symbol()->pointSize() + 1 );
373 mHighlights.insert( layer, band );
377 mHighlights[layer]->addPoint( pt );
380void Qgs3DMapCanvas::updateHighlightSizes()
382 if (
QgsMapLayer *layer = qobject_cast<QgsMapLayer *>( sender() ) )
386 if ( mHighlights.contains( layer ) )
388 mHighlights[layer]->setWidth( rnd->symbol()->pointSize() + 1 );
396 for (
auto it = mHighlights.keyBegin(); it != mHighlights.keyEnd(); it++ )
401 qDeleteAll( mHighlights );
static const QColor DEFAULT_HIGHLIGHT_COLOR
Default highlight color.
NavigationMode
The navigation mode used by 3D cameras.
@ PointCloud
Point cloud layer. Added in QGIS 3.18.
void saveAsImage(const QString &fileName, const QString &fileFormat)
Saves the current scene as an image.
QVector< QgsPointXY > viewFrustum2DExtent()
Calculates the 2D extent viewed by the 3D camera as the vertices of the viewed trapezoid.
Qgs3DMapSettings * mapSettings()
Returns access to the 3D scene configuration.
void setTemporalController(QgsTemporalController *temporalController)
Sets the temporal controller.
void mapSettingsChanged()
Emitted when the the map setting is changed.
Qt3DRender::QCamera * camera() const
Returns the default camera of the 3D Window.
void viewed2DExtentFrom3DChanged(QVector< QgsPointXY > extent)
Emitted when the viewed 2D extent seen by the 3D camera has changed.
void fpsCountChanged(float fpsCount)
Emitted when the FPS count changes (at most every frame)
void setRootEntity(Qt3DCore::QEntity *root)
Sets the specified root entity of the scene.
void setViewFromTop(const QgsPointXY ¢er, float distance, float rotation=0)
Sets camera position to look down at the given point (in map coordinates) in given distance from plan...
void setActiveFrameGraph(Qt3DRender::QFrameGraphNode *activeFrameGraph)
Activates the specified activeFrameGraph.
void setMapSettings(Qgs3DMapSettings *mapSettings)
Configure map scene being displayed. Takes ownership.
void showEvent(QShowEvent *e) override
Manages the display events specified in e.
void cameraNavigationSpeedChanged(double speed)
Emitted when the camera navigation speed is changed.
Qt3DRender::QRenderSettings * renderSettings() const
Returns the render settings of the 3D Window.
Qt3DRender::QFrameGraphNode * activeFrameGraph() const
Returns the node of the active frame graph.
void setMapTool(Qgs3DMapTool *tool)
Sets the active map tool that will receive events from the 3D canvas.
void setViewFrom2DExtent(const QgsRectangle &extent)
Resets camera view to show the extent (top view)
void resizeEvent(QResizeEvent *) override
Resets the aspect ratio of the 3D window.
void highlightFeature(const QgsFeature &feature, QgsMapLayer *layer)
Highlights a feature from layer using a QgsRubberBand3D.
void resetView()
Resets camera position to the default: looking down at the origin of world coordinates.
void savedAsImage(const QString &fileName)
Emitted when the 3D map canvas was successfully saved as image.
void clearHighlights()
Clears all QgsRubberBand3D highlights.
void fpsCounterEnabledChanged(bool enabled)
Emitted when the FPS counter is enabled or disabeld.
QgsCameraController * cameraController()
Returns access to the view's camera controller. Returns nullptr if the scene has not been initialized...
bool eventFilter(QObject *watched, QEvent *event) override
void viewed2DExtentFrom3DChanged(QVector< QgsPointXY > extent)
Emitted when the viewed 2D extent seen by the 3D camera has changed.
void fpsCountChanged(float fpsCount)
Emitted when the FPS count changes.
void setViewFrom2DExtent(const QgsRectangle &extent)
Resets camera view to show the extent extent (top view)
QgsCameraController * cameraController() const
Returns camera controller.
void updateTemporal()
Updates the temporale entities.
void fpsCounterEnabledChanged(bool fpsCounterEnabled)
Emitted when the FPS counter is activated or deactivated.
QVector< QgsPointXY > viewFrustum2DExtent() const
Calculates the 2D extent viewed by the 3D camera as the vertices of the viewed trapezoid.
void viewZoomFull()
Resets camera view to show the whole scene (top view)
void setCameraNavigationMode(Qgis::NavigationMode navigationMode)
Sets the navigation mode for the camera.
void setCameraMovementSpeed(double movementSpeed)
Sets the camera movement speed.
QgsVector3D origin() const
Returns coordinates in map CRS at which 3D scene has origin (0,0,0).
void requestCaptureImage()
Starts a request for an image rendered by the engine.
void requestDepthBufferCapture()
Starts a request for an image containing the depth buffer data of the engine.
void imageCaptured(const QImage &image)
Emitted after a call to requestCaptureImage() to return the captured image.
void depthBufferCaptured(const QImage &image)
Emitted after a call to requestDepthBufferCapture() to return the captured depth buffer.
void setRenderCaptureEnabled(bool enabled)
Sets whether it will be possible to render to an image.
QgsFrameGraph * frameGraph()
Returns the shadow rendering frame graph object used to render the scene.
void navigationModeChanged(Qgis::NavigationMode mode)
Emitted when the navigation mode is changed using the hotkey ctrl + ~.
void requestDepthBufferCapture()
Emitted to ask for the depth buffer image.
void cameraMovementSpeedChanged(double speed)
Emitted whenever the camera movement speed is changed by the controller.
void setViewFromTop(float worldX, float worldY, float distance, float yaw=0)
Sets camera to look down towards given point in world coordinate, in given distance from plane with z...
void depthBufferCaptured(const QImage &depthImage)
Sets the depth buffer image used by the camera controller to calculate world position from a pixel's ...
void setCursorPosition(QPoint point)
Emitted when the mouse cursor position should be moved to the specified point on the map viewport.
The feature class encapsulates a single feature including its unique ID, geometry and a list of field...
Qt3DCore::QEntity * rubberBandsRootEntity()
Returns entity for all rubber bands (to show them always on top)
A geometry is the spatial representation of a feature.
QgsPoint vertexAt(int atVertex) const
Returns coordinates of a vertex.
Base class for all map layer types.
QgsAbstract3DRenderer * renderer3D() const
Returns 3D renderer associated with the layer.
void renderer3DChanged()
Signal emitted when 3D renderer associated with the layer has changed.
3D renderer that renders all points from a point cloud layer
A class to represent a 2D point.
Point geometry type, with support for z-dimension and m-values.
A rectangle specified with double values.
This class is a composition of two QSettings instances:
QVariant value(const QString &key, const QVariant &defaultValue=QVariant(), Section section=NoSection) const
Returns the value for setting key.
A controller base class for temporal objects, contains a signal for notifying updates of the objects ...
void updateTemporalRange(const QgsDateTimeRange &range)
Signals that a temporal range has changed and needs to be updated in all connected objects.
void setTemporalRange(const QgsDateTimeRange &range)
Sets the temporal range for the object.
double y() const
Returns Y coordinate.
double x() const
Returns X coordinate.
void setRootEntity(Qt3DCore::QEntity *root) override
Sets root entity of the 3D scene.
void setSize(QSize s) override
Sets the size of the rendering area (in pixels)