OGRE 14.3
Object-Oriented Graphics Rendering Engine
|
The PCZSceneNode is an extension used to store zone information and provide additional functionality for a given Ogre::SceneNode. More...
#include <OgrePCZSceneNode.h>
Public Member Functions | |
PCZSceneNode (SceneManager *creator) | |
Standard constructor. | |
PCZSceneNode (SceneManager *creator, const String &name) | |
Standard constructor. | |
~PCZSceneNode () | |
Standard destructor. | |
void | _addToRenderQueue (Camera *cam, RenderQueue *queue, bool onlyShadowCasters, VisibleObjectsBoundsInfo *visibleBounds) |
void | _update (bool updateChildren, bool parentHasChanged) override |
Internal method to update the Node. | |
void | addZoneToVisitingZonesMap (PCZone *zone) |
bool | allowedToVisit (void) |
void | allowToVisit (bool yesno) |
void | anchorToHomeZone (PCZone *zone) |
void | clearNodeFromVisitedZones (void) |
void | clearVisitingZonesMap (void) |
SceneNode * | createChildSceneNode (const String &name, const Vector3 &translate=Vector3::ZERO, const Quaternion &rotate=Quaternion::IDENTITY) override |
Creates a new named SceneNode as a child of this node. | |
SceneNode * | createChildSceneNode (const Vector3 &translate=Vector3::ZERO, const Quaternion &rotate=Quaternion::IDENTITY) override |
Creates an unnamed new SceneNode as a child of this node. | |
void | enable (bool yesno) |
PCZone * | getHomeZone (void) |
unsigned long | getLastVisibleFrame (void) |
PCZCamera * | getLastVisibleFromCamera () |
Vector3 & | getPrevPosition (void) |
ZoneData * | getZoneData (PCZone *zone) |
bool | isAnchored (void) |
bool | isEnabled (void) |
bool | isMoved (void) |
bool | isVisitingZone (PCZone *zone) |
void | removeReferencesToZone (PCZone *zone) |
void | savePrevPosition (void) |
void | setHomeZone (PCZone *zone) |
void | setLastVisibleFrame (unsigned long newLVF) |
void | setLastVisibleFromCamera (PCZCamera *camera) |
void | setMoved (bool value) |
void | setZoneData (PCZone *zone, ZoneData *zoneData) |
void | updateFromParentImpl () const override |
Class-specific implementation of _updateFromParent. | |
void | updateZoneData (void) |
Public Member Functions inherited from Ogre::SceneNode | |
SceneNode (SceneManager *creator) | |
Constructor, only to be called by the creator SceneManager. | |
SceneNode (SceneManager *creator, const String &name) | |
Constructor, only to be called by the creator SceneManager. | |
~SceneNode () | |
void | _autoTrack (void) |
Internal method used by OGRE to update auto-tracking cameras. | |
void | _findVisibleObjects (Camera *cam, RenderQueue *queue, VisibleObjectsBoundsInfo *visibleBounds, bool includeChildren=true, bool displayNodes=false, bool onlyShadowCasters=false) |
Internal method which locates any visible objects attached to this node and adds them to the passed in queue. | |
const AxisAlignedBox & | _getWorldAABB (void) const |
Gets the axis-aligned bounding box of this node (and hence all subnodes). | |
void | _notifyRootNode (void) |
Notifies this SceneNode that it is the root scene node. | |
void | _update (bool updateChildren, bool parentHasChanged) override |
Internal method to update the Node. | |
virtual void | _updateBounds (void) |
Tells the SceneNode to update the world bound info it stores. | |
virtual void | attachObject (MovableObject *obj) |
Adds an instance of a scene object to this node. | |
void | destroyAllChildrenAndObjects () |
Destroys everything attatched to or decended from this node. | |
void | destroyAllObjects (void) |
Detaches and destroys all objects attached to this node. | |
void | destroyChildAndObjects (const String &name) |
Removes and destroys the child and all movable objects attached to the child, and does the same to any children of that child node. | |
void | destroyChildAndObjects (SceneNode *child) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | destroyChildAndObjects (unsigned short index) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
virtual void | detachAllObjects (void) |
Detaches all objects attached to this node. | |
virtual MovableObject * | detachObject (const String &name) |
Detaches the named object from this node and returns a pointer to it. | |
virtual void | detachObject (MovableObject *obj) |
Detaches an object by pointer. | |
virtual MovableObject * | detachObject (unsigned short index) |
Detaches the indexed object from this scene node. | |
void | findLights (LightList &destList, Real radius, uint32 lightMask=0xFFFFFFFF) const |
Allows retrieval of the nearest lights to the centre of this SceneNode. | |
void | flipVisibility (bool cascade=true) const |
Inverts the visibility of all objects attached to this node. | |
MovableObject * | getAttachedObject (const String &name) const |
Retrieves a pointer to an attached object by name. | |
MovableObject * | getAttachedObject (size_t index) const |
Retrieves a pointer to an attached object by index. | |
ObjectIterator | getAttachedObjectIterator (void) |
ConstObjectIterator | getAttachedObjectIterator (void) const |
const ObjectMap & | getAttachedObjects () const |
The MovableObjects attached to this node. | |
const Vector3 & | getAutoTrackLocalDirection (void) const |
Get the auto tracking local direction for this node, if it is auto tracking. | |
const Vector3 & | getAutoTrackOffset (void) const |
Get the auto tracking offset for this node, if the node is auto tracking. | |
SceneNode * | getAutoTrackTarget (void) const |
Get the auto tracking target for this node, if any. | |
SceneManager * | getCreator (void) const |
Gets the creator of this scene node. | |
SceneNode * | getParentSceneNode (void) const |
Gets the parent of this SceneNode. | |
bool | getShowBoundingBox () const |
This allows scene managers to determine if the node's bounding box should be added to the rendering queue. | |
bool | isInSceneGraph (void) const |
Determines whether this node is in the scene graph, i.e. | |
void | loadChildren (const String &filename) |
Load a scene from a file as children of this node. | |
void | lookAt (const Vector3 &targetPoint, TransformSpace relativeTo, const Vector3 &localDirectionVector=Vector3::NEGATIVE_UNIT_Z) |
Points the local -Z direction of this node at a point in space. | |
size_t | numAttachedObjects (void) const |
Reports the number of objects attached to this node. | |
void | removeAndDestroyAllChildren (void) |
Removes and destroys all children of this node. | |
void | removeAndDestroyChild (const String &name) |
This method removes and destroys the named child and all of its children. | |
void | removeAndDestroyChild (SceneNode *child) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | removeAndDestroyChild (unsigned short index) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | saveChildren (const String &filename) |
Save the scene hierarchy starting at this node to file. | |
void | setAutoTracking (bool enabled, SceneNode *const target=0, const Vector3 &localDirectionVector=Vector3::NEGATIVE_UNIT_Z, const Vector3 &offset=Vector3::ZERO) |
Enables / disables automatic tracking of another SceneNode. | |
void | setDebugDisplayEnabled (bool enabled, bool cascade=true) const |
Tells all objects attached to this node whether to display their debug information or not. | |
void | setDirection (const Vector3 &vec, TransformSpace relativeTo=TS_PARENT, const Vector3 &localDirectionVector=Vector3::NEGATIVE_UNIT_Z) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | setDirection (Real x, Real y, Real z, TransformSpace relativeTo=TS_PARENT, const Vector3 &localDirectionVector=Vector3::NEGATIVE_UNIT_Z) |
Sets the node's direction vector ie it's local -z. | |
void | setFixedYawAxis (bool useFixed, const Vector3 &fixedAxis=Vector3::UNIT_Y) |
Tells the node whether to yaw around it's own local Y axis or a fixed axis of choice. | |
void | setVisible (bool visible, bool cascade=true) const |
Makes all objects attached to this node become visible / invisible. | |
void | showBoundingBox (bool bShow) |
Allows the showing of the node's bounding box. | |
void | yaw (const Radian &angle, TransformSpace relativeTo=TS_LOCAL) override |
Rotate the node around the Y-axis. | |
Public Member Functions inherited from Ogre::Node | |
Node () | |
Constructor, should only be called by parent, not directly. | |
Node (const String &name) | |
Constructor, should only be called by parent, not directly. | |
virtual | ~Node () |
const Quaternion & | _getDerivedOrientation (void) const |
Gets the orientation of the node as derived from all parents. | |
const Vector3 & | _getDerivedPosition (void) const |
Gets the position of the node as derived from all parents. | |
const Vector3 & | _getDerivedScale (void) const |
Gets the scaling factor of the node as derived from all parents. | |
const Affine3 & | _getFullTransform (void) const |
Gets the full transformation matrix for this node. | |
void | _setDerivedOrientation (const Quaternion &q) |
Sets the final world orientation of the node directly. | |
void | _setDerivedPosition (const Vector3 &pos) |
Sets the final world position of the node directly. | |
void | addChild (Node *child) |
Adds a (precreated) child scene node to this node. | |
void | cancelUpdate (Node *child) |
Called by children to notify their parent that they no longer need an update. | |
Vector3 | convertLocalToWorldDirection (const Vector3 &localDir, bool useScale) |
Gets the world direction of a point in the node local space useful for simple transforms that don't require a child node. | |
Quaternion | convertLocalToWorldOrientation (const Quaternion &localOrientation) |
Gets the world orientation of an orientation in the node local space useful for simple transforms that don't require a child node. | |
Vector3 | convertLocalToWorldPosition (const Vector3 &localPos) |
Gets the world position of a point in the node local space useful for simple transforms that don't require a child node. | |
Vector3 | convertWorldToLocalDirection (const Vector3 &worldDir, bool useScale) |
Gets the local direction, relative to this node, of the given world-space direction. | |
Quaternion | convertWorldToLocalOrientation (const Quaternion &worldOrientation) |
Gets the local orientation, relative to this node, of the given world-space orientation. | |
Vector3 | convertWorldToLocalPosition (const Vector3 &worldPos) |
Gets the local position, relative to this node, of the given world-space position. | |
virtual Node * | createChild (const String &name, const Vector3 &translate=Vector3::ZERO, const Quaternion &rotate=Quaternion::IDENTITY) |
Creates a new named Node as a child of this node. | |
virtual Node * | createChild (const Vector3 &translate=Vector3::ZERO, const Quaternion &rotate=Quaternion::IDENTITY) |
Creates an unnamed new Node as a child of this node. | |
Node * | getChild (const String &name) const |
Gets a pointer to a named child node. | |
Node * | getChild (unsigned short index) const |
Gets a pointer to a child node. | |
ChildNodeIterator | getChildIterator (void) |
ConstChildNodeIterator | getChildIterator (void) const |
const ChildNodeMap & | getChildren () const |
List of sub-nodes of this Node. | |
bool | getInheritOrientation (void) const |
Returns true if this node is affected by orientation applied to the parent node. | |
bool | getInheritScale (void) const |
Returns true if this node is affected by scaling factors applied to the parent node. | |
const Quaternion & | getInitialOrientation (void) const |
Gets the initial orientation of this node, see setInitialState for more info. | |
const Vector3 & | getInitialPosition (void) const |
Gets the initial position of this node, see setInitialState for more info. | |
const Vector3 & | getInitialScale (void) const |
Gets the initial position of this node, see setInitialState for more info. | |
Listener * | getListener (void) const |
Gets the current listener for this Node. | |
Matrix3 | getLocalAxes (void) const |
Gets a matrix whose columns are the local axes based on the nodes orientation relative to it's parent. | |
const String & | getName (void) const |
Returns the name of the node. | |
const Quaternion & | getOrientation () const |
Returns a quaternion representing the nodes orientation. | |
Node * | getParent (void) const |
Gets this node's parent (NULL if this is the root). | |
const Vector3 & | getPosition (void) const |
Gets the position of the node relative to it's parent. | |
const Vector3 & | getScale (void) const |
Gets the scaling factor of this node. | |
Real | getSquaredViewDepth (const Camera *cam) const |
Helper function, get the squared view depth. | |
const Any & | getUserAny (void) const |
UserObjectBindings & | getUserObjectBindings () |
Class that provides convenient interface to establish a linkage between custom user application objects and Ogre core classes. | |
const UserObjectBindings & | getUserObjectBindings () const |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
virtual void | needUpdate (bool forceParentUpdate=false) |
To be called in the event of transform changes to this node that require it's recalculation. | |
uint16 | numChildren (void) const |
Reports the number of child nodes under this one. | |
virtual void | pitch (const Radian &angle, TransformSpace relativeTo=TS_LOCAL) |
Rotate the node around the X-axis. | |
virtual void | removeAllChildren (void) |
Removes all child Nodes attached to this node. | |
virtual Node * | removeChild (const String &name) |
Drops the named child from this node. | |
virtual Node * | removeChild (Node *child) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
virtual Node * | removeChild (unsigned short index) |
Drops the specified child from this node. | |
void | requestUpdate (Node *child, bool forceParentUpdate=false) |
Called by children to notify their parent that they need an update. | |
void | resetOrientation (void) |
Resets the nodes orientation (local axes as world axes, no rotation). | |
void | resetToInitialState (void) |
Resets the position / orientation / scale of this node to it's initial state, see setInitialState for more info. | |
virtual void | roll (const Radian &angle, TransformSpace relativeTo=TS_LOCAL) |
Rotate the node around the Z-axis. | |
void | rotate (const Quaternion &q, TransformSpace relativeTo=TS_LOCAL) |
Rotate the node around an arbitrary axis using a Quarternion. | |
void | rotate (const Vector3 &axis, const Radian &angle, TransformSpace relativeTo=TS_LOCAL) |
Rotate the node around an arbitrary axis. | |
void | scale (const Vector3 &scale) |
Scales the node, combining it's current scale with the passed in scaling factor. | |
void | scale (Real x, Real y, Real z) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | setInheritOrientation (bool inherit) |
Tells the node whether it should inherit orientation from it's parent node. | |
void | setInheritScale (bool inherit) |
Tells the node whether it should inherit scaling factors from it's parent node. | |
void | setInitialState (void) |
Sets the current transform of this node to be the 'initial state' ie that position / orientation / scale to be used as a basis for delta values used in keyframe animation. | |
void | setListener (Listener *listener) |
Sets a listener for this Node. | |
void | setOrientation (const Quaternion &q) |
Sets the orientation of this node via a quaternion. | |
void | setOrientation (Real w, Real x, Real y, Real z) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | setPosition (const Vector3 &pos) |
Sets the position of the node relative to it's parent. | |
void | setPosition (Real x, Real y, Real z) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | setScale (const Vector3 &scale) |
Sets the scaling factor applied to this node. | |
void | setScale (Real x, Real y, Real z) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | setUserAny (const Any &anything) |
void | translate (const Matrix3 &axes, const Vector3 &move, TransformSpace relativeTo=TS_PARENT) |
Moves the node along arbitrary axes. | |
void | translate (const Matrix3 &axes, Real x, Real y, Real z, TransformSpace relativeTo=TS_PARENT) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
void | translate (const Vector3 &d, TransformSpace relativeTo=TS_PARENT) |
Moves the node along the Cartesian axes. | |
void | translate (Real x, Real y, Real z, TransformSpace relativeTo=TS_PARENT) |
This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. | |
Additional Inherited Members | |
Public Types inherited from Ogre::SceneNode | |
typedef ConstVectorIterator< ObjectMap > | ConstObjectIterator |
typedef VectorIterator< ObjectMap > | ObjectIterator |
typedef std::vector< MovableObject * > | ObjectMap |
Public Types inherited from Ogre::Node | |
typedef VectorIterator< ChildNodeMap > | ChildNodeIterator |
typedef std::vector< Node * > | ChildNodeMap |
typedef ConstVectorIterator< ChildNodeMap > | ConstChildNodeIterator |
enum | TransformSpace { TS_LOCAL , TS_PARENT , TS_WORLD } |
Enumeration denoting the spaces which a transform can be relative to. More... | |
Static Public Member Functions inherited from Ogre::Node | |
static void | processQueuedUpdates (void) |
Process queued 'needUpdate' calls. | |
static void | queueNeedUpdate (Node *n) |
Queue a 'needUpdate' call to a node safely. | |
The PCZSceneNode is an extension used to store zone information and provide additional functionality for a given Ogre::SceneNode.
A PCZSceneNode contains a pointer to the home zone for the node and a list of all zones being visited by the node. The PCZSceneManager contains a STD::MAP of PCZSceneNodes which are keyed by the name of each node (each PCZSceneNode has an identical name to the scene node which it is associated with). This allows quick lookup of a given scenenode's PCZSceneNode by the scene manager.
Ogre::PCZSceneNode::PCZSceneNode | ( | SceneManager * | creator | ) |
Standard constructor.
Ogre::PCZSceneNode::PCZSceneNode | ( | SceneManager * | creator, |
const String & | name | ||
) |
Standard constructor.
Ogre::PCZSceneNode::~PCZSceneNode | ( | ) |
Standard destructor.
Internal method to update the Node.
updateChildren | If true , the update cascades down to all children. Specify false if you wish to update children separately, e.g. because of a more selective SceneManager implementation. |
parentHasChanged | This flag indicates that the parent transform has changed, so the child should retrieve the parent's transform and combine it with its own even if it hasn't changed itself. |
Reimplemented from Ogre::Node.
|
overridevirtual |
Class-specific implementation of _updateFromParent.
Splitting the implementation of the update away from the update call itself allows the detail to be overridden without disrupting the general sequence of updateFromParent (e.g. raising events)
Reimplemented from Ogre::Node.
|
overridevirtual |
Creates an unnamed new SceneNode as a child of this node.
translate | Initial translation offset of child relative to parent |
rotate | Initial rotation relative to parent |
Reimplemented from Ogre::SceneNode.
|
overridevirtual |
Creates a new named SceneNode as a child of this node.
This creates a child node with a given name, which allows you to look the node up from the parent which holds this collection of nodes.
name | name of the node |
translate | Initial translation offset of child relative to parent |
rotate | Initial rotation relative to parent |
Reimplemented from Ogre::SceneNode.
void Ogre::PCZSceneNode::_addToRenderQueue | ( | Camera * | cam, |
RenderQueue * | queue, | ||
bool | onlyShadowCasters, | ||
VisibleObjectsBoundsInfo * | visibleBounds | ||
) |
|
inline |