/usr/share/qt5/doc/qtquick/qsgtexture.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 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 | <?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" />
<!-- qsgtexture.cpp -->
<title>QSGTexture 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>QSGTexture</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-types">Public Types</a></li>
<li class="level1"><a href="#public-functions">Public Functions</a></li>
<li class="level1"><a href="#details">Detailed Description</a></li>
<li class="level2"><a href="#texture-atlasses">Texture Atlasses</a></li>
</ul>
</div>
<h1 class="title">QSGTexture Class</h1>
<!-- $$$QSGTexture-brief -->
<p>The QSGTexture class is a baseclass for textures used in the scene graph. <a href="#details">More...</a></p>
<!-- @@@QSGTexture -->
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> Header:</td><td class="memItemRight bottomAlign"> </b><tt><span class="preprocessor">#include <QSGTexture></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"> Inherited By:</td><td class="memItemRight bottomAlign"> <p><a href="qsgdynamictexture.html">QSGDynamicTexture</a>.</p>
</td></tr></table><ul>
<li><a href="qsgtexture-members.html">List of all members, including inherited members</a></li>
</ul>
<a name="public-types"></a>
<h2>Public Types</h2>
<table class="alignedsummary">
<tr><td class="memItemLeft rightAlign topAlign"> enum </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#Filtering-enum">Filtering</a></b> { None, Nearest, Linear }</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> enum </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#WrapMode-enum">WrapMode</a></b> { Repeat, ClampToEdge }</td></tr>
</table>
<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="qsgtexture.html#QSGTexture">QSGTexture</a></b>()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#dtor.QSGTexture">~QSGTexture</a></b>()</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual void </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#bind">bind</a></b>() = 0</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QRectF </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#convertToNormalizedSourceRect">convertToNormalizedSourceRect</a></b>(const QRectF &<i> rect</i>) const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QSGTexture::Filtering </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#filtering">filtering</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual bool </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#hasAlphaChannel">hasAlphaChannel</a></b>() const = 0</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual bool </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#hasMipmaps">hasMipmaps</a></b>() const = 0</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QSGTexture::WrapMode </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#horizontalWrapMode">horizontalWrapMode</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual bool </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#isAtlasTexture">isAtlasTexture</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QSGTexture::Filtering </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#mipmapFiltering">mipmapFiltering</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual QRectF </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#normalizedTextureSubRect">normalizedTextureSubRect</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual QSGTexture * </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#removedFromAtlas">removedFromAtlas</a></b>() const</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#setFiltering">setFiltering</a></b>(Filtering<i> filter</i>)</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#setHorizontalWrapMode">setHorizontalWrapMode</a></b>(WrapMode<i> hwrap</i>)</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#setMipmapFiltering">setMipmapFiltering</a></b>(Filtering<i> filter</i>)</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#setVerticalWrapMode">setVerticalWrapMode</a></b>(WrapMode<i> vwrap</i>)</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual int </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#textureId">textureId</a></b>() const = 0</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> virtual QSize </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#textureSize">textureSize</a></b>() const = 0</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> void </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#updateBindOptions">updateBindOptions</a></b>(bool<i> force</i> = false)</td></tr>
<tr><td class="memItemLeft rightAlign topAlign"> QSGTexture::WrapMode </td><td class="memItemRight bottomAlign"><b><a href="qsgtexture.html#verticalWrapMode">verticalWrapMode</a></b>() const</td></tr>
</table>
<a name="details"></a>
<!-- $$$QSGTexture-description -->
<div class="descr">
<h2>Detailed Description</h2>
<p>The QSGTexture class is a baseclass for textures used in the scene graph.</p>
<p>Users can freely implement their own texture classes to support arbitrary input textures, such as YUV video frames or 8 bit alpha masks. The scene graph backend provides a default implementation of normal color textures. As the implementation of these may be hardware specific, they are are constructed via the factory function <a href="qquickwindow.html#createTextureFromImage">QQuickWindow::createTextureFromImage</a>().</p>
<p>The texture is a wrapper around an OpenGL texture, which texture id is given by <a href="qsgtexture.html#textureId">textureId</a>() and which size in pixels is given by <a href="qsgtexture.html#textureSize">textureSize</a>(). <a href="qsgtexture.html#hasAlphaChannel">hasAlphaChannel</a>() reports if the texture contains opacity values and <a href="qsgtexture.html#hasMipmaps">hasMipmaps</a>() reports if the texture contains mipmap levels.</p>
<p>To use a texture, call the <a href="qsgtexture.html#bind">bind</a>() function. The texture parameters specifying how the texture is bound, can be specified with <a href="qsgtexture.html#setMipmapFiltering">setMipmapFiltering</a>(), <a href="qsgtexture.html#setFiltering">setFiltering</a>(), <a href="qsgtexture.html#setHorizontalWrapMode">setHorizontalWrapMode</a>() and <a href="qsgtexture.html#setVerticalWrapMode">setVerticalWrapMode</a>(). The texture will internally try to store these values to minimize the OpenGL state changes when the texture is bound.</p>
<a name="texture-atlasses"></a>
<h3>Texture Atlasses</h3>
<p>Some scene graph backends use texture atlasses, grouping multiple small textures into one large texture. If this is the case, the function <a href="qsgtexture.html#isAtlasTexture">isAtlasTexture</a>() will return true. Atlasses are used to aid the rendering algorithm to do better sorting which increases performance. The location of the texture inside the atlas is given with the <a href="qsgtexture.html#normalizedTextureSubRect">normalizedTextureSubRect</a>() function.</p>
<p>If the texture is used in such a way that atlas is not preferable, the function <a href="qsgtexture.html#removedFromAtlas">removedFromAtlas</a>() can be used to extract a non-atlassed copy.</p>
</div>
<p><b>See also </b><a href="qtquick-scenegraph-textureinsgnode-example.html">Scene Graph - Rendering FBOs</a> and <a href="qtquick-scenegraph-textureinthread-example.html">Scene Graph - Rendering FBOs in a thread</a>.</p>
<!-- @@@QSGTexture -->
<div class="types">
<h2>Member Type Documentation</h2>
<!-- $$$Filtering$$$None$$$Nearest$$$Linear -->
<h3 class="fn"><a name="Filtering-enum"></a>enum QSGTexture::<span class="name">Filtering</span></h3>
<p>Specifies how sampling of texels should filter when texture coordinates are not pixel aligned.</p>
<table class="valuelist"><tr valign="top" class="odd"><th class="tblConst">Constant</th><th class="tblval">Value</th><th class="tbldscr">Description</th></tr>
<tr><td class="topAlign"><tt>QSGTexture::None</tt></td><td class="topAlign"><tt>0</tt></td><td class="topAlign">No filtering should occur. This value is only used together with <a href="qsgtexture.html#setMipmapFiltering">setMipmapFiltering</a>().</td></tr>
<tr><td class="topAlign"><tt>QSGTexture::Nearest</tt></td><td class="topAlign"><tt>1</tt></td><td class="topAlign">Sampling returns the nearest texel.</td></tr>
<tr><td class="topAlign"><tt>QSGTexture::Linear</tt></td><td class="topAlign"><tt>2</tt></td><td class="topAlign">Sampling returns a linear interpolation of the neighboring texels.</td></tr>
</table>
<!-- @@@Filtering -->
<!-- $$$WrapMode$$$Repeat$$$ClampToEdge -->
<h3 class="fn"><a name="WrapMode-enum"></a>enum QSGTexture::<span class="name">WrapMode</span></h3>
<p>Specifies how the texture should treat texture coordinates.</p>
<table class="valuelist"><tr valign="top" class="odd"><th class="tblConst">Constant</th><th class="tblval">Value</th><th class="tbldscr">Description</th></tr>
<tr><td class="topAlign"><tt>QSGTexture::Repeat</tt></td><td class="topAlign"><tt>0</tt></td><td class="topAlign">Only the factional part of the texture coordiante is used, causing values above 1 and below 0 to repeat.</td></tr>
<tr><td class="topAlign"><tt>QSGTexture::ClampToEdge</tt></td><td class="topAlign"><tt>1</tt></td><td class="topAlign">Values above 1 are clamped to 1 and values below 0 are clamped to 0.</td></tr>
</table>
<!-- @@@WrapMode -->
</div>
<div class="func">
<h2>Member Function Documentation</h2>
<!-- $$$QSGTexture[overload1]$$$QSGTexture -->
<h3 class="fn"><a name="QSGTexture"></a>QSGTexture::<span class="name">QSGTexture</span>()</h3>
<p>Constructs the <a href="qsgtexture.html">QSGTexture</a> base class.</p>
<!-- @@@QSGTexture -->
<!-- $$$~QSGTexture[overload1]$$$~QSGTexture -->
<h3 class="fn"><a name="dtor.QSGTexture"></a>QSGTexture::<span class="name">~QSGTexture</span>()</h3>
<p>Destroys the <a href="qsgtexture.html">QSGTexture</a>.</p>
<!-- @@@~QSGTexture -->
<!-- $$$bind[overload1]$$$bind -->
<h3 class="fn"><a name="bind"></a><span class="type">void</span> QSGTexture::<span class="name">bind</span>()<tt> [pure virtual]</tt></h3>
<p>Call this function to bind this texture to the current texture target.</p>
<p>Binding a texture may also include uploading the texture data from a previously set QImage.</p>
<p><b>Warning:</b> This function can only be called from the rendering thread.</p>
<!-- @@@bind -->
<!-- $$$convertToNormalizedSourceRect[overload1]$$$convertToNormalizedSourceRectconstQRectF& -->
<h3 class="fn"><a name="convertToNormalizedSourceRect"></a><span class="type">QRectF</span> QSGTexture::<span class="name">convertToNormalizedSourceRect</span>(const <span class="type">QRectF</span> &<i> rect</i>) const</h3>
<p>Returns <i>rect</i> converted to normalized coordinates.</p>
<p><b>See also </b><a href="qsgtexture.html#normalizedTextureSubRect">normalizedTextureSubRect</a>().</p>
<!-- @@@convertToNormalizedSourceRect -->
<!-- $$$filtering[overload1]$$$filtering -->
<h3 class="fn"><a name="filtering"></a><span class="type"><a href="qsgtexture.html#Filtering-enum">QSGTexture::Filtering</a></span> QSGTexture::<span class="name">filtering</span>() const</h3>
<p>Returns the sampling mode to be used for this texture.</p>
<p><b>See also </b><a href="qsgtexture.html#setFiltering">setFiltering</a>().</p>
<!-- @@@filtering -->
<!-- $$$hasAlphaChannel[overload1]$$$hasAlphaChannel -->
<h3 class="fn"><a name="hasAlphaChannel"></a><span class="type">bool</span> QSGTexture::<span class="name">hasAlphaChannel</span>() const<tt> [pure virtual]</tt></h3>
<p>Returns true if the texture data contains an alpha channel.</p>
<!-- @@@hasAlphaChannel -->
<!-- $$$hasMipmaps[overload1]$$$hasMipmaps -->
<h3 class="fn"><a name="hasMipmaps"></a><span class="type">bool</span> QSGTexture::<span class="name">hasMipmaps</span>() const<tt> [pure virtual]</tt></h3>
<p>Returns true if the texture data contains mipmap levels.</p>
<!-- @@@hasMipmaps -->
<!-- $$$horizontalWrapMode[overload1]$$$horizontalWrapMode -->
<h3 class="fn"><a name="horizontalWrapMode"></a><span class="type"><a href="qsgtexture.html#WrapMode-enum">QSGTexture::WrapMode</a></span> QSGTexture::<span class="name">horizontalWrapMode</span>() const</h3>
<p>Returns the horizontal wrap mode to be used for this texture.</p>
<p><b>See also </b><a href="qsgtexture.html#setHorizontalWrapMode">setHorizontalWrapMode</a>().</p>
<!-- @@@horizontalWrapMode -->
<!-- $$$isAtlasTexture[overload1]$$$isAtlasTexture -->
<h3 class="fn"><a name="isAtlasTexture"></a><span class="type">bool</span> QSGTexture::<span class="name">isAtlasTexture</span>() const<tt> [virtual]</tt></h3>
<p>Returns weither this texture is part of an atlas or not.</p>
<p>The default implementation returns false.</p>
<!-- @@@isAtlasTexture -->
<!-- $$$mipmapFiltering[overload1]$$$mipmapFiltering -->
<h3 class="fn"><a name="mipmapFiltering"></a><span class="type"><a href="qsgtexture.html#Filtering-enum">QSGTexture::Filtering</a></span> QSGTexture::<span class="name">mipmapFiltering</span>() const</h3>
<p>Returns whether mipmapping should be used when sampling from this texture.</p>
<p><b>See also </b><a href="qsgtexture.html#setMipmapFiltering">setMipmapFiltering</a>().</p>
<!-- @@@mipmapFiltering -->
<!-- $$$normalizedTextureSubRect[overload1]$$$normalizedTextureSubRect -->
<h3 class="fn"><a name="normalizedTextureSubRect"></a><span class="type">QRectF</span> QSGTexture::<span class="name">normalizedTextureSubRect</span>() const<tt> [virtual]</tt></h3>
<p>Returns the rectangle inside <a href="qsgtexture.html#textureSize">textureSize</a>() that this texture represents in normalized coordinates.</p>
<p>The default implementation returns a rect at position (0, 0) with width and height of 1.</p>
<!-- @@@normalizedTextureSubRect -->
<!-- $$$removedFromAtlas[overload1]$$$removedFromAtlas -->
<h3 class="fn"><a name="removedFromAtlas"></a><span class="type">QSGTexture</span> * QSGTexture::<span class="name">removedFromAtlas</span>() const<tt> [virtual]</tt></h3>
<p>This function returns a copy of the current texture which is removed from its atlas.</p>
<p>The current texture remains unchanged, so texture coordinates do not need to be updated.</p>
<p>Removing a texture from an atlas is primarily useful when passing it to a shader that operates on the texture coordinates 0-1 instead of the texture subrect inside the atlas.</p>
<p>If the texture is not part of a texture atlas, this function returns 0.</p>
<p>Implementations of this function are recommended to return the same instance for multiple calls to limit memory usage.</p>
<p><b>Warning:</b> This function can only be called from the rendering thread.</p>
<!-- @@@removedFromAtlas -->
<!-- $$$setFiltering[overload1]$$$setFilteringFiltering -->
<h3 class="fn"><a name="setFiltering"></a><span class="type">void</span> QSGTexture::<span class="name">setFiltering</span>(<span class="type"><a href="qsgtexture.html#Filtering-enum">Filtering</a></span><i> filter</i>)</h3>
<p>Sets the sampling mode to be used for the upcoming <a href="qsgtexture.html#bind">bind</a>() call to <i>filter</i>.</p>
<p><b>See also </b><a href="qsgtexture.html#filtering">filtering</a>().</p>
<!-- @@@setFiltering -->
<!-- $$$setHorizontalWrapMode[overload1]$$$setHorizontalWrapModeWrapMode -->
<h3 class="fn"><a name="setHorizontalWrapMode"></a><span class="type">void</span> QSGTexture::<span class="name">setHorizontalWrapMode</span>(<span class="type"><a href="qsgtexture.html#WrapMode-enum">WrapMode</a></span><i> hwrap</i>)</h3>
<p>Sets the horizontal wrap mode to be used for the upcoming <a href="qsgtexture.html#bind">bind</a>() call to <i>hwrap</i></p>
<p><b>See also </b><a href="qsgtexture.html#horizontalWrapMode">horizontalWrapMode</a>().</p>
<!-- @@@setHorizontalWrapMode -->
<!-- $$$setMipmapFiltering[overload1]$$$setMipmapFilteringFiltering -->
<h3 class="fn"><a name="setMipmapFiltering"></a><span class="type">void</span> QSGTexture::<span class="name">setMipmapFiltering</span>(<span class="type"><a href="qsgtexture.html#Filtering-enum">Filtering</a></span><i> filter</i>)</h3>
<p>Sets the mipmap sampling mode to be used for the upcoming <a href="qsgtexture.html#bind">bind</a>() call to <i>filter</i>.</p>
<p>Setting the mipmap filtering has no effect it the texture does not have mipmaps.</p>
<p><b>See also </b><a href="qsgtexture.html#mipmapFiltering">mipmapFiltering</a>() and <a href="qsgtexture.html#hasMipmaps">hasMipmaps</a>().</p>
<!-- @@@setMipmapFiltering -->
<!-- $$$setVerticalWrapMode[overload1]$$$setVerticalWrapModeWrapMode -->
<h3 class="fn"><a name="setVerticalWrapMode"></a><span class="type">void</span> QSGTexture::<span class="name">setVerticalWrapMode</span>(<span class="type"><a href="qsgtexture.html#WrapMode-enum">WrapMode</a></span><i> vwrap</i>)</h3>
<p>Sets the vertical wrap mode to be used for the upcoming <a href="qsgtexture.html#bind">bind</a>() call to <i>vwrap</i></p>
<p><b>See also </b><a href="qsgtexture.html#verticalWrapMode">verticalWrapMode</a>().</p>
<!-- @@@setVerticalWrapMode -->
<!-- $$$textureId[overload1]$$$textureId -->
<h3 class="fn"><a name="textureId"></a><span class="type">int</span> QSGTexture::<span class="name">textureId</span>() const<tt> [pure virtual]</tt></h3>
<p>Returns the OpenGL texture id for this texture.</p>
<p>The default value is 0, indicating that it is an invalid texture id.</p>
<p>The function should at all times return the correct texture id.</p>
<p><b>Warning:</b> This function can only be called from the rendering thread.</p>
<!-- @@@textureId -->
<!-- $$$textureSize[overload1]$$$textureSize -->
<h3 class="fn"><a name="textureSize"></a><span class="type">QSize</span> QSGTexture::<span class="name">textureSize</span>() const<tt> [pure virtual]</tt></h3>
<p>Returns the size of the texture.</p>
<!-- @@@textureSize -->
<!-- $$$updateBindOptions[overload1]$$$updateBindOptionsbool -->
<h3 class="fn"><a name="updateBindOptions"></a><span class="type">void</span> QSGTexture::<span class="name">updateBindOptions</span>(<span class="type">bool</span><i> force</i> = false)</h3>
<p>Update the texture state to match the filtering, mipmap and wrap options currently set.</p>
<p>If <i>force</i> is true, all properties will be updated regardless of weither they have changed or not.</p>
<!-- @@@updateBindOptions -->
<!-- $$$verticalWrapMode[overload1]$$$verticalWrapMode -->
<h3 class="fn"><a name="verticalWrapMode"></a><span class="type"><a href="qsgtexture.html#WrapMode-enum">QSGTexture::WrapMode</a></span> QSGTexture::<span class="name">verticalWrapMode</span>() const</h3>
<p>Returns the vertical wrap mode to be used for this texture.</p>
<p><b>See also </b><a href="qsgtexture.html#setVerticalWrapMode">setVerticalWrapMode</a>().</p>
<!-- @@@verticalWrapMode -->
</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>
|