PxPlane.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-2012 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_FOUNDATION_PX_PLANE_H 00032 #define PX_FOUNDATION_PX_PLANE_H 00033 00038 #include "foundation/PxMath.h" 00039 #include "foundation/PxVec3.h" 00040 00041 #ifndef PX_DOXYGEN 00042 namespace physx 00043 { 00044 #endif 00045 00051 class PxPlane 00052 { 00053 public: 00057 PX_CUDA_CALLABLE PX_FORCE_INLINE PxPlane() 00058 { 00059 } 00060 00064 PX_CUDA_CALLABLE PX_FORCE_INLINE PxPlane(PxReal nx, PxReal ny, PxReal nz, PxReal distance) 00065 : n(nx, ny, nz) 00066 , d(distance) 00067 { 00068 } 00069 00073 PX_CUDA_CALLABLE PX_FORCE_INLINE PxPlane(const PxVec3& normal, PxReal distance) 00074 : n(normal) 00075 , d(distance) 00076 { 00077 } 00078 00079 00083 PX_CUDA_CALLABLE PX_FORCE_INLINE PxPlane(const PxVec3& point, const PxVec3& normal) 00084 : n(normal) 00085 , d(-point.dot(n)) // p satisfies normal.dot(p) + d = 0 00086 { 00087 } 00088 00092 PX_CUDA_CALLABLE PX_FORCE_INLINE PxPlane(const PxVec3& p0, const PxVec3& p1, const PxVec3& p2) 00093 { 00094 n = (p1 - p0).cross(p2 - p0).getNormalized(); 00095 d = -p0.dot(n); 00096 } 00097 00098 PX_CUDA_CALLABLE PX_FORCE_INLINE PxReal distance(const PxVec3& p) const 00099 { 00100 return p.dot(n) + d; 00101 } 00102 00103 PX_CUDA_CALLABLE PX_FORCE_INLINE bool contains(const PxVec3& p) const 00104 { 00105 return PxAbs(distance(p)) < (1.0e-7f); 00106 } 00107 00111 PX_CUDA_CALLABLE PX_FORCE_INLINE PxVec3 project(const PxVec3 & p) const 00112 { 00113 return p - n * distance(p); 00114 } 00115 00119 PX_CUDA_CALLABLE PX_FORCE_INLINE PxVec3 pointInPlane() const 00120 { 00121 return -n*d; 00122 } 00123 00128 PX_CUDA_CALLABLE PX_FORCE_INLINE void normalize() 00129 { 00130 PxReal denom = 1.0f / n.magnitude(); 00131 n *= denom; 00132 d *= denom; 00133 } 00134 00135 00136 PxVec3 n; 00137 PxReal d; 00138 }; 00139 00140 #ifndef PX_DOXYGEN 00141 } // namespace physx 00142 #endif 00143 00145 #endif 00146
Copyright © 2008-2012 NVIDIA Corporation, 2701 San Tomas Expressway, Santa Clara, CA 95050 U.S.A. All rights reserved. www.nvidia.com