/usr/share/qt5/doc/qtquick/qsggeometrynode.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 | <?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" />
<!-- qsgnode.cpp -->
<title>QSGGeometryNode Class | 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><a href="qtquick-module.html">C++ Classes</a></li>
<li>QSGGeometryNode</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="#public-functions">Public Functions</a></li>
<li class="level1"><a href="#details">Detailed Description</a></li>
</ul>
</div>
<h1 class="title">QSGGeometryNode Class</h1>
<!-- $$$QSGGeometryNode-brief -->
<p>The QSGGeometryNode class is used for all rendered content in the scene graph. <a href="#details">More...</a></p>
<!-- @@@QSGGeometryNode -->
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> Header:</td><td class="memItemRight bottomAlign"> </b><tt><span class="preprocessor">#include <QSGGeometryNode></span>
</tt></td></tr><tr><td class="memItemLeft rightAlign topAlign"> qmake:</td><td class="memItemRight bottomAlign"> <tt>QT += quick</tt></td></tr><tr><td class="memItemLeft rightAlign topAlign"> Inherits:</td><td class="memItemRight bottomAlign"> <a href="qsgbasicgeometrynode.html">QSGBasicGeometryNode</a>.</td></tr><tr><td class="memItemLeft rightAlign topAlign"> Inherited By:</td><td class="memItemRight bottomAlign"> <p><a href="qsgsimplerectnode.html">QSGSimpleRectNode</a> and <a href="qsgsimpletexturenode.html">QSGSimpleTextureNode</a>.</p>
</td></tr></table><ul>
<li><a href="qsggeometrynode-members.html">List of all members, including inherited members</a></li>
</ul>
<a name="public-functions"></a>
<h2>Public Functions</h2>
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> </td><td class="memItemRight bottomAlign"><b><a href="qsggeometrynode.html#QSGGeometryNode">QSGGeometryNode</a></b>()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> </td><td class="memItemRight bottomAlign"><b><a href="qsggeometrynode.html#dtor.QSGGeometryNode">~QSGGeometryNode</a></b>()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QSGMaterial * </td><td class="memItemRight bottomAlign"><b><a href="qsggeometrynode.html#material">material</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QSGMaterial * </td><td class="memItemRight bottomAlign"><b><a href="qsggeometrynode.html#opaqueMaterial">opaqueMaterial</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsggeometrynode.html#setMaterial">setMaterial</a></b>(QSGMaterial *<i> material</i>)</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsggeometrynode.html#setOpaqueMaterial">setOpaqueMaterial</a></b>(QSGMaterial *<i> material</i>)</td></tr>
</table>
<ul>
<li class="fn">3 public functions inherited from <a href="qsgbasicgeometrynode.html#public-functions">QSGBasicGeometryNode</a></li>
<li class="fn">20 public functions inherited from <a href="qsgnode.html#public-functions">QSGNode</a></li>
</ul>
<a name="details"></a>
<!-- $$$QSGGeometryNode-description -->
<div class="descr">
<h2>Detailed Description</h2>
<p>The QSGGeometryNode class is used for all rendered content in the scene graph.</p>
<p>The QSGGeometryNode consists of geometry and material. The geometry defines the mesh, the vertices and their structure, to be drawn. The Material defines how the shape is filled.</p>
<p>The following is a code snipped illustrating how to create a red line using a QSGGeometryNode:</p>
<pre class="cpp"><span class="type"><a href="qsggeometry.html">QSGGeometry</a></span> <span class="operator">*</span>geometry <span class="operator">=</span> <span class="keyword">new</span> <span class="type"><a href="qsggeometry.html">QSGGeometry</a></span>(<span class="type"><a href="qsggeometry.html">QSGGeometry</a></span><span class="operator">::</span>defaultAttributes_Point2D()<span class="operator">,</span> <span class="number">2</span>);
geometry<span class="operator">-</span><span class="operator">></span>setDrawingMode(GL_LINES);
geometry<span class="operator">-</span><span class="operator">></span>setLineWidth(<span class="number">3</span>);
geometry<span class="operator">-</span><span class="operator">></span>vertexDataAsPoint2D()<span class="operator">[</span><span class="number">0</span><span class="operator">]</span><span class="operator">.</span>set(<span class="number">0</span><span class="operator">,</span> <span class="number">0</span>);
geometry<span class="operator">-</span><span class="operator">></span>vertexDataAsPoint2D()<span class="operator">[</span><span class="number">1</span><span class="operator">]</span><span class="operator">.</span>set(width()<span class="operator">,</span> height());
<span class="type"><a href="qsgflatcolormaterial.html">QSGFlatColorMaterial</a></span> <span class="operator">*</span>material <span class="operator">=</span> <span class="keyword">new</span> <span class="type"><a href="qsgflatcolormaterial.html">QSGFlatColorMaterial</a></span>;
material<span class="operator">-</span><span class="operator">></span>setColor(<span class="type">QColor</span>(<span class="number">255</span><span class="operator">,</span> <span class="number">0</span><span class="operator">,</span> <span class="number">0</span>));
<span class="type">QSGGeometryNode</span> <span class="operator">*</span>node <span class="operator">=</span> <span class="keyword">new</span> <span class="type">QSGGeometryNode</span>;
node<span class="operator">-</span><span class="operator">></span><a href="qsgbasicgeometrynode.html#setGeometry">setGeometry</a>(geometry);
node<span class="operator">-</span><span class="operator">></span><a href="qsgnode.html#setFlag">setFlag</a>(<span class="type"><a href="qsgnode.html">QSGNode</a></span><span class="operator">::</span>OwnsGeometry);
node<span class="operator">-</span><span class="operator">></span><a href="qsggeometrynode.html#setMaterial">setMaterial</a>(material);
node<span class="operator">-</span><span class="operator">></span><a href="qsgnode.html#setFlag">setFlag</a>(<span class="type"><a href="qsgnode.html">QSGNode</a></span><span class="operator">::</span>OwnsMaterial);</pre>
<p>A geometry node must have both geometry and a normal material before it is added to the scene graph. When the geometry and materials are changed after the node has been added to the scene graph, the user should also mark them as dirty using <a href="qsgnode.html#markDirty">QSGNode::markDirty</a>().</p>
<p>The geometry node supports two types of materials, the opaqueMaterial and the normal material. The opaqueMaterial is used when the accumulated scene graph opacity at the time of rendering is 1. The primary usecase is to special case opaque rendering to avoid an extra operation in the fragment shader can have significant performance impact on embedded graphics chips. The opaque material is optional.</p>
</div>
<p><b>See also </b><a href="qsggeometry.html">QSGGeometry</a>, <a href="qsgmaterial.html">QSGMaterial</a>, and <a href="qsgsimplematerial.html">QSGSimpleMaterial</a>.</p>
<!-- @@@QSGGeometryNode -->
<div class="func">
<h2>Member Function Documentation</h2>
<!-- $$$QSGGeometryNode[overload1]$$$QSGGeometryNode -->
<h3 class="fn"><a name="QSGGeometryNode"></a>QSGGeometryNode::<span class="name">QSGGeometryNode</span>()</h3>
<p>Creates a new geometry node without geometry and material.</p>
<!-- @@@QSGGeometryNode -->
<!-- $$$~QSGGeometryNode[overload1]$$$~QSGGeometryNode -->
<h3 class="fn"><a name="dtor.QSGGeometryNode"></a>QSGGeometryNode::<span class="name">~QSGGeometryNode</span>()</h3>
<p>Deletes this geometry node.</p>
<p>The flags <a href="qsgnode.html#Flag-enum">QSGNode::OwnsMaterial</a>, <a href="qsgnode.html#Flag-enum">QSGNode::OwnsOpaqueMaterial</a> and <a href="qsgnode.html#Flag-enum">QSGNode::OwnsGeometry</a> decides weither the geometry node should also delete the materials and geometry. By default, these flags are disabled.</p>
<!-- @@@~QSGGeometryNode -->
<!-- $$$material[overload1]$$$material -->
<h3 class="fn"><a name="material"></a><span class="type"><a href="qsgmaterial.html">QSGMaterial</a></span> * QSGGeometryNode::<span class="name">material</span>() const</h3>
<p>Returns the material of the <a href="qsggeometrynode.html">QSGGeometryNode</a>.</p>
<p><b>See also </b><a href="qsggeometrynode.html#setMaterial">setMaterial</a>().</p>
<!-- @@@material -->
<!-- $$$opaqueMaterial[overload1]$$$opaqueMaterial -->
<h3 class="fn"><a name="opaqueMaterial"></a><span class="type"><a href="qsgmaterial.html">QSGMaterial</a></span> * QSGGeometryNode::<span class="name">opaqueMaterial</span>() const</h3>
<p>Returns the opaque material of the <a href="qsggeometrynode.html">QSGGeometryNode</a>.</p>
<p><b>See also </b><a href="qsggeometrynode.html#setOpaqueMaterial">setOpaqueMaterial</a>().</p>
<!-- @@@opaqueMaterial -->
<!-- $$$setMaterial[overload1]$$$setMaterialQSGMaterial* -->
<h3 class="fn"><a name="setMaterial"></a><span class="type">void</span> QSGGeometryNode::<span class="name">setMaterial</span>(<span class="type"><a href="qsgmaterial.html">QSGMaterial</a></span> *<i> material</i>)</h3>
<p>Sets the material of this geometry node to <i>material</i>.</p>
<p>Geometry nodes must have a material before they can be added to the scene graph.</p>
<p>If the material is changed whitout calling setMaterial() again, the user must also mark the material as dirty using <a href="qsgnode.html#markDirty">QSGNode::markDirty</a>().</p>
<p><b>See also </b><a href="qsggeometrynode.html#material">material</a>().</p>
<!-- @@@setMaterial -->
<!-- $$$setOpaqueMaterial[overload1]$$$setOpaqueMaterialQSGMaterial* -->
<h3 class="fn"><a name="setOpaqueMaterial"></a><span class="type">void</span> QSGGeometryNode::<span class="name">setOpaqueMaterial</span>(<span class="type"><a href="qsgmaterial.html">QSGMaterial</a></span> *<i> material</i>)</h3>
<p>Sets the opaque material of this geometry to <i>material</i>.</p>
<p>The opaque material will be preferred by the renderer over the default material, as returned by the <a href="qsggeometrynode.html#material">material</a>() function, if it is not null and the geometry item has an inherited opacity of 1.</p>
<p>The opaqueness refers to scene graph opacity, the material is still allowed to set <a href="qsgmaterial.html#Flag-enum">QSGMaterial::Blending</a> to true and draw transparent pixels.</p>
<p>If the material is changed whitout calling setOpaqueMaterial() again, the user must also mark the opaque material as dirty using <a href="qsgnode.html#markDirty">QSGNode::markDirty</a>().</p>
<p><b>See also </b><a href="qsggeometrynode.html#opaqueMaterial">opaqueMaterial</a>().</p>
<!-- @@@setOpaqueMaterial -->
</div>
</div>
</div>
</div>
</div>
</div>
<div class="footer">
<p>
<acronym title="Copyright">©</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>
|