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