00001
00004 #ifndef FBXFILESDK_KFBXMATH_KFBXMATRIX_H
00005 #define FBXFILESDK_KFBXMATH_KFBXMATRIX_H
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033
00034
00035
00036
00037
00038
00039
00040
00041
00042
00043 #include <fbxfilesdk/components/kbaselib/kaydaradef_h.h>
00044 #include <fbxfilesdk/components/kbaselib/kaydara.h>
00045
00046 #include <fbxfilesdk/kfbxplugins/kfbxtypes.h>
00047 #include <fbxfilesdk/kfbxmath/kfbxvector4.h>
00048
00049 #include <fbxfilesdk/fbxfilesdk_nsbegin.h>
00050
00051 class KFbxQuaternion;
00052 class KFbxXMatrix;
00053
00054
00058 class KFBX_DLL KFbxMatrix : public fbxDouble44
00059 {
00060
00061 public:
00062
00067
00069 KFbxMatrix ();
00070
00074 KFbxMatrix (const KFbxMatrix& pM);
00075
00081 KFbxMatrix (KFbxVector4& pT,
00082 KFbxVector4& pR,
00083 KFbxVector4& pS);
00084
00090 KFbxMatrix (KFbxVector4& pT,
00091 KFbxQuaternion& pQ,
00092 KFbxVector4& pS);
00093
00097 KFbxMatrix (const KFbxXMatrix& pM);
00098
00100 ~KFbxMatrix ();
00101
00103
00108
00114 double Get(int pY, int pX);
00115
00120 KFbxVector4 GetRow(int pY);
00121
00126 KFbxVector4 GetColumn(int pX);
00127
00133 void Set(int pY, int pX, double pValue);
00134
00136 void SetIdentity();
00137
00143 void SetTRS(KFbxVector4& pT,
00144 KFbxVector4& pR,
00145 KFbxVector4& pS);
00146
00152 void SetTQS(KFbxVector4& pT,
00153 KFbxQuaternion& pQ,
00154 KFbxVector4& pS);
00155
00160 void SetRow(int pY, KFbxVector4& pRow);
00161
00166 void SetColumn(int pX, KFbxVector4& pColumn);
00167
00171 KFbxMatrix& operator=(const KFbxMatrix& pMatrix);
00172
00174
00179
00183 KFbxMatrix operator-();
00184
00189 KFbxMatrix operator+(const KFbxMatrix& pMatrix) const;
00190
00195 KFbxMatrix operator-(const KFbxMatrix& pMatrix) const;
00196
00201 KFbxMatrix operator*(const KFbxMatrix& pMatrix) const;
00202
00207 KFbxMatrix& operator+=(KFbxMatrix& pMatrix);
00208
00213 KFbxMatrix& operator-=(KFbxMatrix& pMatrix);
00214
00219 KFbxMatrix& operator*=(KFbxMatrix& pMatrix);
00220
00224 KFbxMatrix Inverse();
00225
00229 KFbxMatrix Transpose();
00230
00232
00237
00242 KFbxVector4 MultNormalize(const KFbxVector4& pVector) const;
00243
00245
00250
00255 bool operator==(KFbxMatrix& pM);
00256
00261 bool operator==(KFbxMatrix const& pM) const;
00262
00267 bool operator==(KFbxXMatrix& pM);
00268
00273 bool operator==(KFbxXMatrix const& pM) const;
00274
00279 bool operator!=(KFbxMatrix& pM);
00280
00285 bool operator!=(KFbxMatrix const& pM) const;
00286
00291 bool operator!=(KFbxXMatrix& pM);
00292
00297 bool operator!=(KFbxXMatrix const& pM) const;
00298
00299
00301
00306
00308 operator double* ();
00309
00311 typedef const double(kDouble44)[4][4] ;
00312
00314 inline kDouble44 & Double44() const { return *((kDouble44 *)&mData); }
00315
00317
00318
00319
00320
00321 };
00322
00323 inline EFbxType FbxTypeOf( KFbxMatrix const &pItem ) { return eDOUBLE44; }
00324
00325
00326 #include <fbxfilesdk/fbxfilesdk_nsend.h>
00327
00328 #endif // FBXFILESDK_KFBXMATH_KFBXMATRIX_H
00329