00001 00004 #ifndef FBXFILESDK_KFBXMATH_KFBXQUATERNION_H 00005 #define FBXFILESDK_KFBXMATH_KFBXQUATERNION_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 00044 #include <fbxfilesdk/components/kbaselib/kaydaradef_h.h> 00045 #include <fbxfilesdk/components/kbaselib/kaydara.h> 00046 00047 #include <fbxfilesdk/kfbxmath/kfbxvector4.h> 00048 00049 #include <fbxfilesdk/fbxfilesdk_nsbegin.h> 00050 00054 class KFBX_DLL KFbxQuaternion : public fbxDouble4 00055 { 00056 00057 public: 00058 00063 00065 KFbxQuaternion(); 00066 00070 KFbxQuaternion(const KFbxQuaternion& pV); 00071 00078 KFbxQuaternion(double pX, double pY, double pZ, double pW = 1.0); 00079 00081 ~KFbxQuaternion(); 00082 00084 00089 00093 KFbxQuaternion& operator=(const KFbxQuaternion& pQuaternion); 00094 00100 double& operator[](int pIndex); 00101 00107 const double& operator[](int pIndex) const; 00108 00114 double GetAt(int pIndex) const; 00115 00121 void SetAt(int pIndex, double pValue); 00122 00129 void Set(double pX, double pY, double pZ, double pW = 1.0); 00130 00132 00137 00143 KFbxQuaternion operator+(double pValue) const; 00144 00150 KFbxQuaternion operator-(double pValue) const; 00151 00157 KFbxQuaternion operator*(double pValue) const; 00158 00164 KFbxQuaternion operator/(double pValue) const; 00165 00171 KFbxQuaternion& operator+=(double pValue); 00172 00178 KFbxQuaternion& operator-=(double pValue); 00179 00185 KFbxQuaternion& operator*=(double pValue); 00186 00192 KFbxQuaternion& operator/=(double pValue); 00193 00195 00200 00204 KFbxQuaternion operator-() const; 00205 00211 KFbxQuaternion operator+(const KFbxQuaternion& pQuaternion) const; 00212 00218 KFbxQuaternion operator-(const KFbxQuaternion& pQuaternion) const; 00219 00225 KFbxQuaternion operator*(const KFbxQuaternion& pQuaternion) const; 00226 00232 KFbxQuaternion operator/(const KFbxQuaternion& pQuaternion) const; 00233 00239 KFbxQuaternion& operator+=(const KFbxQuaternion& pQuaternion); 00240 00246 KFbxQuaternion& operator-=(const KFbxQuaternion& pQuaternion); 00247 00253 KFbxQuaternion& operator*=(const KFbxQuaternion& pQuaternion); 00254 00260 KFbxQuaternion& operator/=(const KFbxQuaternion& pQuaternion); 00261 00266 KFbxQuaternion Product(const KFbxQuaternion& pQuaternion) const; 00267 00270 void Normalize(); 00271 00275 void Conjugate(); 00276 00280 void ComposeSphericalXYZ(const KFbxVector4 pEuler); 00281 00285 KFbxVector4 DecomposeSphericalXYZ() const; 00286 00288 00293 00298 bool operator==(const KFbxQuaternion & pV) const; 00299 00304 bool operator!=(const KFbxQuaternion & pV) const; 00305 00307 00312 00314 operator double* (); 00315 00317 operator const double* () const; 00318 00320 00321 00323 // 00324 // WARNING! 00325 // 00326 // Anything beyond these lines may not be documented accurately and is 00327 // subject to change without notice. 00328 // 00330 00331 #ifndef DOXYGEN_SHOULD_SKIP_THIS 00332 void GetKFbxQuaternionFromPositionToPosition(const KFbxVector4 &pP0, const KFbxVector4 &pP1); 00333 #endif //doxygen 00334 00335 }; 00336 00337 inline EFbxType FbxTypeOf( KFbxQuaternion const &pItem ) { return eDOUBLE4; } 00338 00339 #include <fbxfilesdk/fbxfilesdk_nsend.h> 00340 00341 #endif // FBXFILESDK_KFBXMATH_KFBXQUATERNION_H 00342