1 /****************************************************************************
2 **
3 ** Copyright (C) 2014 Klaralvdalens Datakonsult AB (KDAB).
4 ** Contact: https://www.qt.io/licensing/
5 **
6 ** This file is part of the Qt3D module of the Qt Toolkit.
7 **
8 ** $QT_BEGIN_LICENSE:LGPL$
9 ** Commercial License Usage
10 ** Licensees holding valid commercial Qt licenses may use this file in
11 ** accordance with the commercial license agreement provided with the
12 ** Software or, alternatively, in accordance with the terms contained in
13 ** a written agreement between you and The Qt Company. For licensing terms
14 ** and conditions see https://www.qt.io/terms-conditions. For further
15 ** information use the contact form at https://www.qt.io/contact-us.
16 **
17 ** GNU Lesser General Public License Usage
18 ** Alternatively, this file may be used under the terms of the GNU Lesser
19 ** General Public License version 3 as published by the Free Software
20 ** Foundation and appearing in the file LICENSE.LGPL3 included in the
21 ** packaging of this file. Please review the following information to
22 ** ensure the GNU Lesser General Public License version 3 requirements
23 ** will be met: https://www.gnu.org/licenses/lgpl-3.0.html.
24 **
25 ** GNU General Public License Usage
26 ** Alternatively, this file may be used under the terms of the GNU
27 ** General Public License version 2.0 or (at your option) the GNU General
28 ** Public license version 3 or any later version approved by the KDE Free
29 ** Qt Foundation. The licenses are as published by the Free Software
30 ** Foundation and appearing in the file LICENSE.GPL2 and LICENSE.GPL3
31 ** included in the packaging of this file. Please review the following
32 ** information to ensure the GNU General Public License requirements will
33 ** be met: https://www.gnu.org/licenses/gpl-2.0.html and
34 ** https://www.gnu.org/licenses/gpl-3.0.html.
35 **
36 ** $QT_END_LICENSE$
37 **
38 ****************************************************************************/
39
40 #include "qcuboidmesh.h"
41
42 #include <Qt3DExtras/qcuboidgeometry.h>
43
44 QT_BEGIN_NAMESPACE
45
46 namespace Qt3DExtras {
47
48 /*!
49 * \qmltype CuboidMesh
50 * \instantiates Qt3DExtras::QCuboidMesh
51 * \inqmlmodule Qt3D.Extras
52 * \brief A cuboid mesh.
53 */
54
55 /*!
56 * \qmlproperty real CuboidMesh::xExtent
57 *
58 * Holds the x extent of the mesh.
59 */
60
61 /*!
62 * \qmlproperty real CuboidMesh::yExtent
63 *
64 * Holds the y extent of the mesh.
65 */
66
67 /*!
68 * \qmlproperty real CuboidMesh::zExtent
69 *
70 * Holds the z extent of the mesh.
71 */
72
73 /*!
74 * \qmlproperty size CuboidMesh::yzMeshResolution
75 *
76 * Holds the y-z resolution of the mesh.
77 * The width and height values of this property specify the number of vertices generated for
78 * the y-z faces of the mesh.
79 */
80
81 /*!
82 * \qmlproperty size CuboidMesh::xzMeshResolution
83 *
84 * Holds the x-z resolution of the mesh.
85 * The width and height values of this property specify the number of vertices generated for
86 * the x-z faces of the mesh.
87 */
88
89 /*!
90 * \qmlproperty size CuboidMesh::xyMeshResolution
91 *
92 * Holds the x-y resolution of the mesh.
93 * The width and height values of this property specify the number of vertices generated for
94 * the x-y faces of the mesh.
95 */
96
97 /*!
98 * \class Qt3DExtras::QCuboidMesh
99 \ingroup qt3d-extras-geometries
100 * \inheaderfile Qt3DExtras/QCuboidMesh
101 * \inmodule Qt3DExtras
102 *
103 * \inherits Qt3DRender::QGeometryRenderer
104 *
105 * \brief A cuboid mesh.
106 */
107
108 /*!
109 * Constructs a new QCuboidMesh with \a parent.
110 */
QCuboidMesh(QNode * parent)111 QCuboidMesh::QCuboidMesh(QNode *parent)
112 : QGeometryRenderer(parent)
113 {
114 QCuboidGeometry *geometry = new QCuboidGeometry(this);
115 QObject::connect(geometry, &QCuboidGeometry::xExtentChanged, this, &QCuboidMesh::xExtentChanged);
116 QObject::connect(geometry, &QCuboidGeometry::yExtentChanged, this, &QCuboidMesh::yExtentChanged);
117 QObject::connect(geometry, &QCuboidGeometry::zExtentChanged, this, &QCuboidMesh::zExtentChanged);
118 QObject::connect(geometry, &QCuboidGeometry::xyMeshResolutionChanged, this, &QCuboidMesh::xyMeshResolutionChanged);
119 QObject::connect(geometry, &QCuboidGeometry::xzMeshResolutionChanged, this, &QCuboidMesh::xzMeshResolutionChanged);
120 QObject::connect(geometry, &QCuboidGeometry::yzMeshResolutionChanged, this, &QCuboidMesh::yzMeshResolutionChanged);
121 QGeometryRenderer::setGeometry(geometry);
122 }
123
124 /*! \internal */
~QCuboidMesh()125 QCuboidMesh::~QCuboidMesh()
126 {
127 }
128
setXExtent(float xExtent)129 void QCuboidMesh::setXExtent(float xExtent)
130 {
131 static_cast<QCuboidGeometry *>(geometry())->setXExtent(xExtent);
132 }
133
134 /*!
135 * \property QCuboidMesh::xExtent
136 *
137 * Holds the x extent of the mesh.
138 */
xExtent() const139 float QCuboidMesh::xExtent() const
140 {
141 return static_cast<QCuboidGeometry *>(geometry())->xExtent();
142 }
143
setYExtent(float yExtent)144 void QCuboidMesh::setYExtent(float yExtent)
145 {
146 static_cast<QCuboidGeometry *>(geometry())->setYExtent(yExtent);
147 }
148
149 /*!
150 * \property QCuboidMesh::yExtent
151 *
152 * Holds the y extent of the mesh.
153 */
yExtent() const154 float QCuboidMesh::yExtent() const
155 {
156 return static_cast<QCuboidGeometry *>(geometry())->yExtent();
157 }
158
setZExtent(float zExtent)159 void QCuboidMesh::setZExtent(float zExtent)
160 {
161 static_cast<QCuboidGeometry *>(geometry())->setZExtent(zExtent);
162 }
163
164 /*!
165 * \property QCuboidMesh::zExtent
166 *
167 * Holds the z extent of the mesh.
168 */
zExtent() const169 float QCuboidMesh::zExtent() const
170 {
171 return static_cast<QCuboidGeometry *>(geometry())->zExtent();
172 }
173
setYZMeshResolution(const QSize & resolution)174 void QCuboidMesh::setYZMeshResolution(const QSize &resolution)
175 {
176 static_cast<QCuboidGeometry *>(geometry())->setYZMeshResolution(resolution);
177 }
178
179 /*!
180 * \property QCuboidMesh::yzMeshResolution
181 *
182 * Holds the y-z resolution of the mesh.
183 * The width and height values of this property specify the number of vertices generated for
184 * the y-z faces of the mesh.
185 */
yzMeshResolution() const186 QSize QCuboidMesh::yzMeshResolution() const
187 {
188 return static_cast<QCuboidGeometry *>(geometry())->yzMeshResolution();
189 }
190
setXZMeshResolution(const QSize & resolution)191 void QCuboidMesh::setXZMeshResolution(const QSize &resolution)
192 {
193 static_cast<QCuboidGeometry *>(geometry())->setXZMeshResolution(resolution);
194 }
195
196 /*!
197 * \property QCuboidMesh::xzMeshResolution
198 *
199 * Holds the x-z resolution of the mesh.
200 * The width and height values of this property specify the number of vertices generated for
201 * the x-z faces of the mesh.
202 */
xzMeshResolution() const203 QSize QCuboidMesh::xzMeshResolution() const
204 {
205 return static_cast<QCuboidGeometry *>(geometry())->xzMeshResolution();
206 }
207
setXYMeshResolution(const QSize & resolution)208 void QCuboidMesh::setXYMeshResolution(const QSize &resolution)
209 {
210 static_cast<QCuboidGeometry *>(geometry())->setXYMeshResolution(resolution);
211 }
212
213 /*!
214 * \property QCuboidMesh::xyMeshResolution
215 *
216 * Holds the x-y resolution of the mesh.
217 * The width and height values of this property specify the number of vertices generated for
218 * the x-y faces of the mesh.
219 */
xyMeshResolution() const220 QSize QCuboidMesh::xyMeshResolution() const
221 {
222 return static_cast<QCuboidGeometry *>(geometry())->xyMeshResolution();
223 }
224
225 } // namespace Qt3DExtras
226
227 QT_END_NAMESPACE
228