| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354 |
- #include "CmSphere.h"
- #include "CmRay.h"
- #include "CmPlane.h"
- #include "CmAABox.h"
- namespace BansheeEngine
- {
- std::pair<bool, float> Sphere::intersects(const Ray& ray, bool discardInside) const
- {
- const Vector3& raydir = ray.getDirection();
- const Vector3& rayorig = ray.getOrigin() - getCenter();
- float radius = getRadius();
- // Check origin inside first
- if (rayorig.squaredLength() <= radius*radius && discardInside)
- {
- return std::pair<bool, float>(true, 0.0f);
- }
- // t = (-b +/- sqrt(b*b + 4ac)) / 2a
- float a = raydir.dot(raydir);
- float b = 2 * rayorig.dot(raydir);
- float c = rayorig.dot(rayorig) - radius*radius;
- // Determinant
- float d = (b*b) - (4 * a * c);
- if (d < 0)
- {
- // No intersection
- return std::pair<bool, float>(false, 0.0f);
- }
- else
- {
- // If d == 0 there is one intersection, if d > 0 there are 2.
- // We only return the first one.
-
- float t = ( -b - Math::sqrt(d) ) / (2 * a);
- if (t < 0)
- t = ( -b + Math::sqrt(d) ) / (2 * a);
- return std::pair<bool, float>(true, t);
- }
- }
- bool Sphere::intersects(const Plane& plane) const
- {
- return (Math::abs(plane.getDistance(getCenter())) <= getRadius());
- }
- bool Sphere::intersects(const AABox& box) const
- {
- return box.intersects(*this);
- }
- }
|