kfbxmatrix.h

Go to the documentation of this file.
00001 
00004 #ifndef FBXFILESDK_KFBXMATH_KFBXMATRIX_H
00005 #define FBXFILESDK_KFBXMATH_KFBXMATRIX_H
00006 
00007 /**************************************************************************************
00008 
00009  Copyright (C) 2001 - 2009 Autodesk, Inc. and/or its licensors.
00010  All Rights Reserved.
00011 
00012  The coded instructions, statements, computer programs, and/or related material 
00013  (collectively the "Data") in these files contain unpublished information 
00014  proprietary to Autodesk, Inc. and/or its licensors, which is protected by 
00015  Canada and United States of America federal copyright law and by international 
00016  treaties. 
00017  
00018  The Data may not be disclosed or distributed to third parties, in whole or in
00019  part, without the prior written consent of Autodesk, Inc. ("Autodesk").
00020 
00021  THE DATA IS PROVIDED "AS IS" AND WITHOUT WARRANTY.
00022  ALL WARRANTIES ARE EXPRESSLY EXCLUDED AND DISCLAIMED. AUTODESK MAKES NO
00023  WARRANTY OF ANY KIND WITH RESPECT TO THE DATA, EXPRESS, IMPLIED OR ARISING
00024  BY CUSTOM OR TRADE USAGE, AND DISCLAIMS ANY IMPLIED WARRANTIES OF TITLE, 
00025  NON-INFRINGEMENT, MERCHANTABILITY OR FITNESS FOR A PARTICULAR PURPOSE OR USE. 
00026  WITHOUT LIMITING THE FOREGOING, AUTODESK DOES NOT WARRANT THAT THE OPERATION
00027  OF THE DATA WILL BE UNINTERRUPTED OR ERROR FREE. 
00028  
00029  IN NO EVENT SHALL AUTODESK, ITS AFFILIATES, PARENT COMPANIES, LICENSORS
00030  OR SUPPLIERS ("AUTODESK GROUP") BE LIABLE FOR ANY LOSSES, DAMAGES OR EXPENSES
00031  OF ANY KIND (INCLUDING WITHOUT LIMITATION PUNITIVE OR MULTIPLE DAMAGES OR OTHER
00032  SPECIAL, DIRECT, INDIRECT, EXEMPLARY, INCIDENTAL, LOSS OF PROFITS, REVENUE
00033  OR DATA, COST OF COVER OR CONSEQUENTIAL LOSSES OR DAMAGES OF ANY KIND),
00034  HOWEVER CAUSED, AND REGARDLESS OF THE THEORY OF LIABILITY, WHETHER DERIVED
00035  FROM CONTRACT, TORT (INCLUDING, BUT NOT LIMITED TO, NEGLIGENCE), OR OTHERWISE,
00036  ARISING OUT OF OR RELATING TO THE DATA OR ITS USE OR ANY OTHER PERFORMANCE,
00037  WHETHER OR NOT AUTODESK HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH LOSS
00038  OR DAMAGE. 
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 (const KFbxVector4& pT,
00082                 const KFbxVector4& pR,
00083                 const KFbxVector4& pS);
00084 
00090     KFbxMatrix (const KFbxVector4& pT,
00091                 const KFbxQuaternion& pQ,
00092                 const KFbxVector4& pS);
00093 
00097     KFbxMatrix (const KFbxXMatrix& pM);
00098         
00100     ~KFbxMatrix ();
00101         
00103 
00108 
00114     double Get(int pY, int pX) const;
00115 
00120     KFbxVector4 GetRow(int pY) const;
00121 
00126     KFbxVector4 GetColumn(int pX) const;
00127 
00133     void Set(int pY, int pX, double pValue);
00134 
00136     void SetIdentity();
00137     
00143     void SetTRS(const KFbxVector4& pT,
00144                 const KFbxVector4& pR,
00145                 const KFbxVector4& pS);
00146 
00152     void SetTQS(const KFbxVector4& pT,
00153                 const KFbxQuaternion& pQ,
00154                 const KFbxVector4& pS);
00155 
00160     void SetRow(int pY, const KFbxVector4& pRow);
00161 
00166     void SetColumn(int pX, const KFbxVector4& pColumn);
00167 
00176     void GetElements(KFbxVector4 & pTranslation, KFbxQuaternion & pRotation,
00177         KFbxVector4 & pShearing, KFbxVector4 & pScaling, double & pSign) const;
00178 
00182     KFbxMatrix& operator=(const KFbxMatrix& pMatrix);
00183     
00185 
00190 
00194     KFbxMatrix operator-() const;
00195     
00200     KFbxMatrix operator+(const KFbxMatrix& pMatrix) const;
00201 
00206     KFbxMatrix operator-(const KFbxMatrix& pMatrix) const;
00207 
00212     KFbxMatrix operator*(const KFbxMatrix& pMatrix) const;
00213 
00218     KFbxMatrix& operator+=(const KFbxMatrix& pMatrix);
00219 
00224     KFbxMatrix& operator-=(const KFbxMatrix& pMatrix);
00225 
00230     KFbxMatrix& operator*=(const KFbxMatrix& pMatrix);
00231 
00235     KFbxMatrix Inverse() const;
00236 
00240     KFbxMatrix Transpose() const;
00241 
00243 
00248 
00253     KFbxVector4 MultNormalize(const KFbxVector4& pVector) const;
00254 
00256 
00261 
00266     bool operator==(const KFbxMatrix & pM) const;
00267 
00272     bool operator==(const KFbxXMatrix & pM) const;
00273 
00278     bool operator!=(const KFbxMatrix & pM) const;
00279 
00284     bool operator!=(const KFbxXMatrix & pM) const;
00285 
00286     
00288 
00293 
00295     operator double* ();
00296 
00298     operator const double* () const;
00299 
00301     typedef const double(kDouble44)[4][4] ;
00302 
00304     inline kDouble44 & Double44() const { return *((kDouble44 *)&mData); }
00305 
00307 
00308     // Matrix data.
00309 //  double mData[4][4];
00310 
00311 };
00312 
00313 inline EFbxType FbxTypeOf( KFbxMatrix   const &pItem )  { return eDOUBLE44; }
00314 
00315 
00316 #include <fbxfilesdk/fbxfilesdk_nsend.h>
00317 
00318 #endif // FBXFILESDK_KFBXMATH_KFBXMATRIX_H
00319