5 template<
typename genType>
8 genType
const& orig, genType
const& dir,
9 genType
const& planeOrig, genType
const& planeNormal,
10 typename genType::value_type & intersectionDistance
13 typename genType::value_type d = glm::dot(dir, planeNormal);
14 typename genType::value_type Epsilon = std::numeric_limits<typename genType::value_type>::epsilon();
18 typename genType::value_type
const tmp_intersectionDistance = glm::dot(planeOrig - orig, planeNormal) / d;
19 if (tmp_intersectionDistance >
static_cast<typename genType::value_type
>(0)) {
20 intersectionDistance = tmp_intersectionDistance;
28 template<
typename T, qualifier Q>
44 T
const det = glm::dot(edge1, p);
48 if(det > std::numeric_limits<T>::epsilon())
54 baryPosition.x = glm::dot(dist, p);
55 if(baryPosition.x <
static_cast<T
>(0) || baryPosition.x > det)
62 baryPosition.y = glm::dot(dir, Perpendicular);
63 if((baryPosition.y <
static_cast<T
>(0)) || ((baryPosition.x + baryPosition.y) > det))
66 else if(det < -std::numeric_limits<T>::epsilon())
72 baryPosition.x = glm::dot(dist, p);
73 if((baryPosition.x >
static_cast<T
>(0)) || (baryPosition.x < det))
80 baryPosition.y = glm::dot(dir, Perpendicular);
81 if((baryPosition.y >
static_cast<T
>(0)) || (baryPosition.x + baryPosition.y < det))
87 T inv_det =
static_cast<T
>(1) / det;
90 distance = glm::dot(edge2, Perpendicular) * inv_det;
91 baryPosition *= inv_det;
96 template<
typename genType>
99 genType
const& orig, genType
const& dir,
100 genType
const& vert0, genType
const& vert1, genType
const& vert2,
104 typename genType::value_type Epsilon = std::numeric_limits<typename genType::value_type>::epsilon();
106 genType edge1 = vert1 - vert0;
107 genType edge2 = vert2 - vert0;
109 genType Perpendicular =
cross(dir, edge2);
111 float det = dot(edge1, Perpendicular);
113 if (det > -Epsilon && det < Epsilon)
115 typename genType::value_type inv_det =
typename genType::value_type(1) / det;
117 genType Tengant = orig - vert0;
119 position.y = dot(Tengant, Perpendicular) * inv_det;
120 if (position.y <
typename genType::value_type(0) || position.y >
typename genType::value_type(1))
123 genType Cotengant =
cross(Tengant, edge1);
125 position.z = dot(dir, Cotengant) * inv_det;
126 if (position.z <
typename genType::value_type(0) || position.y + position.z >
typename genType::value_type(1))
129 position.x = dot(edge2, Cotengant) * inv_det;
134 template<
typename genType>
137 genType
const& rayStarting, genType
const& rayNormalizedDirection,
138 genType
const& sphereCenter,
const typename genType::value_type sphereRadiusSquered,
139 typename genType::value_type & intersectionDistance
142 typename genType::value_type Epsilon = std::numeric_limits<typename genType::value_type>::epsilon();
143 genType diff = sphereCenter - rayStarting;
144 typename genType::value_type t0 = dot(diff, rayNormalizedDirection);
145 typename genType::value_type dSquared = dot(diff, diff) - t0 * t0;
146 if( dSquared > sphereRadiusSquered )
150 typename genType::value_type t1 =
sqrt( sphereRadiusSquered - dSquared );
151 intersectionDistance = t0 > t1 + Epsilon ? t0 - t1 : t0 + t1;
152 return intersectionDistance > Epsilon;
155 template<
typename genType>
158 genType
const& rayStarting, genType
const& rayNormalizedDirection,
159 genType
const& sphereCenter,
const typename genType::value_type sphereRadius,
160 genType & intersectionPosition, genType & intersectionNormal
163 typename genType::value_type distance;
164 if(
intersectRaySphere( rayStarting, rayNormalizedDirection, sphereCenter, sphereRadius * sphereRadius, distance ) )
166 intersectionPosition = rayStarting + rayNormalizedDirection * distance;
167 intersectionNormal = (intersectionPosition - sphereCenter) / sphereRadius;
173 template<
typename genType>
176 genType
const& point0, genType
const& point1,
177 genType
const& sphereCenter,
typename genType::value_type sphereRadius,
178 genType & intersectionPoint1, genType & intersectionNormal1,
179 genType & intersectionPoint2, genType & intersectionNormal2
182 typename genType::value_type Epsilon = std::numeric_limits<typename genType::value_type>::epsilon();
183 genType dir =
normalize(point1 - point0);
184 genType diff = sphereCenter - point0;
185 typename genType::value_type t0 = dot(diff, dir);
186 typename genType::value_type dSquared = dot(diff, diff) - t0 * t0;
187 if( dSquared > sphereRadius * sphereRadius )
191 typename genType::value_type t1 =
sqrt( sphereRadius * sphereRadius - dSquared );
192 if( t0 < t1 + Epsilon )
194 intersectionPoint1 = point0 + dir * (t0 - t1);
195 intersectionNormal1 = (intersectionPoint1 - sphereCenter) / sphereRadius;
196 intersectionPoint2 = point0 + dir * (t0 + t1);
197 intersectionNormal2 = (intersectionPoint2 - sphereCenter) / sphereRadius;
GLM_FUNC_DECL GLM_CONSTEXPR genType abs(genType x)
GLM_FUNC_QUALIFIER vec< L, T, Q > sqrt(vec< L, T, Q > const &x)
Definition func_exponential.inl:128
GLM_FUNC_QUALIFIER vec< L, T, Q > normalize(vec< L, T, Q > const &x)
Definition func_geometric.inl:190
GLM_FUNC_QUALIFIER vec< 3, T, Q > cross(vec< 3, T, Q > const &x, vec< 3, T, Q > const &y)
Definition func_geometric.inl:175
GLM_FUNC_DECL bool intersectRayTriangle(vec< 3, T, Q > const &orig, vec< 3, T, Q > const &dir, vec< 3, T, Q > const &v0, vec< 3, T, Q > const &v1, vec< 3, T, Q > const &v2, vec< 2, T, Q > &baryPosition, T &distance)
Definition intersect.inl:30
GLM_FUNC_DECL bool intersectLineSphere(genType const &point0, genType const &point1, genType const &sphereCenter, typename genType::value_type sphereRadius, genType &intersectionPosition1, genType &intersectionNormal1, genType &intersectionPosition2=genType(), genType &intersectionNormal2=genType())
Definition intersect.inl:175
GLM_FUNC_DECL bool intersectLineTriangle(genType const &orig, genType const &dir, genType const &vert0, genType const &vert1, genType const &vert2, genType &position)
Definition intersect.inl:98
GLM_FUNC_DECL bool intersectRaySphere(genType const &rayStarting, genType const &rayNormalizedDirection, genType const &sphereCenter, typename genType::value_type const sphereRadiusSquered, typename genType::value_type &intersectionDistance)
Definition intersect.inl:136
GLM_FUNC_DECL bool intersectRayPlane(genType const &orig, genType const &dir, genType const &planeOrig, genType const &planeNormal, typename genType::value_type &intersectionDistance)
Definition intersect.inl:7
Core features
Definition common.hpp:21
Definition qualifier.hpp:35