PxMeshScale.h
Go to the documentation of this file.00001 // This code contains NVIDIA Confidential Information and is disclosed to you 00002 // under a form of NVIDIA software license agreement provided separately to you. 00003 // 00004 // Notice 00005 // NVIDIA Corporation and its licensors retain all intellectual property and 00006 // proprietary rights in and to this software and related documentation and 00007 // any modifications thereto. Any use, reproduction, disclosure, or 00008 // distribution of this software and related documentation without an express 00009 // license agreement from NVIDIA Corporation is strictly prohibited. 00010 // 00011 // ALL NVIDIA DESIGN SPECIFICATIONS, CODE ARE PROVIDED "AS IS.". NVIDIA MAKES 00012 // NO WARRANTIES, EXPRESSED, IMPLIED, STATUTORY, OR OTHERWISE WITH RESPECT TO 00013 // THE MATERIALS, AND EXPRESSLY DISCLAIMS ALL IMPLIED WARRANTIES OF NONINFRINGEMENT, 00014 // MERCHANTABILITY, AND FITNESS FOR A PARTICULAR PURPOSE. 00015 // 00016 // Information and code furnished is believed to be accurate and reliable. 00017 // However, NVIDIA Corporation assumes no responsibility for the consequences of use of such 00018 // information or for any infringement of patents or other rights of third parties that may 00019 // result from its use. No license is granted by implication or otherwise under any patent 00020 // or patent rights of NVIDIA Corporation. Details are subject to change without notice. 00021 // This code supersedes and replaces all information previously supplied. 00022 // NVIDIA Corporation products are not authorized for use as critical 00023 // components in life support devices or systems without express written approval of 00024 // NVIDIA Corporation. 00025 // 00026 // Copyright (c) 2008-2017 NVIDIA Corporation. All rights reserved. 00027 // Copyright (c) 2004-2008 AGEIA Technologies, Inc. All rights reserved. 00028 // Copyright (c) 2001-2004 NovodeX AG. All rights reserved. 00029 00030 00031 #ifndef PX_PHYSICS_NX_MESHSCALE 00032 #define PX_PHYSICS_NX_MESHSCALE 00033 00037 #include "common/PxPhysXCommonConfig.h" 00038 #include "foundation/PxMat33.h" 00039 #include "foundation/PxAssert.h" 00040 00043 #define PX_MESH_SCALE_MIN 1e-6f 00044 00047 #define PX_MESH_SCALE_MAX 1e6f 00048 00049 #if !PX_DOXYGEN 00050 namespace physx 00051 { 00052 #endif 00053 00068 class PxMeshScale 00069 { 00070 //= ATTENTION! ===================================================================================== 00071 // Changing the data layout of this class breaks the binary serialization format. See comments for 00072 // PX_BINARY_SERIAL_VERSION. If a modification is required, please adjust the getBinaryMetaData 00073 // function. If the modification is made on a custom branch, please change PX_BINARY_SERIAL_VERSION 00074 // accordingly. 00075 //================================================================================================== 00076 public: 00080 PX_CUDA_CALLABLE PX_FORCE_INLINE PxMeshScale(): scale(1.0f), rotation(PxIdentity) 00081 { 00082 } 00083 00087 explicit PX_CUDA_CALLABLE PX_FORCE_INLINE PxMeshScale(PxReal r): scale(r), rotation(PxIdentity) 00088 { 00089 } 00090 00094 PX_CUDA_CALLABLE PX_FORCE_INLINE PxMeshScale(const PxVec3& s) 00095 { 00096 scale = s; 00097 rotation = PxQuat(PxIdentity); 00098 } 00099 00103 PX_CUDA_CALLABLE PX_FORCE_INLINE PxMeshScale(const PxVec3& s, const PxQuat& r) 00104 { 00105 PX_ASSERT(r.isUnit()); 00106 scale = s; 00107 rotation = r; 00108 } 00109 00110 00114 PX_CUDA_CALLABLE PX_FORCE_INLINE bool isIdentity() const 00115 { 00116 return (scale.x == 1.0f && scale.y == 1.0f && scale.z == 1.0f); 00117 } 00118 00122 PX_CUDA_CALLABLE PX_FORCE_INLINE PxMeshScale getInverse() const 00123 { 00124 return PxMeshScale(PxVec3(1.0f/scale.x, 1.0f/scale.y, 1.0f/scale.z), rotation); 00125 } 00126 00130 PX_CUDA_CALLABLE PX_FORCE_INLINE PxMat33 toMat33() const 00131 { 00132 PxMat33 rot(rotation); 00133 PxMat33 trans = rot.getTranspose(); 00134 trans.column0 *= scale[0]; 00135 trans.column1 *= scale[1]; 00136 trans.column2 *= scale[2]; 00137 return trans * rot; 00138 } 00139 00143 PX_CUDA_CALLABLE PX_FORCE_INLINE bool hasNegativeDeterminant() const 00144 { 00145 return (scale.x * scale.y * scale.z < 0.0f); 00146 } 00147 00148 PxVec3 transform(const PxVec3& v) const 00149 { 00150 return rotation.rotateInv(scale.multiply(rotation.rotate(v))); 00151 } 00152 00153 bool isValidForTriangleMesh() const 00154 { 00155 PxVec3 absXYZ = scale.abs(); 00156 return (absXYZ.maxElement() <= PX_MESH_SCALE_MAX) && (absXYZ.minElement() >= PX_MESH_SCALE_MIN); 00157 } 00158 00159 bool isValidForConvexMesh() const 00160 { 00161 return (scale.maxElement() <= PX_MESH_SCALE_MAX) && (scale.minElement() >= PX_MESH_SCALE_MIN); 00162 } 00163 00164 PxVec3 scale; 00165 PxQuat rotation; 00166 00167 00168 }; 00169 00170 #if !PX_DOXYGEN 00171 } // namespace physx 00172 #endif 00173 00175 #endif
Copyright © 2008-2017 NVIDIA Corporation, 2701 San Tomas Expressway, Santa Clara, CA 95050 U.S.A. All rights reserved. www.nvidia.com