OGRE 2.1
Object-Oriented Graphics Rendering Engine
|
Portal datastructure for connecting zones. More...
#include <OgrePortal.h>
Public Types | |
typedef FastArray< MovableObject * > | MovableObjectArray |
@See SceneManager::cullFrustum | |
enum | PORTAL_TYPE { PORTAL_TYPE_QUAD , PORTAL_TYPE_AABB , PORTAL_TYPE_SPHERE } |
enum | PortalIntersectResult { NO_INTERSECT , INTERSECT_NO_CROSS , INTERSECT_BACK_NO_CROSS , INTERSECT_CROSS } |
Public Member Functions | |
Portal (const String &name, const PORTAL_TYPE type=PORTAL_TYPE_QUAD) | |
virtual | ~Portal () |
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 | _notifyAttached (Node *parent, bool isTagPoint=false) |
Called when attached to a scene node. | |
void | _notifyManager (SceneManager *man) |
Notify the object of it's manager (internal use only) | |
void | _notifyMoved () |
Called when scene node moved. | |
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. | |
void | _updateRenderQueue (RenderQueue *queue) |
Internal method by which the movable object must add Renderable subclass instances to the rendering queue. | |
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 | 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. | |
void | adjustNodeToMatch (SceneNode *node) |
Adjust the portal so that it is centered and oriented on the given node. | |
void | calcDirectionAndRadius () const |
Calculate the local direction and radius of the portal. | |
bool | closeTo (const PortalBase *otherPortal) |
Check if portal touches another portal. | |
virtual AnimableValuePtr | createAnimableValue (const String &valueName) |
Create a reference-counted AnimableValuePtr for the named value. | |
bool | crossedPortal (const PortalBase *otherPortal) |
Check if portal crossed over portal. | |
void | detachFromParent (void) |
Detaches an object from a parent SceneNode if attached. | |
const AxisAlignedBox & | getAAB () |
Returns an updated AAB of the portal for intersection test. | |
const StringVector & | getAnimableValueNames (void) const |
Gets a list of animable value names for this object. | |
const AxisAlignedBox & | getBoundingBox () const |
Real | getBoundingRadius () const |
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. | |
const Capsule & | getCapsule () const |
Returns an updated capsule of the portal for intersection test. | |
bool | getCastShadows (void) const |
Returns whether shadow casting is enabled for this object. | |
const Vector3 & | getCorner (int index) const |
Get the coordinates of one of the portal corners in local space. | |
PCZone * | getCurrentHomeZone () |
Get the Zone the Portal is currently "in". | |
unsigned char | getCurrentMeshLod (void) const |
const Vector3 & | getDerivedCorner (int index) const |
Get the derived (world) coordinates of one of the portal corners. | |
const Vector3 & | getDerivedCP () const |
Get the position (centerpoint) of the portal in world coordinates. | |
const Vector3 & | getDerivedDirection () const |
Get the direction of the portal in world coordinates. | |
const Plane & | getDerivedPlane () const |
Get the portal plane in world coordinates. | |
const Sphere & | getDerivedSphere () const |
Get the sphere centered on the derived CP of the portal in world coordinates. | |
const Vector3 & | getDirection () const |
Get the direction vector of the portal in local space. | |
bool | getEnabled () const |
Check if portal is enabled. | |
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. | |
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. | |
const String & | getMovableType () const |
Returns the type name of this object. | |
const String & | getName (void) const |
Returns the name of this object. | |
PCZone * | getNewHomeZone () |
Get the Zone the Portal should be moved to. | |
Node * | getParentNode (void) const |
Returns the node to which this object is attached. | |
SceneNode * | getParentSceneNode (void) const |
const Vector3 & | getPrevDerivedCP () const |
Get the previous position (centerpoint) of the portal in world coordinates. | |
const Plane & | getPrevDerivedPlane () const |
Get the previous portal plane in world coordinates. | |
uint32 | getQueryFlags (void) const |
Returns the query flags relevant for this object. | |
Real | getRadius () const |
Retrieve the radius of the portal (calculates if necessary for quad portals) | |
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. | |
uint8 | getRenderQueueGroup (void) const |
Gets the queue group for this entity, see setRenderQueueGroup for full details. | |
Real | getShadowRenderingDistance (void) const |
Gets the distance at which batches are no longer casting shadows. | |
SkeletonInstance * | getSkeletonInstance (void) const |
Portal * | getTargetPortal () |
Get the connected portal (if any) | |
PCZone * | getTargetZone () |
Get the Zone the Portal connects to. | |
PORTAL_TYPE | getType () const |
Get the type of portal. | |
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. | |
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. | |
virtual const AxisAlignedBox & | getWorldBoundingBox (bool derive=false) const |
Retrieves the axis-aligned bounding box for this object in world coordinates. | |
virtual const Sphere & | getWorldBoundingSphere (bool derive=false) const |
Retrieves the worldspace bounding sphere for this object. | |
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 void | instanceBatchCullFrustumThreaded (const Frustum *frustum, const Camera *lodCamera, uint32 combinedVisibilityFlags) |
@See InstancingTheadedCullingMethod, | |
bool | intersects (const AxisAlignedBox &aab) |
Check if portal intersects an aab. | |
bool | intersects (const PlaneBoundedVolume &pbv) |
Check if portal intersects a plane bounded volume. | |
bool | intersects (const Ray &ray) |
Check if portal intersects a ray. | |
bool | intersects (const Sphere &sphere) |
Check if portal intersects an sphere. | |
PortalIntersectResult | intersects (PCZSceneNode *sn) |
Check for intersection between portal & scenenode (also determines if scenenode crosses over portal. | |
bool | isAttached (void) const |
Returns true if this object is attached to a Node. | |
bool | isStatic () const |
Checks whether this MovableObject is static. @See setStatic. | |
bool | isVisible (void) const |
Returns whether or not this object is supposed to be visible or not. | |
bool | needUpdate () |
Returns true if portal needs update. | |
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) |
const LightList & | queryLights (void) const |
Gets a list of lights, ordered relative to how close they are to this movable object. | |
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. | |
void | setCastShadows (bool enabled) |
Sets whether or not this object will cast shadows. | |
void | setCorner (int index, const Vector3 &point) |
Set the local coordinates of one of the portal corners. | |
void | setCorners (const Vector3 *corners) |
Set the local coordinates of all of the portal corners. | |
void | setCurrentHomeZone (PCZone *zone) |
Set the current home zone of the portal. | |
void | setDirection (const Vector3 &d) |
Set the "inward/outward norm" direction of AAB or SPHERE portals NOTE: UNIT_Z = "outward" norm, NEGATIVE_UNIT_Z = "inward" norm NOTE: Remember, Portal norms always point towards the zone they are "in". | |
void | setEnabled (bool value) |
enable the portal | |
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. | |
void | setName (const String &name) |
Sets a custom name for this node. | |
void | setNewHomeZone (PCZone *zone) |
Set the zone this portal should be moved to. | |
void | setNode (SceneNode *sn) |
Set the SceneNode the Portal is associated with. | |
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 | 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 | setTargetPortal (Portal *portal) |
Set the target portal pointer. | |
void | setTargetZone (PCZone *zone) |
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. | |
void | updateDerivedValues () const |
Update the derived values. | |
void | visitRenderables (Renderable::Visitor *visitor, bool debugRenderables=false) |
Public Attributes | |
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). | |
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 |
Portal datastructure for connecting zones.
@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 |
|
inherited |
|
inherited |
Ogre::Portal::Portal | ( | const String & | name, |
const PORTAL_TYPE | type = PORTAL_TYPE_QUAD |
||
) |
|
virtual |
|
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.
Called when attached to a scene node.
|
inlineinherited |
Notify the object of it's manager (internal use only)
|
inlineinherited |
Called when scene node moved.
@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.
|
inlineinherited |
Internal method by which the movable object must add Renderable subclass instances to the rendering queue.
|
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.
Adjust the portal so that it is centered and oriented on the given node.
|
staticinherited |
@See SceneManager::buildLightList
globalLightList | List of lights already culled against all possible frustums and reorganized contiguously for SoA |
|
inherited |
Calculate the local direction and radius of the portal.
|
staticinherited |
|
inherited |
Check if portal touches another portal.
|
inlinevirtualinherited |
Create a reference-counted AnimableValuePtr for the named value.
Reimplemented in Ogre::Light.
References Ogre::Exception::ERR_ITEM_NOT_FOUND, and OGRE_EXCEPT.
|
inherited |
Check if portal crossed over portal.
|
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.
|
inherited |
Returns an updated AAB of the portal for intersection test.
|
inlineinherited |
Gets a list of animable value names for this object.
References Ogre::Exception::ERR_ITEM_NOT_FOUND, and OGRE_EXCEPT.
|
inherited |
|
inlineinherited |
|
inlineinherited |
Returns the distance to camera as calculated in @cullFrustum.
Returns the distance to camera as calculated in @cullFrustum.
Returns an updated capsule of the portal for intersection test.
Returns whether shadow casting is enabled for this object.
Get the coordinates of one of the portal corners in local space.
|
inlineinherited |
Get the Zone the Portal is currently "in".
Get the default query flags for all future MovableObject instances.
Get the default visibility flags for all future MovableObject instances.
Get the derived (world) coordinates of one of the portal corners.
Get the position (centerpoint) of the portal in world coordinates.
Get the direction of the portal in world coordinates.
Get the portal plane in world coordinates.
Get the sphere centered on the derived CP of the portal in world coordinates.
Get the direction vector of the portal in local space.
|
inlineinherited |
Check if portal is enabled.
|
inlineinherited |
Get the unique id of this object.
|
inlineinherited |
Get a bitwise mask which will filter the lights affecting this object.
Gets the current listener for this object.
Retrieves the local axis-aligned bounding box for this object.
See getLocalAabb and getWorldRadius.
Returns the type name of this object.
Implements Ogre::MovableObject.
Returns the name of this object.
|
inlineinherited |
Get the Zone the Portal should be moved to.
Returns the node to which this object is attached.
Get the previous position (centerpoint) of the portal in world coordinates.
Get the previous portal plane in world coordinates.
Returns the query flags relevant for this object.
|
inherited |
Retrieve the radius of the portal (calculates if necessary for quad portals)
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.
Gets the queue group for this entity, see setRenderQueueGroup for full details.
Gets the distance at which batches are no longer casting shadows.
|
inlineinherited |
|
inline |
Get the connected portal (if any)
|
inlineinherited |
Get the type of portal.
|
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.
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.
|
virtualinherited |
Retrieves the axis-aligned bounding box for this object in world coordinates.
|
virtualinherited |
Retrieves the worldspace bounding sphere for this object.
|
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 ).
|
inlinevirtualinherited |
@See InstancingTheadedCullingMethod,
|
inherited |
Check if portal intersects an aab.
|
inherited |
Check if portal intersects a plane bounded volume.
Check if portal intersects an sphere.
|
inherited |
Check for intersection between portal & scenenode (also determines if scenenode crosses over portal.
Returns true if this object is attached to a Node.
|
inherited |
Checks whether this MovableObject is static. @See setStatic.
Returns whether or not this object is supposed to be visible or not.
|
inherited |
Returns true if portal needs update.
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
|
inlineinherited |
operator new, with debug line info
placement operator new
|
inlineinherited |
|
inlineinherited |
array operator new, with debug line info
Gets a list of lights, ordered relative to how close they are to this movable object.
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.
Sets whether or not this object will cast shadows.
Set the local coordinates of one of the portal corners.
Set the local coordinates of all of the portal corners.
Set the current home zone of the portal.
Set the default query flags for all future MovableObject instances.
Set the default visibility flags for all future MovableObject instances.
Set the "inward/outward norm" direction of AAB or SPHERE portals NOTE: UNIT_Z = "outward" norm, NEGATIVE_UNIT_Z = "inward" norm NOTE: Remember, Portal norms always point towards the zone they are "in".
References OGRE_EXCEPT.
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.
Sets a custom name for this node.
Doesn't have to be unique
Set the zone this portal should be moved to.
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 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 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
|
inherited |
Update the derived values.
|
inlineinherited |
|
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 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 |