kfbxxmatrix.h

Go to the documentation of this file.
00001 
00004 #ifndef _FBXSDK_X_MATRIX_H_
00005 #define _FBXSDK_X_MATRIX_H_
00006 
00007 /**************************************************************************************
00008 
00009  Copyright © 2000 - 2007 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 #include <kaydaradef.h>
00043 #ifndef KFBX_DLL 
00044     #define KFBX_DLL K_DLLIMPORT
00045 #endif
00046 
00047 #include <kaydara.h>
00048 
00049 #include <kfbxmath/kfbxquaternion.h>
00050 #include <kfbxmath/kfbxvector4.h>
00051 #include <kfbxmath/kfbxtransformation.h>
00052 
00053 #include <kbaselib_forward.h>
00054 
00055 #include <fbxfilesdk_nsbegin.h>
00056 
00061 class KFBX_DLL KFbxXMatrix
00062 {
00063 public:
00064 
00069 
00071     KFbxXMatrix();
00072 
00074     KFbxXMatrix(const KFbxXMatrix& pXMatrix);
00075 
00081     KFbxXMatrix(KFbxVector4& pT,
00082                 KFbxVector4& pR,
00083                 KFbxVector4& pS);
00084         
00086     ~KFbxXMatrix();
00087         
00089 
00094 
00100     double Get(int pY, int pX);
00101 
00105     KFbxVector4 GetT();
00106 
00110     KFbxVector4 GetR();
00111 
00115     KFbxQuaternion GetQ();
00116 
00120     KFbxVector4 GetS();
00121 
00126     KFbxVector4 GetRow(int pY);
00127 
00132     KFbxVector4 GetColumn(int pX);
00133 
00135     void SetIdentity();
00136     
00140     void SetT(KFbxVector4& pT);
00141 
00145     void SetR(KFbxVector4& pR);
00146 
00150     void SetQ(KFbxQuaternion& pQ);
00151 
00155     void SetS(KFbxVector4& pS);
00156 
00162     void SetTRS(KFbxVector4& pT,
00163                 KFbxVector4& pR,
00164                 KFbxVector4& pS);
00165 
00171     void SetTQS(KFbxVector4& pT,
00172                 KFbxQuaternion& pQ,
00173                 KFbxVector4& pS);
00174 
00176     KFbxXMatrix& operator=(const KFbxXMatrix& pM);
00177     
00179 
00184 
00190     KFbxXMatrix operator*(double pValue);
00191 
00197     KFbxXMatrix operator/(double pValue);
00198 
00204     KFbxXMatrix& operator*=(double pValue);
00205 
00211     KFbxXMatrix& operator/=(double pValue);
00212 
00214 
00219 
00224     KFbxVector4 MultT(KFbxVector4& pVector4);
00225 
00230     KFbxVector4 MultR(KFbxVector4& pVector4);
00231     
00236     KFbxQuaternion MultQ(KFbxQuaternion& pQuaternion);
00237 
00242     KFbxVector4 MultS(KFbxVector4& pVector4);
00243         
00245 
00250 
00254     KFbxXMatrix operator-();
00255     
00260     KFbxXMatrix operator*(KFbxXMatrix& pXMatrix);
00261 
00266     KFbxXMatrix& operator*=(KFbxXMatrix& pXMatrix);
00267 
00271     KFbxXMatrix Inverse();
00272 
00276     KFbxXMatrix Transpose();
00277 
00279 
00284 
00289     bool operator==(KFbxXMatrix& pXMatrix);
00290 
00295     bool operator!=(KFbxXMatrix& pXMatrix);
00296     
00298 
00303     
00305     operator double* ();
00306 
00308 
00309     
00310 
00311 
00313 //
00314 //  WARNING!
00315 //
00316 //  Anything beyond these lines may not be documented accurately and is 
00317 //  subject to change without notice.
00318 //
00320 
00321 #ifndef DOXYGEN_SHOULD_SKIP_THIS    
00322 
00323 
00324     
00325 
00326     void V2M(KFbxXMatrix &pMatrix, KFbxVector4 &pVector, ERotationOrder pRotationOrder);
00327     void M2V(KFbxVector4 &pVector, KFbxXMatrix &pMatrix, ERotationOrder pRotationOrder);
00328 
00333 
00334     KFbxXMatrix& operator=(const KgeAMatrix& pAMatrix);
00335     operator KgeAMatrix& ();
00336 
00338 
00339     // Matrix data.
00340     double mData[4][4];
00341 
00342 #endif // #ifndef DOXYGEN_SHOULD_SKIP_THIS
00343 
00344 };
00345 
00346 #include <fbxfilesdk_nsend.h>
00347 
00348 #endif // #ifndef _FBXSDK_X_MATRIX_H_
00349 
00350