OGRE 2.1
Object-Oriented Graphics Rendering Engine
|
A frustum represents a pyramid, capped at the near and far end which is used to represent either a visible area or a projection area. More...
#include <OgreFrustum.h>
Public Types | |
typedef map< size_t, Vector4 >::type | CustomParameterMap |
typedef FastArray< MovableObject * > | MovableObjectArray |
@See SceneManager::cullFrustum | |
Public Member Functions | |
Frustum (IdType id, ObjectMemoryManager *objectMemoryManager) | |
Named constructor. | |
virtual | ~Frustum () |
const Plane * | _getCachedFrustumPlanes (void) const |
Returns the frustum planes, doesn't check if dirty. | |
const Vector3 * | _getCachedWorldSpaceCorners (void) const |
LightList * | _getLightList () |
Returns a pointer to the current list of lights for this object. | |
SceneManager * | _getManager (void) const |
Get the manager of this object, if any (internal use only) | |
ObjectData & | _getObjectData () |
Returns a direct access to the ObjectData state. | |
const Matrix4 & | _getParentNodeFullTransform (void) const |
Returns the full transformation of the parent sceneNode or the attachingPoint node. | |
virtual void | _notifyAttached (Node *parent) |
Internal method called to notify the object that it has been attached to a node. | |
void | _notifyManager (SceneManager *man) |
Notify the object of it's manager (internal use only) | |
virtual void | _notifyParentNodeMemoryChanged (void) |
@See Node::_callMemoryChangeListeners | |
virtual void | _notifyStaticDirty (void) const |
Called by SceneManager when it is telling we're a static MovableObject being dirty Don't call this directly. | |
virtual void | _releaseManualHardwareResources () |
Notifies the movable object that hardware resources were lost. | |
virtual void | _restoreManualHardwareResources () |
Notifies the movable object that hardware resources should be restored. | |
virtual void | _setHlmsHashes (uint32 hash, uint32 casterHash) |
Manually sets the hlms hashes. Don't call this directly. | |
virtual void | _setNullDatablock (void) |
Sets the datablock to a null pointer. | |
virtual void | _updateCustomGpuParameter (const GpuProgramParameters::AutoConstantEntry &constantEntry, GpuProgramParameters *params) const |
Update a custom GpuProgramParameters constant which is derived from information only this Renderable knows. | |
virtual void | _updateRenderQueue (RenderQueue *queue, Camera *camera, const Camera *lodCamera) |
Internal method by which the movable object must add Renderable subclass instances to the rendering queue. | |
void | addPoseWeight (size_t index, float w) |
void | addQueryFlags (uint32 flags) |
As setQueryFlags, except the flags passed as parameters are appended to the existing flags on this object. | |
void | addVisibilityFlags (uint32 flags) |
As setVisibilityFlags, except the flags passed as parameters are appended to the existing flags on this object. | |
virtual void | calcViewMatrixRelative (const Vector3 &relPos, Matrix4 &matToUpdate) const |
Calculate a view matrix for this frustum, relative to a potentially dynamic point. | |
virtual AnimableValuePtr | createAnimableValue (const String &valueName) |
Create a reference-counted AnimableValuePtr for the named value. | |
void | detachFromParent (void) |
Detaches an object from a parent SceneNode if attached. | |
virtual void | disableCustomNearClipPlane (void) |
Disables any custom near clip plane. | |
virtual void | disableReflection (void) |
Disables reflection modification previously turned on with enableReflection. | |
virtual void | enableCustomNearClipPlane (const MovablePlane *plane) |
Links the frustum to a custom near clip plane, which can be used to clip geometry in a custom manner without using user clip planes. | |
virtual void | enableCustomNearClipPlane (const Plane &plane) |
Links the frustum to a custom near clip plane, which can be used to clip geometry in a custom manner without using user clip planes. | |
virtual void | enableReflection (const MovablePlane *p) |
Modifies this frustum so it always renders from the reflection of itself through the plane specified. | |
virtual void | enableReflection (const Plane &p) |
Modifies this frustum so it always renders from the reflection of itself through the plane specified. | |
const StringVector & | getAnimableValueNames (void) const |
Gets a list of animable value names for this object. | |
virtual Real | getAspectRatio (void) const |
Retrieves the current aspect ratio. | |
const AxisAlignedBox & | getBoundingBox (void) const |
Overridden from MovableObject. | |
RealAsUint | getCachedDistanceToCamera (void) const |
Returns the distance to camera as calculated in @cullFrustum. | |
Real | getCachedDistanceToCameraAsReal (void) const |
Returns the distance to camera as calculated in @cullFrustum. | |
bool | getCastShadows (void) const |
Returns whether shadow casting is enabled for this object. | |
virtual bool | getCastsShadows (void) const |
Method which reports whether this renderable would normally cast a shadow. | |
uint8 | getCurrentMaterialLod (void) const |
unsigned char | getCurrentMeshLod (void) const |
const Vector4 & | getCustomParameter (size_t index) const |
Gets the custom value associated with this Renderable at the given index. | |
const CustomParameterMap & | getCustomParameters (void) const |
void | getCustomWorldSpaceCorners (ArrayVector3 outCorners[(8+ARRAY_PACKED_REALS - 1)/ARRAY_PACKED_REALS], Real customFarPlane) const |
HlmsDatablock * | getDatablock (void) const |
virtual Real | getFarClipDistance (void) const |
Retrieves the distance from the frustum to the far clipping plane. | |
virtual Real | getFocalLength () const |
Returns focal length of frustum. | |
virtual const Radian & | getFOVy (void) const |
Retrieves the frustums Y-dimension Field Of View (FOV). | |
virtual void | getFrustumExtents (Real &outleft, Real &outright, Real &outtop, Real &outbottom, FrustrumExtentsType frustrumExtentsType=FET_PROJ_PLANE_POS) const |
Get the extents of the frustum in view space. | |
virtual const Vector2 & | getFrustumOffset () const |
Retrieves the frustum offsets. | |
const Plane & | getFrustumPlane (unsigned short plane) const |
Retrieves a specified plane of the frustum (world space). | |
const Plane * | getFrustumPlanes (void) const |
Retrieves the clipping planes of the frustum (world space). | |
uint32 | getHlmsCasterHash (void) const |
uint32 | getHlmsHash (void) const |
IdType | getId () const |
Get the unique id of this object. | |
uint32 | getLightMask () const |
Get a bitwise mask which will filter the lights affecting this object. | |
const LightList & | getLights (void) const |
Overridden from Renderable. | |
Listener * | getListener (void) const |
Gets the current listener for this object. | |
Aabb | getLocalAabb (void) const |
Retrieves the local axis-aligned bounding box for this object. | |
float | getLocalRadius (void) const |
See getLocalAabb and getWorldRadius. | |
MaterialPtr | getMaterial (void) const |
Retrieves the material this renderable object uses. | |
const String & | getMovableType (void) const |
Overridden from MovableObject. | |
const String & | getName (void) const |
Returns the name of this object. | |
virtual Real | getNearClipDistance (void) const |
Sets the position of the near clipping plane. | |
unsigned short | getNumPoses (void) const |
virtual unsigned short | getNumWorldTransforms (void) const |
Returns the number of world transform matrices this renderable requires. | |
virtual const Quaternion & | getOrientationForViewUpdate (void) const |
Get the derived orientation of this frustum. | |
OrientationMode | getOrientationMode () const |
Get the orientation mode of the frustum. | |
virtual Real | getOrthoWindowHeight () const |
Gets the orthographic window height, for use with orthographic rendering only. | |
virtual Real | getOrthoWindowWidth () const |
Gets the orthographic window width, for use with orthographic rendering only. | |
Node * | getParentNode (void) const |
Returns the node to which this object is attached. | |
SceneNode * | getParentSceneNode (void) const |
PlaneBoundedVolume | getPlaneBoundedVolume () |
Gets a world-space list of planes enclosing the frustum. | |
virtual bool | getPolygonModeOverrideable (void) const |
Gets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting. | |
bool | getPoseHalfPrecision () const |
bool | getPoseNormals () const |
TexBufferPacked * | getPoseTexBuffer () const |
float | getPoseWeight (size_t index) const |
float * | getPoseWeights () const |
virtual const Vector3 & | getPositionForViewUpdate (void) const |
Get the derived position of this frustum. | |
virtual const Matrix4 & | getProjectionMatrix (void) const |
Gets the normal projection matrix for this frustum, ie the projection matrix which conforms to standard right-handed rules and uses depth range [-1,+1]. | |
virtual const Matrix4 & | getProjectionMatrixRS (void) const |
Gets the projection matrix for this frustum adjusted for the current rendersystem specifics (may be right or left-handed, depth range may vary). | |
virtual const Matrix4 & | getProjectionMatrixWithRSDepth (void) const |
Gets the depth-adjusted projection matrix for the current rendersystem, but one which still conforms to right-hand rules. | |
virtual ProjectionType | getProjectionType (void) const |
Retrieves info on the type of projection used (orthographic or perspective). | |
uint32 | getQueryFlags (void) const |
Returns the query flags relevant for this object. | |
virtual const Matrix4 & | getReflectionMatrix (void) const |
Returns the reflection matrix of the frustum if appropriate. | |
virtual const Plane & | getReflectionPlane (void) const |
Returns the reflection plane of the frustum if appropriate. | |
Real | getRenderingDistance (void) const |
Gets the distance at which batches are no longer rendered. | |
Real | getRenderingMinPixelSize () const |
Returns the minimum pixel size an object needs to be in both screen axes in order to be rendered. | |
void | getRenderOperation (v1::RenderOperation &op, bool casterPass) |
Overridden from Renderable. | |
uint8 | getRenderQueueGroup (void) const |
Gets the queue group for this entity, see setRenderQueueGroup for full details. | |
uint8 | getRenderQueueSubGroup (void) const |
Real | getShadowRenderingDistance (void) const |
Gets the distance at which batches are no longer casting shadows. | |
SkeletonInstance * | getSkeletonInstance (void) const |
Real | getSquaredViewDepth (const Camera *cam) const |
Overridden from Renderable. | |
bool | getUseIdentityProjection (void) const |
Returns whether or not to use an 'identity' projection. | |
bool | getUseIdentityView (void) const |
Returns whether or not to use an 'identity' view. | |
virtual bool | getUseIdentityViewProjMatrixIsDynamic (void) const |
Returns whether the Hlms implementation should evaluate getUseIdentityProjection per object at runtime, or if it can assume the Renderable will remain with the same setting until the datablock is flushed (performance optimization) | |
virtual bool | getUseIdentityWorldMatrix (void) const |
Returns whether the world matrix is an identity matrix. | |
virtual OGRE_DEPRECATED const Any & | getUserAny (void) const |
UserObjectBindings & | getUserObjectBindings () |
Return an instance of user objects binding associated with this class. | |
UserObjectBindings & | getUserObjectBindings () |
Return an instance of user objects binding associated with this class. | |
const UserObjectBindings & | getUserObjectBindings () const |
Return an instance of user objects binding associated with this class. | |
const UserObjectBindings & | getUserObjectBindings () const |
Return an instance of user objects binding associated with this class. | |
const VertexArrayObjectArray & | getVaos (VertexPass vertexPass) const |
virtual const Matrix4 & | getViewMatrix (void) const |
Gets the view matrix for this frustum. | |
uint32 | getVisibilityFlags (void) const |
Returns the visibility flags relevant for this object. | |
bool | getVisible (void) const |
Gets this object whether to be visible or not, if it has a renderable component. | |
Aabb | getWorldAabb () const |
Gets the axis aligned box in world space. | |
Aabb | getWorldAabbUpdated () |
Gets the axis aligned box in world space. | |
float | getWorldRadius () const |
Gets the bounding Radius scaled by max( scale.x, scale.y, scale.z ). | |
float | getWorldRadiusUpdated () |
Gets the bounding Radius scaled by max( scale.x, scale.y, scale.z ). | |
virtual const Vector3 * | getWorldSpaceCorners (void) const |
Gets the world space corners of the frustum. | |
void | getWorldTransforms (Matrix4 *xform) const |
Overridden from Renderable. | |
bool | hasCustomParameter (size_t index) const |
Checks whether a custom value is associated with this Renderable at the given index. | |
bool | hasSkeletonAnimation (void) const |
virtual void | instanceBatchCullFrustumThreaded (const Frustum *frustum, const Camera *lodCamera, uint32 combinedVisibilityFlags) |
@See InstancingTheadedCullingMethod, | |
bool | isAttached (void) const |
Returns true if this object is attached to a Node. | |
virtual bool | isCustomNearClipPlaneEnabled (void) const |
Is a custom near clip plane in use? | |
virtual bool | isCustomProjectionMatrixEnabled (void) const |
Returns whether a custom projection matrix is in use. | |
virtual bool | isCustomViewMatrixEnabled (void) const |
Returns whether a custom view matrix is in use. | |
virtual bool | isReflected (void) const |
Returns whether this frustum is being reflected. | |
bool | isStatic () const |
Checks whether this MovableObject is static. @See setStatic. | |
virtual bool | isVisible (const AxisAlignedBox &bound, FrustumPlane *culledBy=0) const |
Tests whether the given container is visible in the Frustum. | |
virtual bool | isVisible (const Sphere &bound, FrustumPlane *culledBy=0) const |
Tests whether the given container is visible in the Frustum. | |
virtual bool | isVisible (const Vector3 &vert, FrustumPlane *culledBy=0) const |
Tests whether the given vertex is visible in the Frustum. | |
bool | isVisible (void) const |
Returns whether or not this object is supposed to be visible or not. | |
void | operator delete (void *ptr) |
void | operator delete (void *ptr, const char *, int, const char *) |
void | operator delete (void *ptr, void *) |
void | operator delete[] (void *ptr) |
void | operator delete[] (void *ptr, const char *, int, const char *) |
void * | operator new (size_t sz) |
void * | operator new (size_t sz, const char *file, int line, const char *func) |
operator new, with debug line info | |
void * | operator new (size_t sz, void *ptr) |
placement operator new | |
void * | operator new[] (size_t sz) |
void * | operator new[] (size_t sz, const char *file, int line, const char *func) |
array operator new, with debug line info | |
bool | operator() (const IdObject &left, const IdObject &right) |
bool | operator() (const IdObject *left, const IdObject *right) |
virtual void | postRender (SceneManager *sm, RenderSystem *rsys) |
Called immediately after the Renderable has been rendered. | |
virtual bool | preRender (SceneManager *sm, RenderSystem *rsys) |
Called just prior to the Renderable being rendered. | |
virtual bool | projectSphere (const Sphere &sphere, Real *left, Real *top, Real *right, Real *bottom) const |
Project a sphere onto the near plane and get the bounding rectangle. | |
const LightList & | queryLights (void) const |
Gets a list of lights, ordered relative to how close they are to this movable object. | |
void | removeCustomParameter (size_t index) |
Removes a custom value which is associated with this Renderable at the given index. | |
void | removeQueryFlags (uint32 flags) |
As setQueryFlags, except the flags passed as parameters are removed from the existing flags on this object. | |
void | removeVisibilityFlags (uint32 flags) |
As setVisibilityFlags, except the flags passed as parameters are removed from the existing flags on this object. | |
virtual void | resetFrustumExtents () |
Reset the frustum extents to be automatically derived from other params. | |
virtual void | setAspectRatio (Real ratio) |
Sets the aspect ratio for the frustum viewport. | |
void | setCastShadows (bool enabled) |
Sets whether or not this object will cast shadows. | |
void | setCustomParameter (size_t index, const Vector4 &value) |
Sets a custom parameter for this Renderable, which may be used to drive calculations for this specific Renderable, like GPU program parameters. | |
virtual void | setCustomProjectionMatrix (bool enable, const Matrix4 &projectionMatrix=Matrix4::IDENTITY, bool alternateDepthRange=false) |
Set whether to use a custom projection matrix on this frustum. | |
virtual void | setCustomViewMatrix (bool enable, const Matrix4 &viewMatrix=Matrix4::IDENTITY) |
Set whether to use a custom view matrix on this frustum. | |
virtual void | setDatablock (HlmsDatablock *datablock) |
Assigns a datablock (i.e. HLMS Material) to this renderable. | |
void | setDatablock (IdString datablockName) |
Assigns a datablock (i.e. | |
void | setDatablockOrMaterialName (String materialName, String groupName) |
First tries to see if an HLMS datablock exist with the given name, if not, tries to search among low level materials. | |
virtual void | setFarClipDistance (Real farDist) |
Sets the distance to the far clipping plane. | |
virtual void | setFocalLength (Real focalLength=1.0) |
Sets frustum focal length (used in stereo rendering). | |
virtual void | setFOVy (const Radian &fovy) |
Sets the Y-dimension Field Of View (FOV) of the frustum. | |
virtual void | setFrustumExtents (Real left, Real right, Real top, Real bottom, FrustrumExtentsType frustrumExtentsType=FET_PROJ_PLANE_POS) |
Manually set the extents of the frustum. | |
virtual void | setFrustumOffset (const Vector2 &offset) |
Sets frustum offsets, used in stereo rendering. | |
virtual void | setFrustumOffset (Real horizontal=0.0, Real vertical=0.0) |
Sets frustum offsets, used in stereo rendering. | |
void | setLightMask (uint32 lightMask) |
Set a bitwise mask which will filter the lights affecting this object. | |
void | setListener (Listener *listener) |
Sets a listener for this object. | |
void | setLocalAabb (const Aabb box) |
Sets the local axis-aligned bounding box for this object. | |
virtual void | setMaterial (const MaterialPtr &material) |
Sets the given material. Overrides HLMS materials. | |
void | setMaterialName (const String &name, const String &groupName) |
Sets the name of the Material to be used. Prefer using HLMS @See setHlms. | |
void | setName (const String &name) |
Sets a custom name for this node. | |
virtual void | setNearClipDistance (Real nearDist) |
Sets the position of the near clipping plane. | |
void | setOrientationMode (OrientationMode orientationMode) |
Set the orientation mode of the frustum. | |
virtual void | setOrthoWindow (Real w, Real h) |
Sets the orthographic window settings, for use with orthographic rendering only. | |
virtual void | setOrthoWindowHeight (Real h) |
Sets the orthographic window height, for use with orthographic rendering only. | |
virtual void | setOrthoWindowWidth (Real w) |
Sets the orthographic window width, for use with orthographic rendering only. | |
virtual void | setPolygonModeOverrideable (bool override) |
Sets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting. | |
void | setPoseWeight (size_t index, float w) |
virtual void | setProjectionType (ProjectionType pt) |
Sets the type of projection to use (orthographic or perspective). | |
void | setQueryFlags (uint32 flags) |
Sets the query flags for this object. | |
void | setRenderingDistance (Real dist) |
Sets the distance at which the object is no longer rendered. | |
void | setRenderingMinPixelSize (Real pixelSize) |
Sets the minimum pixel size an object needs to be in both screen axes in order to be rendered. | |
virtual void | setRenderQueueGroup (uint8 queueID) |
Sets the render queue group this entity will be rendered through. | |
void | setRenderQueueSubGroup (uint8 subGroup) |
Sets the render queue sub group. | |
void | setShadowRenderingDistance (Real dist) |
Sets the distance at which the object is no longer casting shadows. | |
bool | setStatic (bool bStatic) |
Turns this Node into static or dynamic. | |
void | setUseIdentityProjection (bool useIdentityProjection) |
Sets whether or not to use an 'identity' projection. | |
void | setUseIdentityView (bool useIdentityView) |
Sets whether or not to use an 'identity' view. | |
virtual OGRE_DEPRECATED void | setUserAny (const Any &anything) |
void | setVisibilityFlags (uint32 flags) |
Sets the visibility flags for this object. | |
void | setVisible (bool visible) |
Tells this object whether to be visible or not, if it has a renderable component. | |
Public Attributes | |
uint8 | mCustomParameter |
Only valid when using low level materials. | |
size_t | mGlobalIndex |
Index in the vector holding this MO reference (could be our parent node, or a global array tracking all movable objecst to avoid memory leaks). | |
uint32 | mHlmsGlobalIndex |
Index in the vector holding this Rendrable reference in the HLMS datablock. | |
size_t | mParentIndex |
Index in the vector holding this MO reference (could be our parent node, or a global array tracking all movable objecst to avoid memory leaks). | |
RenderableArray | mRenderables |
Static Public Attributes | |
static const FastArray< Real > | c_DefaultLodMesh |
static const Real | INFINITE_FAR_PLANE_ADJUST |
Small constant used to reduce far plane projection to avoid inaccuracies. | |
A frustum represents a pyramid, capped at the near and far end which is used to represent either a visible area or a projection area.
Can be used for a number of applications.
|
inherited |
@See SceneManager::cullFrustum
frustum | Frustum to clip against |
sceneVisibilityFlags | Combined scene's visibility flags (i.e. viewport | scene). Set LAYER_SHADOW_CASTER bit if you want to exclude non-shadow casters. |
outCulledObjects | Out. List of objects that are (fully or partially) inside the frustum and should be rendered |
lodCamera | Camera in which lod levels calculations are based (i.e. during shadow pass renders) Note however, we only use this camera to calulate if should be visible according to mUpperDistance |
Ogre::Frustum::Frustum | ( | IdType | id, |
ObjectMemoryManager * | objectMemoryManager | ||
) |
Named constructor.
|
virtual |
Returns the frustum planes, doesn't check if dirty.
|
inlineinherited |
Returns a pointer to the current list of lights for this object.
|
inlineinherited |
Get the manager of this object, if any (internal use only)
|
inlineinherited |
Returns a direct access to the ObjectData state.
Returns the full transformation of the parent sceneNode or the attachingPoint node.
Internal method called to notify the object that it has been attached to a node.
Reimplemented in Ogre::v1::Entity, Ogre::v1::InstancedEntity, and Ogre::ParticleSystem.
|
inlineinherited |
Notify the object of it's manager (internal use only)
@See Node::_callMemoryChangeListeners
Reimplemented in Ogre::v1::InstancedEntity, and Ogre::Item.
Called by SceneManager when it is telling we're a static MovableObject being dirty Don't call this directly.
Reimplemented in Ogre::v1::InstancedEntity.
Notifies the movable object that hardware resources were lost.
Reimplemented in Ogre::v1::BillboardSet, and Ogre::v1::ManualObject.
Notifies the movable object that hardware resources should be restored.
Manually sets the hlms hashes. Don't call this directly.
Reimplemented in Ogre::SubItem.
Sets the datablock to a null pointer.
Use case: If you will be destroying an HlmsDatablock and all Renderables associated by it; it makes no sense to change the Renderable's datablock to a default one, only to be destroyed immediately after (you pay an unnecessary performance price).
Reimplemented in Ogre::v1::BillboardSet, and Ogre::v1::SubEntity.
|
inlinevirtualinherited |
Update a custom GpuProgramParameters constant which is derived from information only this Renderable knows.
constantEntry | The auto constant entry referring to the parameter being updated |
params | The parameters object which this method should call to set the updated parameters. |
Reimplemented in Ogre::v1::SubEntity.
|
inlinevirtualinherited |
Internal method by which the movable object must add Renderable subclass instances to the rendering queue.
Reimplemented in Ogre::v1::BillboardChain, Ogre::MovablePlane, Ogre::v1::BillboardSet, Ogre::v1::Entity, Ogre::v1::InstanceBatchHW, Ogre::v1::InstanceBatchHW_VTF, Ogre::v1::BaseInstanceBatchVTF, Ogre::v1::InstancedEntity, Ogre::Light, Ogre::v1::ManualObject, Ogre::ParticleSystem, and Ogre::v1::StaticGeometry::Region.
As setQueryFlags, except the flags passed as parameters are appended to the existing flags on this object.
As setVisibilityFlags, except the flags passed as parameters are appended to the existing flags on this object.
|
staticinherited |
@See SceneManager::buildLightList
globalLightList | List of lights already culled against all possible frustums and reorganized contiguously for SoA |
|
staticinherited |
|
virtual |
Calculate a view matrix for this frustum, relative to a potentially dynamic point.
Mainly for use by OGRE internally when using camera-relative rendering for frustums that are not the centre (e.g. texture projection)
|
inlinevirtualinherited |
Create a reference-counted AnimableValuePtr for the named value.
Reimplemented in Ogre::Light.
References Ogre::Exception::ERR_ITEM_NOT_FOUND, and OGRE_EXCEPT.
|
staticinherited |
|
staticinherited |
@See SceneManager::cullLights &
outGlobalLightList | Output, a list of lights, contiguously placed |
frustums | An array of all frustums we need to check against |
cubemapFrustums | An array of all frustums that are used at least once as cubemaps (@See SceneManager::createCamera) |
Detaches an object from a parent SceneNode if attached.
Disables any custom near clip plane.
Disables reflection modification previously turned on with enableReflection.
|
virtual |
Links the frustum to a custom near clip plane, which can be used to clip geometry in a custom manner without using user clip planes.
plane | The plane to link to to perform the clipping. This plane must continue to exist while the camera is linked to it; do not destroy it before the frustum. |
Links the frustum to a custom near clip plane, which can be used to clip geometry in a custom manner without using user clip planes.
plane | The plane to link to to perform the clipping. This plane must continue to exist while the camera is linked to it; do not destroy it before the frustum. |
|
virtual |
Modifies this frustum so it always renders from the reflection of itself through the plane specified.
Note that this version of the method links to a plane so that changes to it are picked up automatically. It is important that this plane continues to exist whilst this object does; do not destroy the plane before the frustum.
Modifies this frustum so it always renders from the reflection of itself through the plane specified.
|
inlineinherited |
Gets a list of animable value names for this object.
References Ogre::Exception::ERR_ITEM_NOT_FOUND, and OGRE_EXCEPT.
Retrieves the current aspect ratio.
const AxisAlignedBox & Ogre::Frustum::getBoundingBox | ( | void | ) | const |
Overridden from MovableObject.
|
inlineinherited |
Returns the distance to camera as calculated in @cullFrustum.
Returns the distance to camera as calculated in @cullFrustum.
Returns whether shadow casting is enabled for this object.
Method which reports whether this renderable would normally cast a shadow.
Reimplemented in Ogre::v1::StaticGeometry::GeometryBucket, Ogre::v1::SubEntity, Ogre::SubItem, Ogre::WireAabb, and Ogre::ManualObject::ManualObjectSection.
Gets the custom value associated with this Renderable at the given index.
index | Index of the parameter to retrieve. |
References Ogre::Exception::ERR_ITEM_NOT_FOUND, and OGRE_EXCEPT.
|
inlineinherited |
void Ogre::Frustum::getCustomWorldSpaceCorners | ( | ArrayVector3 | outCorners[(8+ARRAY_PACKED_REALS - 1)/ARRAY_PACKED_REALS], |
Real | customFarPlane | ||
) | const |
|
inlineinherited |
Get the default query flags for all future MovableObject instances.
Get the default visibility flags for all future MovableObject instances.
Retrieves the distance from the frustum to the far clipping plane.
Reimplemented in Ogre::Camera.
Retrieves the frustums Y-dimension Field Of View (FOV).
|
virtual |
Get the extents of the frustum in view space.
left,right,top,bottom | The position where the side clip planes intersect the near clip plane, in eye space OR the tangent of the half angles from the eye to the edges of the near clip plane |
frustrumExtentsType | Specifies in what format the extents are returned. See OgreFrustrum::setFrustumExtents for more information |
Retrieves the frustum offsets.
Retrieves a specified plane of the frustum (world space).
Retrieves the clipping planes of the frustum (world space).
|
inlineinherited |
Get the unique id of this object.
|
inlineinherited |
Get a bitwise mask which will filter the lights affecting this object.
Overridden from Renderable.
Implements Ogre::Renderable.
Gets the current listener for this object.
Retrieves the local axis-aligned bounding box for this object.
See getLocalAabb and getWorldRadius.
|
inherited |
Retrieves the material this renderable object uses.
It may be null if it's using the HLMS. @See getDatablock
Overridden from MovableObject.
Implements Ogre::MovableObject.
Returns the name of this object.
Sets the position of the near clipping plane.
Reimplemented in Ogre::Camera.
|
inlinevirtualinherited |
Returns the number of world transform matrices this renderable requires.
Reimplemented in Ogre::v1::BorderRenderable, Ogre::v1::InstanceBatchHW, Ogre::v1::InstanceBatchShader, Ogre::v1::BaseInstanceBatchVTF, and Ogre::v1::SubEntity.
|
virtual |
Get the derived orientation of this frustum.
Reimplemented in Ogre::Camera.
OrientationMode Ogre::Frustum::getOrientationMode | ( | ) | const |
Get the orientation mode of the frustum.
Gets the orthographic window height, for use with orthographic rendering only.
Gets the orthographic window width, for use with orthographic rendering only.
Returns the node to which this object is attached.
PlaneBoundedVolume Ogre::Frustum::getPlaneBoundedVolume | ( | ) |
Gets a world-space list of planes enclosing the frustum.
Gets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.
Reimplemented in Ogre::v1::BorderRenderable.
Referenced by Ogre::v1::BorderRenderable::getPolygonModeOverrideable().
|
inherited |
|
inherited |
|
inherited |
|
inherited |
Get the derived position of this frustum.
Reimplemented in Ogre::Camera.
Gets the normal projection matrix for this frustum, ie the projection matrix which conforms to standard right-handed rules and uses depth range [-1,+1].
Gets the projection matrix for this frustum adjusted for the current rendersystem specifics (may be right or left-handed, depth range may vary).
Gets the depth-adjusted projection matrix for the current rendersystem, but one which still conforms to right-hand rules.
|
virtual |
Retrieves info on the type of projection used (orthographic or perspective).
Returns the query flags relevant for this object.
Returns the reflection matrix of the frustum if appropriate.
Returns the reflection plane of the frustum if appropriate.
Gets the distance at which batches are no longer rendered.
|
inlineinherited |
Returns the minimum pixel size an object needs to be in both screen axes in order to be rendered.
|
virtual |
Overridden from Renderable.
Implements Ogre::Renderable.
Gets the queue group for this entity, see setRenderQueueGroup for full details.
Gets the distance at which batches are no longer casting shadows.
|
inlineinherited |
Overridden from Renderable.
Returns whether or not to use an 'identity' projection.
Returns whether or not to use an 'identity' view.
|
inlinevirtualinherited |
Returns whether the Hlms implementation should evaluate getUseIdentityProjection per object at runtime, or if it can assume the Renderable will remain with the same setting until the datablock is flushed (performance optimization)
Returns whether the world matrix is an identity matrix.
Reimplemented in Ogre::v1::BillboardSet.
|
inlinevirtualinherited |
Reimplemented in Ogre::v1::InstanceBatch.
|
inlineinherited |
Return an instance of user objects binding associated with this class.
You can use it to associate one or more custom objects with this class instance.
|
inlineinherited |
Return an instance of user objects binding associated with this class.
You can use it to associate one or more custom objects with this class instance.
|
inlineinherited |
Return an instance of user objects binding associated with this class.
You can use it to associate one or more custom objects with this class instance.
|
inlineinherited |
Return an instance of user objects binding associated with this class.
You can use it to associate one or more custom objects with this class instance.
|
inlineinherited |
Gets the view matrix for this frustum.
Mainly for use by OGRE internally.
Reimplemented in Ogre::Camera.
Returns the visibility flags relevant for this object.
Reserved visibility flags are not returned.
Gets this object whether to be visible or not, if it has a renderable component.
|
inherited |
Gets the axis aligned box in world space.
|
inherited |
Gets the axis aligned box in world space.
|
inherited |
Gets the bounding Radius scaled by max( scale.x, scale.y, scale.z ).
|
inherited |
Gets the bounding Radius scaled by max( scale.x, scale.y, scale.z ).
Gets the world space corners of the frustum.
Reimplemented in Ogre::Camera.
Overridden from Renderable.
Implements Ogre::Renderable.
Checks whether a custom value is associated with this Renderable at the given index.
index | Index of the parameter to check for existence. |
|
inlinevirtualinherited |
@See InstancingTheadedCullingMethod,
Returns true if this object is attached to a Node.
Is a custom near clip plane in use?
Returns whether a custom projection matrix is in use.
Returns whether a custom view matrix is in use.
Returns whether this frustum is being reflected.
|
inherited |
Checks whether this MovableObject is static. @See setStatic.
|
virtual |
Tests whether the given container is visible in the Frustum.
bound | Bounding box to be checked (world space). |
culledBy | Optional pointer to an int which will be filled by the plane number which culled the box if the result was false ; |
true
is returned. false
is returned. Reimplemented in Ogre::Camera, and Ogre::PCZCamera.
|
virtual |
Tests whether the given container is visible in the Frustum.
bound | Bounding sphere to be checked (world space). |
culledBy | Optional pointer to an int which will be filled by the plane number which culled the box if the result was false ; |
true
is returned. false
is returned. Reimplemented in Ogre::Camera.
|
virtual |
Tests whether the given vertex is visible in the Frustum.
vert | Vertex to be checked (world space). |
culledBy | Optional pointer to an int which will be filled by the plane number which culled the box if the result was false ; |
true
is returned. false
is returned. Reimplemented in Ogre::Camera.
Returns whether or not this object is supposed to be visible or not.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
operator new, with debug line info
placement operator new
|
inlineinherited |
|
inlineinherited |
array operator new, with debug line info
|
inlinevirtualinherited |
Called immediately after the Renderable has been rendered.
|
inlinevirtualinherited |
Called just prior to the Renderable being rendered.
Reimplemented in Ogre::v1::BillboardChain.
|
virtual |
Project a sphere onto the near plane and get the bounding rectangle.
sphere | The world-space sphere to project. |
left | Pointers to destination values, these will be completed with the normalised device coordinates (in the range {-1,1}). |
top | Pointers to destination values, these will be completed with the normalised device coordinates (in the range {-1,1}). |
right | Pointers to destination values, these will be completed with the normalised device coordinates (in the range {-1,1}). |
bottom | Pointers to destination values, these will be completed with the normalised device coordinates (in the range {-1,1}). |
true
if the sphere was projected to a subset of the near plane, false
if the entire near plane was contained. Reimplemented in Ogre::Camera.
Gets a list of lights, ordered relative to how close they are to this movable object.
Removes a custom value which is associated with this Renderable at the given index.
index | Index of the parameter to remove. |
As setQueryFlags, except the flags passed as parameters are removed from the existing flags on this object.
As setVisibilityFlags, except the flags passed as parameters are removed from the existing flags on this object.
Reset the frustum extents to be automatically derived from other params.
Sets the aspect ratio for the frustum viewport.
Sets whether or not this object will cast shadows.
Sets a custom parameter for this Renderable, which may be used to drive calculations for this specific Renderable, like GPU program parameters.
index | The index with which to associate the value. Note that this does not have to start at 0, and can include gaps. It also has no direct correlation with a GPU program parameter index - the mapping between the two is performed by the ACT_CUSTOM entry, if that is used. |
value | The value to associate. |
|
virtual |
Set whether to use a custom projection matrix on this frustum.
See Frustum::setCustomViewMatrix
enable | If true , the custom projection matrix passed as the second parameter will be used in preference to an auto calculated one. If false , the frustum will revert to auto calculating the projection matrix. |
projectionMatrix | The custom view matrix to use. |
alternateDepthRange | Set this to true if the input projectionMatrix has the depth in range [0; 1] instead of the range [-1; 1] that Ogre expects. |
Projection matrices obtained from Oculus SDK's need to set this to true.
Note that we will internally convert the projection matrix by performing the range conversion, so don't expect Frustum::getProjectionMatrix to return you exactly the same projection matrix you passed to us!
|
virtual |
Set whether to use a custom view matrix on this frustum.
enable | If true , the custom view matrix passed as the second parameter will be used in preference to an auto calculated one. If false, the frustum will revert to auto calculating the view matrix. |
viewMatrix | The custom view matrix to use, the matrix must be an affine matrix. |
|
virtualinherited |
Assigns a datablock (i.e. HLMS Material) to this renderable.
Reimplemented in Ogre::v1::BillboardSet, Ogre::v1::SubEntity, and Ogre::v1::SubEntity.
Assigns a datablock (i.e.
HLMS material) based on its unique name.
|
inherited |
First tries to see if an HLMS datablock exist with the given name, if not, tries to search among low level materials.
Set the default query flags for all future MovableObject instances.
Set the default visibility flags for all future MovableObject instances.
Sets the distance to the far clipping plane.
farDist | The distance to the far clipping plane from the frustum in world coordinates.If you specify 0, this means an infinite view distance which is useful especially when projecting shadows; but be careful not to use a near distance too close. |
Sets frustum focal length (used in stereo rendering).
focalLength | The distance to the focal plane from the frustum in world coordinates. |
Sets the Y-dimension Field Of View (FOV) of the frustum.
|
virtual |
Manually set the extents of the frustum.
left,right,top,bottom | The position where the side clip planes intersect the near clip plane, in eye space OR the tangent of the half angles from the eye to the edges of the near clip plane |
frustrumExtentsType | Specifies how the extents are represented. Be default they are the positions on near clip plane. However if this is a scene camera it is recommended that you actually use the tangent of the half angles. ie Half the FoV angles. This is because Ogre uses this camera setup to calculate custom clipping planes for PSSM algorithms, and Forward+ algorithms, but alter the near and far clip distances. |
Sets frustum offsets, used in stereo rendering.
offset | The horizontal and vertical plane offsets. |
Sets frustum offsets, used in stereo rendering.
horizontal | The horizontal plane offset. |
vertical | The vertical plane offset. |
Set a bitwise mask which will filter the lights affecting this object.
Sets a listener for this object.
Sets the local axis-aligned bounding box for this object.
|
virtualinherited |
Sets the given material. Overrides HLMS materials.
Reimplemented in Ogre::v1::SimpleRenderable, Ogre::v1::BillboardSet, and Ogre::v1::SubEntity.
Sets the name of the Material to be used. Prefer using HLMS @See setHlms.
Sets a custom name for this node.
Doesn't have to be unique
Sets the position of the near clipping plane.
nearDist | The distance to the near clipping plane from the frustum in world coordinates. |
void Ogre::Frustum::setOrientationMode | ( | OrientationMode | orientationMode | ) |
Set the orientation mode of the frustum.
Default is OR_DEGREE_0
Sets the orthographic window settings, for use with orthographic rendering only.
w | The width of the view window in world units. |
h | The height of the view window in world units. |
Sets the orthographic window height, for use with orthographic rendering only.
h | The height of the view window in world units. |
Sets the orthographic window width, for use with orthographic rendering only.
w | The width of the view window in world units. |
Sets whether this renderable's chosen detail level can be overridden (downgraded) by the camera setting.
override | true means that a lower camera detail will override this renderables detail level, false means it won't. |
|
virtual |
Sets the type of projection to use (orthographic or perspective).
Default is perspective.
Reimplemented in Ogre::PCZCamera.
Sets the query flags for this object.
Sets the distance at which the object is no longer rendered.
dist | Distance beyond which the object will not be rendered (the default is FLT_MAX, which means objects are always rendered). Values equal or below zero will be ignored, and cause an assertion in debug mode. |
Sets the minimum pixel size an object needs to be in both screen axes in order to be rendered.
pixelSize | Number of minimum pixels (the default is 0, which means objects are always rendered). |
Sets the render queue group this entity will be rendered through.
queueID | Enumerated value of the queue group to use. See the enum RenderQueueGroupID for what kind of values can be used here. |
Reimplemented in Ogre::Decal, Ogre::v1::Entity, Ogre::Light, and Ogre::ParticleSystem.
Sets the render queue sub group.
subGroup | The sub group. This value can't exceed OGRE_MAKE_MASK( SubRqIdBits ) @See RenderQueue |
Sets the distance at which the object is no longer casting shadows.
dist | Distance beyond which the object will not cast shadows (the default is FLT_MAX, which means objects are always casting shadows). Values equal or below zero will be ignored, and cause an assertion in debug mode. |
Turns this Node into static or dynamic.
Sets whether or not to use an 'identity' projection.
Sets whether or not to use an 'identity' view.
|
inlinevirtualinherited |
Reimplemented in Ogre::v1::InstanceBatch.
Sets the visibility flags for this object.
Tells this object whether to be visible or not, if it has a renderable component.
|
staticinherited |
@See SceneManager::updateAllBounds
Small constant used to reduce far plane projection to avoid inaccuracies.
|
inherited |
Only valid when using low level materials.
|
inherited |
Index in the vector holding this MO reference (could be our parent node, or a global array tracking all movable objecst to avoid memory leaks).
Used for O(1) removals.
|
inherited |
Index in the vector holding this Rendrable reference in the HLMS datablock.
Used for O(1) removals.
|
inherited |
Index in the vector holding this MO reference (could be our parent node, or a global array tracking all movable objecst to avoid memory leaks).
Used for O(1) removals.
|
inherited |