QGIS API Documentation 4.1.0-Master (009143bf4b4)
Loading...
Searching...
No Matches
qgsmatrix4x4.h
Go to the documentation of this file.
1/***************************************************************************
2 qgsmatrix4x4.h
3 --------------------------------------
4 Date : July 2023
5 Copyright : (C) 2023 by Martin Dobias
6 Email : wonder dot sk at gmail dot com
7 ***************************************************************************
8 * *
9 * This program is free software; you can redistribute it and/or modify *
10 * it under the terms of the GNU General Public License as published by *
11 * the Free Software Foundation; either version 2 of the License, or *
12 * (at your option) any later version. *
13 * *
14 ***************************************************************************/
15
16#ifndef QGSMATRIX4X4_H
17#define QGSMATRIX4X4_H
18
19#include "qgis_core.h"
20#include "qgis_sip.h"
21#include "qgsvector3d.h"
22
23#include <QString>
24
25using namespace Qt::StringLiterals;
26
41class CORE_EXPORT QgsMatrix4x4
42{
43 public:
47 // clang-format off
49 double m11, double m12, double m13, double m14,
50 double m21, double m22, double m23, double m24,
51 double m31, double m32, double m33, double m34,
52 double m41, double m42, double m43, double m44
53 );
54 // clang-format on
55
56 bool operator==( const QgsMatrix4x4 &other ) const
57 {
58 const double *data = *m;
59 const double *otherData = *( other.m );
60 for ( int i = 0; i < 16; ++i, data++, otherData++ )
61 {
62 if ( !qgsDoubleNear( *data, *otherData ) )
63 return false;
64 }
65 return true;
66 }
67
68 bool operator!=( const QgsMatrix4x4 &other ) const { return !( *this == other ); }
69
71 const double *constData() const SIP_SKIP { return *m; }
73 double *data() SIP_SKIP { return *m; }
74 // clang-format off
76 QList< double > dataList() const SIP_PYNAME( data ) SIP_HOLDGIL;
77 // clang-format on
78
82 void translate( const QgsVector3D &vector );
83
85 QgsVector3D map( const QgsVector3D &vector ) const SIP_HOLDGIL
86 {
87 return *this * vector;
88 }
89
91 bool isIdentity() const SIP_HOLDGIL;
93 void setToIdentity() SIP_HOLDGIL;
94
100 void scale( const QgsVector3D &vector );
101
108 void rotate( double angle, double x, double y, double z );
109
116 void rotate( double angle, const QgsVector3D &vector );
117
118#ifdef SIP_RUN
119// clang-format off
120 SIP_PYOBJECT __repr__();
121 % MethodCode
122 QString str = u"<QgsMatrix4x4(%1, %2, %3, %4, %5, %6, %7, %8, %9, %10, %11, %12, %13, %14, %15, %16)>"_s
123 .arg( sipCpp->data()[0] )
124 .arg( sipCpp->data()[4] )
125 .arg( sipCpp->data()[8] )
126 .arg( sipCpp->data()[12] )
127 .arg( sipCpp->data()[1] )
128 .arg( sipCpp->data()[5] )
129 .arg( sipCpp->data()[9] )
130 .arg( sipCpp->data()[13] )
131 .arg( sipCpp->data()[2] )
132 .arg( sipCpp->data()[6] )
133 .arg( sipCpp->data()[10] )
134 .arg( sipCpp->data()[14] )
135 .arg( sipCpp->data()[3] )
136 .arg( sipCpp->data()[7] )
137 .arg( sipCpp->data()[11] )
138 .arg( sipCpp->data()[15] );
139 sipRes = PyUnicode_FromString( str.toUtf8().constData() );
140 % End
141// clang-format on
142#endif
143
144#ifndef SIP_RUN
145 friend CORE_EXPORT QgsMatrix4x4 operator*( const QgsMatrix4x4 &m1, const QgsMatrix4x4 &m2 );
146 friend CORE_EXPORT QgsVector3D operator*( const QgsMatrix4x4 &matrix, const QgsVector3D &vector );
147#endif
148
149 private:
150 // Matrix data - in column-major order
151 double m[4][4];
152
154 explicit QgsMatrix4x4( int ) { } // cppcheck-suppress uninitMemberVarPrivate
155};
156
158CORE_EXPORT QgsVector3D operator*( const QgsMatrix4x4 &matrix, const QgsVector3D &vector );
160CORE_EXPORT QgsMatrix4x4 operator*( const QgsMatrix4x4 &m1, const QgsMatrix4x4 &m2 );
161
162
163#endif
A simple 4x4 matrix implementation useful for transformation in 3D space.
bool operator==(const QgsMatrix4x4 &other) const
QgsMatrix4x4()
Initializes identity matrix.
void setToIdentity()
Sets matrix to be identity matrix.
QgsVector3D map(const QgsVector3D &vector) const
Matrix-vector multiplication (vector is converted to homogeneous coordinates [X,Y,...
bool operator!=(const QgsMatrix4x4 &other) const
double * data()
Returns pointer to the matrix data (stored in column-major order).
const double * constData() const
Returns pointer to the matrix data (stored in column-major order).
A 3D vector (similar to QVector3D) with the difference that it uses double precision instead of singl...
Definition qgsvector3d.h:33
bool qgsDoubleNear(double a, double b, double epsilon=4 *std::numeric_limits< double >::epsilon())
Compare two doubles (but allow some difference).
Definition qgis.h:7108
#define SIP_SKIP
Definition qgis_sip.h:133
#define SIP_PYNAME(name)
Definition qgis_sip.h:88
#define SIP_HOLDGIL
Definition qgis_sip.h:178
QgsMargins operator*(const QgsMargins &margins, double factor)
Returns a QgsMargins object that is formed by multiplying each component of the given margins by fact...
Definition qgsmargins.h:245
CORE_EXPORT QgsVector3D operator*(const QgsMatrix4x4 &matrix, const QgsVector3D &vector)
Matrix-vector multiplication (vector is converted to homogeneous coordinates [X,Y,...