OGRE
1.12.13
Object-Oriented Graphics Rendering Engine
|
Defines a plane in 3D space. More...
#include <OgrePlane.h>
Public Types | |
enum | Side { NO_SIDE, POSITIVE_SIDE, NEGATIVE_SIDE, BOTH_SIDE } |
The "positive side" of the plane is the half space to which the plane normal points. More... | |
Public Member Functions | |
Plane () | |
Default constructor - sets everything to 0. More... | |
Plane (const Vector3 &p0, const Vector3 &p1, const Vector3 &p2) | |
Plane (const Vector3 &rkNormal, const Vector3 &rkPoint) | |
Plane (const Vector3 &rkNormal, Real fConstant) | |
Construct a plane through a normal, and a distance to move the plane along the normal. More... | |
Plane (const Vector4 &v) | |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More... | |
Plane (Real a, Real b, Real c, Real _d) | |
Construct a plane using the 4 constants directly. More... | |
Real | getDistance (const Vector3 &rkPoint) const |
This is a pseudodistance. More... | |
Side | getSide (const AxisAlignedBox &box) const |
Returns the side where the alignedBox is. More... | |
Side | getSide (const Vector3 ¢re, const Vector3 &halfSize) const |
Returns which side of the plane that the given box lies on. More... | |
Side | getSide (const Vector3 &rkPoint) const |
Real | normalise (void) |
Normalises the plane. More... | |
bool | operator!= (const Plane &rhs) const |
Plane | operator- () const |
Get flipped plane, with same location but reverted orientation. More... | |
bool | operator== (const Plane &rhs) const |
Comparison operator. More... | |
Vector3 | projectVector (const Vector3 &v) const |
Project a vector onto the plane. More... | |
void | redefine (const Vector3 &p0, const Vector3 &p1, const Vector3 &p2) |
Redefine this plane based on 3 points. More... | |
void | redefine (const Vector3 &rkNormal, const Vector3 &rkPoint) |
Redefine this plane based on a normal and a point. More... | |
Public Attributes | |
Real | d |
Vector3 | normal |
Defines a plane in 3D space.
enum Ogre::Plane::Side |
|
inline |
Default constructor - sets everything to 0.
Construct a plane through a normal, and a distance to move the plane along the normal.
Construct a plane using the 4 constants directly.
|
inlineexplicit |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.
References NEGATIVE_SIDE, NO_SIDE, and POSITIVE_SIDE.
Referenced by Ogre::PlaneBoundedVolume::intersects(), and Ogre::Math::intersects().
|
inline |
Returns the side where the alignedBox is.
The flag BOTH_SIDE indicates an intersecting box. One corner ON the plane is sufficient to consider the box and the plane intersecting.
References Ogre::AxisAlignedBox::getCenter(), Ogre::AxisAlignedBox::getHalfSize(), Ogre::AxisAlignedBox::isInfinite(), and Ogre::AxisAlignedBox::isNull().
Returns which side of the plane that the given box lies on.
The box is defined as centre/half-size pairs for effectively.
centre | The centre of the box. |
halfSize | The half-size of the box. |
This is a pseudodistance.
The sign of the return value is positive if the point is on the positive side of the plane, negative if the point is on the negative side, and zero if the point is on the plane.
References Ogre::Vector< dims, T >::dotProduct().
Referenced by Ogre::Sphere::intersects(), and Ogre::PlaneBoundedVolume::intersects().
Redefine this plane based on 3 points.
References Ogre::Math::calculateBasicFaceNormal(), and Ogre::Vector< dims, T >::dotProduct().
Redefine this plane based on a normal and a point.
References Ogre::Vector< dims, T >::dotProduct().
Project a vector onto the plane.
v | The input vector |
|
inline |
Normalises the plane.
References Ogre::Vector< dims, T >::length().
|
inline |
Get flipped plane, with same location but reverted orientation.
|
inline |
Vector3 Ogre::Plane::normal |
Referenced by Ogre::Ray::intersects(), operator!=(), Ogre::operator*(), and operator==().
Real Ogre::Plane::d |
Referenced by Ogre::Ray::intersects(), operator!=(), Ogre::operator*(), and operator==().