Qt3D Renderer Scene Update Strategy: Difference between revisions
No edit summary |
No edit summary |
||
Line 1: | Line 1: | ||
[[Qt3D | [[Category:Developing_with_Qt::Qt3D]]<br />[[Qt3D_wip_newapi_Overview ]]<br />[toc align_right="yes&quot; depth="3&quot;] | ||
=Qt3D Renderer Scene Update Strategy= | = Qt3D Renderer Scene Update Strategy = | ||
==Backend Rendering classes== | == Backend Rendering classes == | ||
A Backend SceneGraph tree is built from the Frontend SceneGraph Tree.<br /> This allows to monitor the Frontend SceneGraph tree nodes for updates, perform computations in parallel and contiguously order resources in memory. | A Backend SceneGraph tree is built from the Frontend SceneGraph Tree.<br />This allows to monitor the Frontend SceneGraph tree nodes for updates, perform computations in parallel and contiguously order resources in memory. | ||
======== | ==== * RenderNode<br />Maps to : '''Entity''' ==== | ||
* | ==== * RenderCamera<br />Maps to Component : '''CameraLens''' ==== | ||
======== | ==== * MeshData<br />Maps to Component: '''Mesh''' ==== | ||
* | ==== * RenderMaterial<br />Maps to Component: '''Material''' ==== | ||
======== | ==== * RenderTechnique<br />Maps to Node : '''Technique''' ==== | ||
* | ==== * RenderShader<br />Maps to Node : '''ShaderProgram''' ==== | ||
== | == RenderSceneBuilder == | ||
Builds a tree of backend entities from the root of the frontend SceneGraph tree.<br />Recursively traverses the SceneGraph tree.<br />For each Entity traversed, a RenderNode is created.<br />Each entity has a unique id which allows us to retrieve the backend element from a frontend one. | |||
Foreach of the following contained component properties :<br />* Material <s>> creates a '''RenderMaterial'''<br />* CameraLens</s>> creates a '''RenderCamera'''<br />* Mesh <s>> creates a '''MeshData'''<br />* Transform</s>> sets the '''RenderNode localTransform''' matrix to transform<br />* FrameGraph <s>> sets the builds and sets FrameGraphNode tree | |||
<br />'''Things that should change :'''<br />* Check wether RenderEffect and RenderRenderPass classes are needed<br />* QChangeArbiter should monitor updates Transforms, Materials, CameraLens …<br />* Have lazy loading of backend entities | |||
<br />h2. RenderView and RenderCommands | |||
<br />Once the SceneGraph and FrameGraph trees have been populated, the actual rendering can take place. | |||
<br />Before the scene can be rendered, a few computations have to be performed.<br />Those include :<br />* Word transform<br />* Bounding volume<br />* Camera scene culling<br />* Loading meshes that haven' t been loaded yet<br />* Creating a set of rendering command based on the FrameGraph's description | |||
<br />Those computations can easily be performed in parallel and that's where the thread pool and the jobs come in handy. | |||
<br />A few classes act as wrappers around these jobs<br /># LoadMeshDataJobs</s>> one instance per mesh to load<br /># UpdateWorldTransform <s>> one instance in total<br /># UpdateBoudingVolumJob</s>> one instance in total<br /># RenderViewJob <s>> one instance per leaf node of the FrameGraphTree | |||
<br />Each job batch is executed in the order defined above and is dependent on the completion of the batch launched prior to it. | |||
<br />'''Note:''' As these jobs are executed in a thread context that is not the same as the thread owning the QOpenGLContext, none of these jobs can actually perform OpenGL draw calls or OpenGL VAO/VBO initialization / filling. | |||
<br />A '''RenderView''' instance is created for each FrameGraph leaf node.<br />It contains :<br />* Handle to a RenderCamera<br />* Viewport rectangle<br />* TechniqueFilter<br />* RenderPassFilter<br />* An array of RenderCommand | |||
<br />The '''RenderCommand''' class actually contains low level data :<br />* OpenGLVertexArrayObject<br />* QMatrix4x4</s>> world transform matrix<br />* QOpenGLShaderProgram<br />* QUniformPack <s>> uniform names and values to be bound to the shader<br />* MeshData</s>> Mesh data on the CPU side memory<br />* Handle to a RenderMaterial | |||
'''Note:''' This is a temporary description that should evolve quite a bit in the following weeks as we figure out what works, what doesn't, what's missing … | |||
'''Note:''' This is a temporary description that should evolve quite a bit in the following weeks as we figure out what works, what | |||
A '''RenderView''' is filled in a two step process. | A '''RenderView''' is filled in a two step process. | ||
Line 98: | Line 42: | ||
# The Backend SceneGraph tree is culled and RenderCommand are built | # The Backend SceneGraph tree is culled and RenderCommand are built | ||
The Backend SceneGraph tree is recursively traversed.<br /> For each RenderNode: | The Backend SceneGraph tree is recursively traversed.<br />For each RenderNode:<br />* If there is a MeshData indexed using the same Entity Uuid as the current RenderNode<br />'''''' Set the RenderCommand's MeshData to of the MeshData<br />'''''' Set the RenderCommand's matrix to the RenderNode's worldTransformMatrix<br />'''''' Set the Material handle to to the handle indexed by the Entity Uuid | ||
* If there is a MeshData indexed using the same Entity Uuid as the current RenderNode | |||
Each RenderView object once filled is inserted in order in a temporary queue owned by a QCircularBuffer. When the number of required RenderView instances for a frame is reached, this process is repeated with a new empty queue. | Each RenderView object once filled is inserted in order in a temporary queue owned by a QCircularBuffer. When the number of required RenderView instances for a frame is reached, this process is repeated with a new empty queue. | ||
===What should change | === What should change === | ||
* | * Once a MeshData has been uploaded to the VAO/VBO once, this could be freed and removed from a RenderCommand. | ||
** | * Have a way to store VAO/VBO pointer | ||
* See what has to be done improved so that memory reordering doesn't affect the process of building the RenderCommand objects |
Revision as of 10:35, 24 February 2015
Qt3D_wip_newapi_Overview
[toc align_right="yes" depth="3"]
Qt3D Renderer Scene Update Strategy
Backend Rendering classes
A Backend SceneGraph tree is built from the Frontend SceneGraph Tree.
This allows to monitor the Frontend SceneGraph tree nodes for updates, perform computations in parallel and contiguously order resources in memory.
* RenderNode
Maps to : Entity
* RenderCamera
Maps to Component : CameraLens
* MeshData
Maps to Component: Mesh
* RenderMaterial
Maps to Component: Material
* RenderTechnique
Maps to Node : Technique
* RenderShader
Maps to Node : ShaderProgram
RenderSceneBuilder
Builds a tree of backend entities from the root of the frontend SceneGraph tree.
Recursively traverses the SceneGraph tree.
For each Entity traversed, a RenderNode is created.
Each entity has a unique id which allows us to retrieve the backend element from a frontend one.
Foreach of the following contained component properties :
* Material > creates a RenderMaterial> creates a RenderCamera
* CameraLens
* Mesh > creates a MeshData> sets the RenderNode localTransform matrix to transform
* Transform
* FrameGraph > sets the builds and sets FrameGraphNode tree
> one instance per mesh to load
Things that should change :
* Check wether RenderEffect and RenderRenderPass classes are needed
* QChangeArbiter should monitor updates Transforms, Materials, CameraLens …
* Have lazy loading of backend entities
h2. RenderView and RenderCommands
Once the SceneGraph and FrameGraph trees have been populated, the actual rendering can take place.
Before the scene can be rendered, a few computations have to be performed.
Those include :
* Word transform
* Bounding volume
* Camera scene culling
* Loading meshes that haven' t been loaded yet
* Creating a set of rendering command based on the FrameGraph's description
Those computations can easily be performed in parallel and that's where the thread pool and the jobs come in handy.
A few classes act as wrappers around these jobs
# LoadMeshDataJobs
# UpdateWorldTransform > one instance in total> one instance in total
# UpdateBoudingVolumJob
# RenderViewJob > one instance per leaf node of the FrameGraphTree
> world transform matrix
Each job batch is executed in the order defined above and is dependent on the completion of the batch launched prior to it.
Note: As these jobs are executed in a thread context that is not the same as the thread owning the QOpenGLContext, none of these jobs can actually perform OpenGL draw calls or OpenGL VAO/VBO initialization / filling.
A RenderView instance is created for each FrameGraph leaf node.
It contains :
* Handle to a RenderCamera
* Viewport rectangle
* TechniqueFilter
* RenderPassFilter
* An array of RenderCommand
The RenderCommand class actually contains low level data :
* OpenGLVertexArrayObject
* QMatrix4x4
* QOpenGLShaderProgram
* QUniformPack > uniform names and values to be bound to the shader> Mesh data on the CPU side memory
* MeshData
* Handle to a RenderMaterial
Note: This is a temporary description that should evolve quite a bit in the following weeks as we figure out what works, what doesn't, what's missing …
A RenderView is filled in a two step process.
- The Backend FrameGraph tree is traversed from the leaf node to the root. This allows to retrieve the camera, viewport, technique and renderpass filters.
- The Backend SceneGraph tree is culled and RenderCommand are built
The Backend SceneGraph tree is recursively traversed.
For each RenderNode:
* If there is a MeshData indexed using the same Entity Uuid as the current RenderNode
' Set the RenderCommand's MeshData to of the MeshData
' Set the RenderCommand's matrix to the RenderNode's worldTransformMatrix
' Set the Material handle to to the handle indexed by the Entity Uuid
Each RenderView object once filled is inserted in order in a temporary queue owned by a QCircularBuffer. When the number of required RenderView instances for a frame is reached, this process is repeated with a new empty queue.
What should change
- Once a MeshData has been uploaded to the VAO/VBO once, this could be freed and removed from a RenderCommand.
- Have a way to store VAO/VBO pointer
- See what has to be done improved so that memory reordering doesn't affect the process of building the RenderCommand objects