source: trunk/src/gui/math3d/qgenericmatrix.cpp@ 885

Last change on this file since 885 was 846, checked in by Dmitry A. Kuminov, 14 years ago

trunk: Merged in qt 4.7.2 sources from branches/vendor/nokia/qt.

  • Property svn:eol-style set to native
File size: 8.8 KB
Line 
1/****************************************************************************
2**
3** Copyright (C) 2011 Nokia Corporation and/or its subsidiary(-ies).
4** All rights reserved.
5** Contact: Nokia Corporation (qt-info@nokia.com)
6**
7** This file is part of the QtGui module of the Qt Toolkit.
8**
9** $QT_BEGIN_LICENSE:LGPL$
10** Commercial Usage
11** Licensees holding valid Qt Commercial licenses may use this file in
12** accordance with the Qt Commercial License Agreement provided with the
13** Software or, alternatively, in accordance with the terms contained in
14** a written agreement between you and Nokia.
15**
16** GNU Lesser General Public License Usage
17** Alternatively, this file may be used under the terms of the GNU Lesser
18** General Public License version 2.1 as published by the Free Software
19** Foundation and appearing in the file LICENSE.LGPL included in the
20** packaging of this file. Please review the following information to
21** ensure the GNU Lesser General Public License version 2.1 requirements
22** will be met: http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
23**
24** In addition, as a special exception, Nokia gives you certain additional
25** rights. These rights are described in the Nokia Qt LGPL Exception
26** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
27**
28** GNU General Public License Usage
29** Alternatively, this file may be used under the terms of the GNU
30** General Public License version 3.0 as published by the Free Software
31** Foundation and appearing in the file LICENSE.GPL included in the
32** packaging of this file. Please review the following information to
33** ensure the GNU General Public License version 3.0 requirements will be
34** met: http://www.gnu.org/copyleft/gpl.html.
35**
36** If you have questions regarding the use of this file, please contact
37** Nokia at qt-info@nokia.com.
38** $QT_END_LICENSE$
39**
40****************************************************************************/
41
42#include "qgenericmatrix.h"
43
44QT_BEGIN_NAMESPACE
45
46/*!
47 \class QGenericMatrix
48 \brief The QGenericMatrix class is a template class that represents a NxM transformation matrix with N columns and M rows.
49 \since 4.6
50 \ingroup painting
51 \ingroup painting-3D
52
53 The QGenericMatrix template has three parameters:
54
55 \table
56 \row \i N \i Number of columns.
57 \row \i M \i Number of rows.
58 \row \i T \i Element type that is visible to users of the class.
59 \endtable
60
61 \sa QMatrix4x4
62*/
63
64/*!
65 \fn QGenericMatrix::QGenericMatrix()
66
67 Constructs a NxM identity matrix.
68*/
69
70/*!
71 \fn QGenericMatrix::QGenericMatrix(const QGenericMatrix<N, M, T>& other)
72
73 Constructs a copy of \a other.
74*/
75
76/*!
77 \fn QGenericMatrix::QGenericMatrix(const T *values)
78
79 Constructs a matrix from the given N * M floating-point \a values.
80 The contents of the array \a values is assumed to be in
81 row-major order.
82
83 \sa copyDataTo()
84*/
85
86/*!
87 \fn const T& QGenericMatrix::operator()(int row, int column) const
88
89 Returns a constant reference to the element at position
90 (\a row, \a column) in this matrix.
91*/
92
93/*!
94 \fn T& QGenericMatrix::operator()(int row, int column)
95
96 Returns a reference to the element at position (\a row, \a column)
97 in this matrix so that the element can be assigned to.
98*/
99
100/*!
101 \fn bool QGenericMatrix::isIdentity() const
102
103 Returns true if this matrix is the identity; false otherwise.
104
105 \sa setToIdentity()
106*/
107
108/*!
109 \fn void QGenericMatrix::setToIdentity()
110
111 Sets this matrix to the identity.
112
113 \sa isIdentity()
114*/
115
116/*!
117 \fn void QGenericMatrix::fill(T value)
118
119 Fills all elements of this matrix with \a value.
120*/
121
122/*!
123 \fn QGenericMatrix<M, N> QGenericMatrix::transposed() const
124
125 Returns this matrix, transposed about its diagonal.
126*/
127
128/*!
129 \fn QGenericMatrix<N, M, T>& QGenericMatrix::operator+=(const QGenericMatrix<N, M, T>& other)
130
131 Adds the contents of \a other to this matrix.
132*/
133
134/*!
135 \fn QGenericMatrix<N, M, T>& QGenericMatrix::operator-=(const QGenericMatrix<N, M, T>& other)
136
137 Subtracts the contents of \a other from this matrix.
138*/
139
140/*!
141 \fn QGenericMatrix<N, M, T>& QGenericMatrix::operator*=(T factor)
142
143 Multiplies all elements of this matrix by \a factor.
144*/
145
146/*!
147 \fn QGenericMatrix<N, M, T>& QGenericMatrix::operator/=(T divisor)
148
149 Divides all elements of this matrix by \a divisor.
150*/
151
152/*!
153 \fn bool QGenericMatrix::operator==(const QGenericMatrix<N, M, T>& other) const
154
155 Returns true if this matrix is identical to \a other; false otherwise.
156*/
157
158/*!
159 \fn bool QGenericMatrix::operator!=(const QGenericMatrix<N, M, T>& other) const
160
161 Returns true if this matrix is not identical to \a other; false otherwise.
162*/
163
164/*!
165 \fn QGenericMatrix<N, M, T> operator+(const QGenericMatrix<N, M, T>& m1, const QGenericMatrix<N, M, T>& m2)
166 \relates QGenericMatrix
167
168 Returns the sum of \a m1 and \a m2.
169*/
170
171/*!
172 \fn QGenericMatrix<N, M, T> operator-(const QGenericMatrix<N, M, T>& m1, const QGenericMatrix<N, M, T>& m2)
173 \relates QGenericMatrix
174
175 Returns the difference of \a m1 and \a m2.
176*/
177
178/*!
179 \fn QGenericMatrix<M1, M2, T> operator*(const QGenericMatrix<N, M2, T>& m1, const QGenericMatrix<M1, N, T>& m2)
180 \relates QGenericMatrix
181
182 Returns the product of the NxM2 matrix \a m1 and the M1xN matrix \a m2
183 to produce a M1xM2 matrix result.
184*/
185
186/*!
187 \fn QGenericMatrix<N, M, T> operator-(const QGenericMatrix<N, M, T>& matrix)
188 \overload
189 \relates QGenericMatrix
190
191 Returns the negation of \a matrix.
192*/
193
194/*!
195 \fn QGenericMatrix<N, M, T> operator*(T factor, const QGenericMatrix<N, M, T>& matrix)
196 \relates QGenericMatrix
197
198 Returns the result of multiplying all elements of \a matrix by \a factor.
199*/
200
201/*!
202 \fn QGenericMatrix<N, M, T> operator*(const QGenericMatrix<N, M, T>& matrix, T factor)
203 \relates QGenericMatrix
204
205 Returns the result of multiplying all elements of \a matrix by \a factor.
206*/
207
208/*!
209 \fn QGenericMatrix<N, M, T> operator/(const QGenericMatrix<N, M, T>& matrix, T divisor)
210 \relates QGenericMatrix
211
212 Returns the result of dividing all elements of \a matrix by \a divisor.
213*/
214
215/*!
216 \fn void QGenericMatrix::copyDataTo(T *values) const
217
218 Retrieves the N * M items in this matrix and copies them to \a values
219 in row-major order.
220*/
221
222/*!
223 \fn T *QGenericMatrix::data()
224
225 Returns a pointer to the raw data of this matrix.
226
227 \sa constData()
228*/
229
230/*!
231 \fn const T *QGenericMatrix::data() const
232
233 Returns a constant pointer to the raw data of this matrix.
234
235 \sa constData()
236*/
237
238/*!
239 \fn const T *QGenericMatrix::constData() const
240
241 Returns a constant pointer to the raw data of this matrix.
242
243 \sa data()
244*/
245
246#ifndef QT_NO_DATASTREAM
247
248/*!
249 \fn QDataStream &operator<<(QDataStream &stream, const QGenericMatrix<N, M, T> &matrix)
250 \relates QGenericMatrix
251
252 Writes the given \a matrix to the given \a stream and returns a
253 reference to the stream.
254
255 \sa {Serializing Qt Data Types}
256*/
257
258/*!
259 \fn QDataStream &operator>>(QDataStream &stream, QGenericMatrix<N, M, T> &matrix)
260 \relates QGenericMatrix
261
262 Reads a NxM matrix from the given \a stream into the given \a matrix
263 and returns a reference to the stream.
264
265 \sa {Serializing Qt Data Types}
266*/
267
268#endif
269
270/*!
271 \typedef QMatrix2x2
272 \relates QGenericMatrix
273
274 The QMatrix2x2 type defines a convenient instantiation of the
275 QGenericMatrix template for 2 columns, 2 rows, and qreal as
276 the element type.
277*/
278
279/*!
280 \typedef QMatrix2x3
281 \relates QGenericMatrix
282
283 The QMatrix2x3 type defines a convenient instantiation of the
284 QGenericMatrix template for 2 columns, 3 rows, and qreal as
285 the element type.
286*/
287
288/*!
289 \typedef QMatrix2x4
290 \relates QGenericMatrix
291
292 The QMatrix2x4 type defines a convenient instantiation of the
293 QGenericMatrix template for 2 columns, 4 rows, and qreal as
294 the element type.
295*/
296
297/*!
298 \typedef QMatrix3x2
299 \relates QGenericMatrix
300
301 The QMatrix3x2 type defines a convenient instantiation of the
302 QGenericMatrix template for 3 columns, 2 rows, and qreal as
303 the element type.
304*/
305
306/*!
307 \typedef QMatrix3x3
308 \relates QGenericMatrix
309
310 The QMatrix3x3 type defines a convenient instantiation of the
311 QGenericMatrix template for 3 columns, 3 rows, and qreal as
312 the element type.
313*/
314
315/*!
316 \typedef QMatrix3x4
317 \relates QGenericMatrix
318
319 The QMatrix3x4 type defines a convenient instantiation of the
320 QGenericMatrix template for 3 columns, 4 rows, and qreal as
321 the element type.
322*/
323
324/*!
325 \typedef QMatrix4x2
326 \relates QGenericMatrix
327
328 The QMatrix4x2 type defines a convenient instantiation of the
329 QGenericMatrix template for 4 columns, 2 rows, and qreal as
330 the element type.
331*/
332
333/*!
334 \typedef QMatrix4x3
335 \relates QGenericMatrix
336
337 The QMatrix4x3 type defines a convenient instantiation of the
338 QGenericMatrix template for 4 columns, 3 rows, and qreal as
339 the element type.
340*/
341
342QT_END_NAMESPACE
Note: See TracBrowser for help on using the repository browser.