This file is indexed.

/usr/share/qt5/doc/qtquick/qtquick-visualcanvas-scenegraph.html is in qtdeclarative5-doc-html 5.2.1-3ubuntu15.

This file is owned by root:root, with mode 0o644.

The actual contents of the file can be viewed below.

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en_US" lang="en_US">
<head>
  <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<!-- scenegraph.qdoc -->
  <title>Qt Quick Scene Graph | QtQuick 5.2</title>
  <link rel="stylesheet" type="text/css" href="style/offline.css" />
</head>
<body>
<div class="header" id="qtdocheader">
    <div class="main">
    <div class="main-rounded">
        <div class="navigationbar">
        <ul>
<li>Qt 5.2</li>
<li><a href="qtquick-index.html">Qt Quick</a></li>
<li>Qt Quick Scene Graph</li>
<li id="buildversion">
Qt 5.2.1 Reference Documentation</li>
    </ul>
    </div>
</div>
<div class="content">
<div class="line">
<div class="content mainContent">
<div class="toc">
<h3><a name="toc">Contents</a></h3>
<ul>
<li class="level1"><a href="#the-scene-graph-in-qt-quick">The Scene Graph in Qt Quick</a></li>
<li class="level1"><a href="#qt-quick-scene-graph-structure">Qt Quick Scene Graph Structure</a></li>
<li class="level2"><a href="#nodes">Nodes</a></li>
<li class="level3"><a href="#preprocessing">Preprocessing</a></li>
<li class="level3"><a href="#node-ownership">Node Ownership</a></li>
<li class="level2"><a href="#materials">Materials</a></li>
<li class="level2"><a href="#convenience-nodes">Convenience Nodes</a></li>
<li class="level1"><a href="#scene-graph-and-rendering">Scene Graph and Rendering</a></li>
<li class="level2"><a href="#threaded-render-loop">Threaded Render Loop</a></li>
<li class="level2"><a href="#non-threaded-render-loop">Non-threaded Render Loop</a></li>
<li class="level2"><a href="#mixing-scene-graph-and-opengl">Mixing Scene Graph and OpenGL</a></li>
<li class="level2"><a href="#custom-items-using-qpainter">Custom Items using QPainter</a></li>
<li class="level1"><a href="#scene-graph-backend">Scene Graph Backend</a></li>
</ul>
</div>
<h1 class="title">Qt Quick Scene Graph</h1>
<span class="subtitle"></span>
<!-- $$$qtquick-visualcanvas-scenegraph.html-description -->
<div class="descr"> <a name="details"></a>
<a name="the-scene-graph-in-qt-quick"></a>
<h2>The Scene Graph in Qt Quick</h2>
<p>Qt Quick 2 makes use of a dedicated scene graph based on OpenGL ES 2.0 or OpenGL 2.0 for its rendering. Using a scene graph for graphics rather than the traditional imperative painting systems (QPainter and similar), means the scene to be rendered can be retained between frames and the complete set of primitives to render is known before rendering starts. This opens up for a number of optimizations, such as batch rendering to minimize state changes and discarding obscured primitives.</p>
<p>For example, say a user-interface contains a list of ten items where each item has a background color, an icon and a text. Using the traditional drawing techniques, this would result in 30 draw calls and a similar amount of state changes. A scene graph, on the other hand, could reorganize the primitives to render such that all backgrounds are drawn in one call, then all icons, then all the text, reducing the total amount of draw calls to only 3. Batching and state change reduction like this can greatly improve performance on some hardware.</p>
<p>The scene graph is closely tied to Qt Quick 2.0 and can not be used stand-alone. The scene graph is managed and rendered by the <a href="qquickwindow.html">QQuickWindow</a> class and custom Item types can add their graphical primitives into the scene graph through a call to <a href="qquickitem.html#updatePaintNode">QQuickItem::updatePaintNode</a>().</p>
<p>The scene graph is a graphical representation of the Item scene, an independent structure that contains enough information to render all the items. Once it has been set up, it can be manipulated and rendered independently of the state of the items. On many platforms, the scene graph will even be rendered on a dedicated render thread while the GUI thread is preparing the next frame's state.</p>
<a name="qt-quick-scene-graph-structure"></a>
<h2>Qt Quick Scene Graph Structure</h2>
<p>The scene graph is composed of a number of predefined node types, each serving a dedicated purpose. Although we refer to it as a scene graph, a more precise definition is node tree. The tree is built from <a href="qquickitem.html">QQuickItem</a> types in the QML scene and internally the scene is then processed by a renderer which draws the scene. The nodes themselves do <b>not</b> contain any active drawing code nor virtual <tt>paint()</tt> function.</p>
<p>Even though the node tree is mostly built internally by the existing Qt Quick QML types, it is possible for users to also add complete subtrees with their own content, including subtrees that represent 3D models.</p>
<a name="nodes"></a>
<h3>Nodes</h3>
<p>The most important node for users is the <a href="qsggeometrynode.html">QSGGeometryNode</a>. It is used to define custom graphics by defining its geometry and material. The geometry is defined using <a href="qsggeometry.html">QSGGeometry</a> and describes the shape or mesh of the graphical primitive. It can be a line, a rectangle, a polygon, many disconnected rectangles, or complex 3D mesh. The material defines how the pixels in this shape are filled.</p>
<p>A node can have any number of children and geometry nodes will be rendered so they appear in child-order with parents behind their children.</p>
<p><b>Note: </b>This does not say anything about the actual rendering order in the renderer. Only the visual output is guaranteed.</p><p>The available nodes are: <table class="annotated">
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgnode.html">QSGNode</a></p></td><td class="tblDescr"><p>The base class for all nodes in the scene graph</p></td></tr>
<tr class="even topAlign"><td class="tblName"><p><a href="qsggeometrynode.html">QSGGeometryNode</a></p></td><td class="tblDescr"><p>Used for all rendered content in the scene graph</p></td></tr>
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgclipnode.html">QSGClipNode</a></p></td><td class="tblDescr"><p>Implements the clipping functionality in the scene graph</p></td></tr>
<tr class="even topAlign"><td class="tblName"><p><a href="qsgtransformnode.html">QSGTransformNode</a></p></td><td class="tblDescr"><p>Implements transformations in the scene graph</p></td></tr>
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgopacitynode.html">QSGOpacityNode</a></p></td><td class="tblDescr"><p>Used to change opacity of nodes</p></td></tr>
</table>
</p>
<p>Custom nodes are added to the scene graph by subclassing <a href="qquickitem.html#updatePaintNode">QQuickItem::updatePaintNode</a>() and setting the <a href="qquickitem.html#Flag-enum">QQuickItem::ItemHasContents</a> flag.</p>
<p><b>Warning:</b> It is crucial that OpenGL operations and interaction with the scene graph happens exclusively on the render thread, primarily during the updatePaintNode() call. The rule of thumb is to only use classes with the &quot;QSG&quot; prefix inside the <a href="qquickitem.html#updatePaintNode">QQuickItem::updatePaintNode</a>() function.</p>
<p>For more details, see the <a href="qtquick-scenegraph-customgeometry-example.html">Scene Graph - Custom Geometry</a>.</p>
<a name="preprocessing"></a>
<h4>Preprocessing</h4>
<p>Nodes have a virtual <a href="qsgnode.html#preprocess">QSGNode::preprocess</a>() function, which will be called before the scene graph is rendered. Node subclasses can set the flag <a href="qsgnode.html#Flag-enum">QSGNode::UsePreprocess</a> and override the <a href="qsgnode.html#preprocess">QSGNode::preprocess</a>() function to do final preparation of their node. For example, dividing a bezier curve into the correct level of detail for the current scale factor or updating a section of a texture.</p>
<a name="node-ownership"></a>
<h4>Node Ownership</h4>
<p>Ownership of the nodes is either done explicitly by the creator or by the scene graph by setting the flag <a href="qsgnode.html#Flag-enum">QSGNode::OwnedByParent</a>. Assigning ownership to the scene graph is often preferable as it simplifies cleanup when the scene graph lives outside the GUI thread.</p>
<a name="materials"></a>
<h3>Materials</h3>
<p>The material describes how the interior of a geometry in a <a href="qsggeometrynode.html">QSGGeometryNode</a> is filled. It encapsulates an OpenGL shader program and provides ample flexibility in what can be achieved, though most of the Qt Quick items themselves only use very basic materials, such as solid color and texture fills.</p>
<p>For users who just want to apply custom shading to a QML Item type, it is possible to do this directly in QML using the <a href="qml-qtquick-shadereffect.html">ShaderEffect</a> type.</p>
<p>Below is a complete list of material classes: <table class="annotated">
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgmaterialshader.html">QSGMaterialShader</a></p></td><td class="tblDescr"><p>Represents an OpenGL shader program in the renderer</p></td></tr>
<tr class="even topAlign"><td class="tblName"><p><a href="qsgmaterialtype.html">QSGMaterialType</a></p></td><td class="tblDescr"><p>Used as a unique type token in combination with QSGMaterial</p></td></tr>
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgmaterial.html">QSGMaterial</a></p></td><td class="tblDescr"><p>Encapsulates rendering state for a shader program</p></td></tr>
<tr class="even topAlign"><td class="tblName"><p><a href="qsgflatcolormaterial.html">QSGFlatColorMaterial</a></p></td><td class="tblDescr"><p>Convenient way of rendering solid colored geometry in the scene graph</p></td></tr>
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgsimplematerialshader.html">QSGSimpleMaterialShader</a></p></td><td class="tblDescr"><p>Convenient way of building custom materials for the scene graph</p></td></tr>
<tr class="even topAlign"><td class="tblName"><p><a href="qsgsimplematerial.html">QSGSimpleMaterial</a></p></td><td class="tblDescr"><p>Template generated class used to store the state used with a QSGSimpleMateralShader</p></td></tr>
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgopaquetexturematerial.html">QSGOpaqueTextureMaterial</a></p></td><td class="tblDescr"><p>Convenient way of rendering textured geometry in the scene graph</p></td></tr>
<tr class="even topAlign"><td class="tblName"><p><a href="qsgtexturematerial.html">QSGTextureMaterial</a></p></td><td class="tblDescr"><p>Convenient way of rendering textured geometry in the scene graph</p></td></tr>
<tr class="odd topAlign"><td class="tblName"><p><a href="qsgvertexcolormaterial.html">QSGVertexColorMaterial</a></p></td><td class="tblDescr"><p>Convenient way of rendering per-vertex colored geometry in the scene graph</p></td></tr>
</table>
</p>
<p>For more details, see the <a href="qtquick-scenegraph-simplematerial-example.html">Scene Graph - Simple Material</a></p>
<a name="convenience-nodes"></a>
<h3>Convenience Nodes</h3>
<p>The scene graph API is very low-level and focuses on performance rather than convenience. Writing custom geometries and materials from scratch, even the most basic ones, requires a non-trivial amount of code. For this reason, the API includes a few convenience classes to make the most common custom nodes readily available.</p>
<ul>
<li><a href="qsgsimplerectnode.html">QSGSimpleRectNode</a> - a <a href="qsggeometrynode.html">QSGGeometryNode</a> subclass which defines a rectangular geometry with a solid color material.</li>
<li><a href="qsgsimpletexturenode.html">QSGSimpleTextureNode</a> - a <a href="qsggeometrynode.html">QSGGeometryNode</a> subclass which defines a rectangular geometry with a texture material.</li>
</ul>
<a name="scene-graph-and-rendering"></a>
<h2>Scene Graph and Rendering</h2>
<p>The rendering of the scene graph happens internally in the <a href="qquickwindow.html">QQuickWindow</a> class, and there is no public API to access it. There are however, a few places in the rendering pipeline where the user can attach application code. This can be to add custom scene graph content or render raw OpenGL content. The integration points are defined by the render loop.</p>
<p>For detailed description of how the scene graph renderer works, see <a href="qtquick-visualcanvas-scenegraph-renderer.html">Qt Quick Scene Graph Renderer</a>.</p>
<a name="threaded-render-loop"></a>
<h3>Threaded Render Loop</h3>
<p>On many configurations, the scene graph rendering will happen on a dedicated render thread. This is done to increase parallelism of multi-core processors and make better use of stall times such as waiting for a blocking swap buffer call. This offers significant performance improvements, but imposes certain restrictions on where and when interaction with the scene graph can happen.</p>
<p>The following is a simple outline of how a frame gets composed with the threaded render loop.</p>
<p class="centerAlign"><img src="images/sg-renderloop-threaded.jpg" alt="" /></p><ol class="1">
<li>A change occurs in the QML scene, causing <tt>QQuickItem::update()</tt> to be called. This can be the result of for instance an animation or user input. An event is posted to the render thread to initiate a new frame.</li>
<li>The render thread prepares to draw a new frame and makes the OpenGL context current and initiates a blocks on the GUI thread.</li>
<li>While the render thread is preparing the new frame, the GUI thread calls <a href="qquickitem.html#updatePolish">QQuickItem::updatePolish</a>() to do final touch-up of items before they are rendered.</li>
<li>GUI thread is blocked.</li>
<li>The <a href="qquickwindow.html#beforeSynchronizing">QQuickWindow::beforeSynchronizing</a>() signal is emitted. Applications can make direct connections (using Qt::DirectConnection) to this signal to do any preparation required before calls to <a href="qquickitem.html#updatePaintNode">QQuickItem::updatePaintNode</a>().</li>
<li>Synchronization of the QML state into the scene graph. This is done by calling the <a href="qquickitem.html#updatePaintNode">QQuickItem::updatePaintNode</a>() function on all items that have changed since the previous frame. This is the only time the QML items and the nodes in the scene graph interact.</li>
<li>GUI thread block is released.</li>
<li>The scene graph is rendered:<ol class="1">
<li>The <a href="qquickwindow.html#beforeRendering">QQuickWindow::beforeRendering</a>() signal is emitted. Applications can make direct connections (using Qt::DirectConnection) to this signal to use custom OpenGL calls which will then stack visually beneath the QML scene.</li>
<li>Items that have specified <a href="qsgnode.html#Flag-enum">QSGNode::UsePreprocess</a>, will have their <a href="qsgnode.html#preprocess">QSGNode::preprocess</a>() function invoked.</li>
<li>The renderer processes the nodes and calls OpenGL functions.</li>
<li>The <a href="qquickwindow.html#afterRendering">QQuickWindow::afterRendering</a>() signal is emitted. Applications can make direct connections (using Qt::DirectConnection) to this signal to use custom OpenGL calls which will then stack visually over the QML scene.</li>
<li>The rendered frame is swapped and <a href="qquickwindow.html#frameSwapped">QQuickWindow::frameSwapped</a>() is emitted.</li>
</ol>
</li>
<li>While the render thread is rendering, the GUI is free to advance animations, process events, etc.</li>
</ol>
<p>The threaded renderer is currently used by default on Linux, Mac OS X and EGLFS based QPA platforms, but this is subject to change. It is possible to force use of the threaded renderer by setting <tt>QML_FORCE_THREADED_RENDERER=1</tt> in the environment.</p>
<a name="non-threaded-render-loop"></a>
<h3>Non-threaded Render Loop</h3>
<p>The non-threaded render loop is currently used by default on Windows and non-EGLFS based embedded platforms. This is mostly a precautionary measure, as not all combinations of OpenGL drivers and windowing systems have been tested.</p>
<p>Even when using the non-threaded render loop, you should write your code as if you are using the threaded renderer, as failing to do so will make the code non-portable.</p>
<p>The following is a simplified illustration of the frame rendering sequence in the non-threaded renderer.</p>
<p class="centerAlign"><img src="images/sg-renderloop-singlethreaded.jpg" alt="" /></p><a name="mixing-scene-graph-and-opengl"></a>
<h3>Mixing Scene Graph and OpenGL</h3>
<p>The scene graph offers two methods for integrating OpenGL content: by calling OpenGL commands directly and by creating a textured node in the scene graph.</p>
<p>By connecting to the <a href="qquickwindow.html#beforeRendering">QQuickWindow::beforeRendering</a>() and <a href="qquickwindow.html#afterRendering">QQuickWindow::afterRendering</a>() signals, applications can make OpenGL calls directly into the same context as the scene graph is rendering to. As the signal names indicate, the user can then render OpenGL content either under a Qt Quick scene or over it. The benefit of integrating in this manner is that no extra framebuffer nor memory is needed to perform the rendering. The downside is that Qt Quick decides when to call the signals and this is the only time the OpenGL application is allowed to draw.</p>
<p>The <a href="qtquick-scenegraph-openglunderqml-example.html">Scene Graph - OpenGL Under QML</a> example gives an example on how to use use these signals.</p>
<p>The other alternative is to create a <a href="qquickframebufferobject.html">QQuickFramebufferObject</a>, render into it, and let it be displayed in the scene graph as a texture. The <a href="qtquick-scenegraph-textureinsgnode-example.html">Scene Graph - Rendering FBOs</a> example shows how this can be done. It is also possible to combine multiple rendering contexts and multiple threads to create content to be displayed in the scene graph. The <a href="qtquick-scenegraph-textureinthread-example.html">Scene Graph - Rendering FBOs in a thread</a> examples show how this can be done.</p>
<p><b>Warning:</b> When mixing OpenGL content with scene graph rendering, it is important the application does not leave the OpenGL context in a state with buffers bound, attributes enabled, special values in the z-buffer or stencil-buffer or similar. Doing so can result in unpredictable behavior.</p>
<p><b>Warning:</b> The OpenGL rendering code must be thread aware, as the rendering might be happening outside the GUI thread.</p>
<a name="custom-items-using-qpainter"></a>
<h3>Custom Items using QPainter</h3>
<p>The <a href="qquickitem.html">QQuickItem</a> provides a subclass, <a href="qquickpainteditem.html">QQuickPaintedItem</a>, which allows the users to render content using QPainter.</p>
<p><b>Warning:</b> Using <a href="qquickpainteditem.html">QQuickPaintedItem</a> uses an indirect 2D surface to render its content, either using software rasterization or using an OpenGL framebuffer object (FBO), so the rendering is a two-step operation. First rasterize the surface, then draw the surface. Using scene graph API directly is always significantly faster.</p>
<a name="scene-graph-backend"></a>
<h2>Scene Graph Backend</h2>
<p>In addition to the public API, the scene graph has an adaptation layer which opens up the implementation to do hardware specific adaptations. This is an undocumented, internal and private plugin API, which lets hardware adaptation teams make the most of their hardware. It includes:</p>
<ul>
<li>Custom textures; specifically the implementation of QQuickWindow::createTextureFromImage and the internal representation of the texture used by <a href="qml-qtquick-image.html">Image</a> and <a href="qml-qtquick-borderimage.html">BorderImage</a> types.</li>
<li>Custom renderer; the adaptation layer lets the plugin decide how the scene graph is traversed and rendered, making it possible to optimize the rendering algorithm for a specific hardware or to make use of extensions which improve performance.</li>
<li>Custom scene graph implementation of many of the default QML types, including its text and font rendering.</li>
<li>Custom animation driver; allows the animation system to hook into the low-level display vertical refresh to get smooth rendering.</li>
<li>Custom render loop; allows better control over how QML deals with multiple windows.</li>
</ul>
</div>
<!-- @@@qtquick-visualcanvas-scenegraph.html -->
        </div>
       </div>
   </div>
   </div>
</div>
<div class="footer">
   <p>
   <acronym title="Copyright">&copy;</acronym> 2013 Digia Plc and/or its
   subsidiaries. Documentation contributions included herein are the copyrights of
   their respective owners.<br>    The documentation provided herein is licensed under the terms of the    <a href="http://www.gnu.org/licenses/fdl.html">GNU Free Documentation    License version 1.3</a> as published by the Free Software Foundation.<br>    Digia, Qt and their respective logos are trademarks of Digia Plc     in Finland and/or other countries worldwide. All other trademarks are property
   of their respective owners. </p>
</div>
</body>
</html>