OGRE  13.6
Object-Oriented Graphics Rendering Engine
Ogre::Node Class Referenceabstract

Class representing a general-purpose node an articulated scene graph. More...

#include <OgreNode.h>

+ Inheritance diagram for Ogre::Node:

Classes

class  Listener
 Listener which gets called back on Node events. More...
 

Public Types

typedef VectorIterator< ChildNodeMapChildNodeIterator
 
typedef std::vector< Node * > ChildNodeMap
 
typedef ConstVectorIterator< ChildNodeMapConstChildNodeIterator
 
enum  TransformSpace { TS_LOCAL , TS_PARENT , TS_WORLD }
 Enumeration denoting the spaces which a transform can be relative to. More...
 

Public Member Functions

 Node ()
 Constructor, should only be called by parent, not directly. More...
 
 Node (const String &name)
 Constructor, should only be called by parent, not directly. More...
 
virtual ~Node ()
 
const Quaternion_getDerivedOrientation (void) const
 Gets the orientation of the node as derived from all parents. More...
 
const Vector3_getDerivedPosition (void) const
 Gets the position of the node as derived from all parents. More...
 
const Vector3_getDerivedScale (void) const
 Gets the scaling factor of the node as derived from all parents. More...
 
const Affine3_getFullTransform (void) const
 Gets the full transformation matrix for this node. More...
 
void _setDerivedOrientation (const Quaternion &q)
 Sets the final world orientation of the node directly. More...
 
void _setDerivedPosition (const Vector3 &pos)
 Sets the final world position of the node directly. More...
 
virtual void _update (bool updateChildren, bool parentHasChanged)
 Internal method to update the Node. More...
 
void addChild (Node *child)
 Adds a (precreated) child scene node to this node. More...
 
void cancelUpdate (Node *child)
 Called by children to notify their parent that they no longer need an update. More...
 
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. More...
 
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. More...
 
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. More...
 
Vector3 convertWorldToLocalDirection (const Vector3 &worldDir, bool useScale)
 Gets the local direction, relative to this node, of the given world-space direction. More...
 
Quaternion convertWorldToLocalOrientation (const Quaternion &worldOrientation)
 Gets the local orientation, relative to this node, of the given world-space orientation. More...
 
Vector3 convertWorldToLocalPosition (const Vector3 &worldPos)
 Gets the local position, relative to this node, of the given world-space position. More...
 
virtual NodecreateChild (const String &name, const Vector3 &translate=Vector3::ZERO, const Quaternion &rotate=Quaternion::IDENTITY)
 Creates a new named Node as a child of this node. More...
 
virtual NodecreateChild (const Vector3 &translate=Vector3::ZERO, const Quaternion &rotate=Quaternion::IDENTITY)
 Creates an unnamed new Node as a child of this node. More...
 
NodegetChild (const String &name) const
 Gets a pointer to a named child node. More...
 
NodegetChild (unsigned short index) const
 Gets a pointer to a child node. More...
 
ChildNodeIterator getChildIterator (void)
 
ConstChildNodeIterator getChildIterator (void) const
 
const ChildNodeMapgetChildren () const
 List of sub-nodes of this Node. More...
 
bool getInheritOrientation (void) const
 Returns true if this node is affected by orientation applied to the parent node. More...
 
bool getInheritScale (void) const
 Returns true if this node is affected by scaling factors applied to the parent node. More...
 
const QuaterniongetInitialOrientation (void) const
 Gets the initial orientation of this node, see setInitialState for more info. More...
 
const Vector3getInitialPosition (void) const
 Gets the initial position of this node, see setInitialState for more info. More...
 
const Vector3getInitialScale (void) const
 Gets the initial position of this node, see setInitialState for more info. More...
 
ListenergetListener (void) const
 Gets the current listener for this Node. More...
 
Matrix3 getLocalAxes (void) const
 Gets a matrix whose columns are the local axes based on the nodes orientation relative to it's parent. More...
 
const StringgetName (void) const
 Returns the name of the node. More...
 
const QuaterniongetOrientation () const
 Returns a quaternion representing the nodes orientation. More...
 
NodegetParent (void) const
 Gets this node's parent (NULL if this is the root). More...
 
const Vector3getPosition (void) const
 Gets the position of the node relative to it's parent. More...
 
const Vector3getScale (void) const
 Gets the scaling factor of this node. More...
 
Real getSquaredViewDepth (const Camera *cam) const
 Helper function, get the squared view depth. More...
 
const AnygetUserAny (void) const
 
UserObjectBindingsgetUserObjectBindings ()
 Class that provides convenient interface to establish a linkage between custom user application objects and Ogre core classes. More...
 
const UserObjectBindingsgetUserObjectBindings () const
 This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More...
 
virtual void needUpdate (bool forceParentUpdate=false)
 To be called in the event of transform changes to this node that require it's recalculation. More...
 
uint16 numChildren (void) const
 Reports the number of child nodes under this one. More...
 
virtual void pitch (const Radian &angle, TransformSpace relativeTo=TS_LOCAL)
 Rotate the node around the X-axis. More...
 
virtual void removeAllChildren (void)
 Removes all child Nodes attached to this node. More...
 
virtual NoderemoveChild (const String &name)
 Drops the named child from this node. More...
 
virtual NoderemoveChild (Node *child)
 This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts. More...
 
virtual NoderemoveChild (unsigned short index)
 Drops the specified child from this node. More...
 
void requestUpdate (Node *child, bool forceParentUpdate=false)
 Called by children to notify their parent that they need an update. More...
 
void resetOrientation (void)
 Resets the nodes orientation (local axes as world axes, no rotation). More...
 
void resetToInitialState (void)
 Resets the position / orientation / scale of this node to it's initial state, see setInitialState for more info. More...
 
virtual void roll (const Radian &angle, TransformSpace relativeTo=TS_LOCAL)
 Rotate the node around the Z-axis. More...
 
void rotate (const Quaternion &q, TransformSpace relativeTo=TS_LOCAL)
 Rotate the node around an arbitrary axis using a Quarternion. More...
 
void rotate (const Vector3 &axis, const Radian &angle, TransformSpace relativeTo=TS_LOCAL)
 Rotate the node around an arbitrary axis. More...
 
void scale (const Vector3 &scale)
 Scales the node, combining it's current scale with the passed in scaling factor. More...
 
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. More...
 
void setInheritOrientation (bool inherit)
 Tells the node whether it should inherit orientation from it's parent node. More...
 
void setInheritScale (bool inherit)
 Tells the node whether it should inherit scaling factors from it's parent node. More...
 
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. More...
 
void setListener (Listener *listener)
 Sets a listener for this Node. More...
 
void setOrientation (const Quaternion &q)
 Sets the orientation of this node via a quaternion. More...
 
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. More...
 
void setPosition (const Vector3 &pos)
 Sets the position of the node relative to it's parent. More...
 
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. More...
 
void setScale (const Vector3 &scale)
 Sets the scaling factor applied to this node. More...
 
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. More...
 
void setUserAny (const Any &anything)
 
void translate (const Matrix3 &axes, const Vector3 &move, TransformSpace relativeTo=TS_PARENT)
 Moves the node along arbitrary axes. More...
 
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. More...
 
void translate (const Vector3 &d, TransformSpace relativeTo=TS_PARENT)
 Moves the node along the Cartesian axes. More...
 
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. More...
 
virtual void yaw (const Radian &angle, TransformSpace relativeTo=TS_LOCAL)
 Rotate the node around the Y-axis. More...
 

Static Public Member Functions

static void processQueuedUpdates (void)
 Process queued 'needUpdate' calls. More...
 
static void queueNeedUpdate (Node *n)
 Queue a 'needUpdate' call to a node safely. More...
 

Detailed Description

Class representing a general-purpose node an articulated scene graph.

Remarks
A node in the scene graph is a node in a structured tree. A node contains information about the transformation which will apply to it and all of it's children. Child nodes can have transforms of their own, which are combined with their parent's transformations.
This is an abstract class - concrete classes are based on this for specific purposes, e.g. SceneNode, Bone

Member Typedef Documentation

◆ ChildNodeMap

typedef std::vector<Node*> Ogre::Node::ChildNodeMap

◆ ChildNodeIterator

◆ ConstChildNodeIterator

Member Enumeration Documentation

◆ TransformSpace

Enumeration denoting the spaces which a transform can be relative to.

Enumerator
TS_LOCAL 

Transform is relative to the local space.

TS_PARENT 

Transform is relative to the space of the parent node.

TS_WORLD 

Transform is relative to world space.

Constructor & Destructor Documentation

◆ Node() [1/2]

Ogre::Node::Node ( )

Constructor, should only be called by parent, not directly.

◆ Node() [2/2]

Ogre::Node::Node ( const String name)

Constructor, should only be called by parent, not directly.

Remarks
Assigned a name.

◆ ~Node()

virtual Ogre::Node::~Node ( )
virtual

Member Function Documentation

◆ getName()

const String& Ogre::Node::getName ( void  ) const
inline

Returns the name of the node.

◆ getParent()

Node* Ogre::Node::getParent ( void  ) const
inline

Gets this node's parent (NULL if this is the root).

◆ getOrientation()

const Quaternion& Ogre::Node::getOrientation ( void  ) const
inline

Returns a quaternion representing the nodes orientation.

◆ setOrientation() [1/2]

void Ogre::Node::setOrientation ( const Quaternion q)

Sets the orientation of this node via a quaternion.

Remarks
Orientations, unlike other transforms, are not always inherited by child nodes. Whether or not orientations affect the orientation of the child nodes depends on the setInheritOrientation option of the child. In some cases you want a orientating of a parent node to apply to a child node (e.g. where the child node is a part of the same object, so you want it to be the same relative orientation based on the parent's orientation), but not in other cases (e.g. where the child node is just for positioning another object, you want it to maintain it's own orientation). The default is to inherit as with other transforms.
Note that rotations are oriented around the node's origin.

◆ setOrientation() [2/2]

void Ogre::Node::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.

◆ resetOrientation()

void Ogre::Node::resetOrientation ( void  )

Resets the nodes orientation (local axes as world axes, no rotation).

Remarks
Orientations, unlike other transforms, are not always inherited by child nodes. Whether or not orientations affect the orientation of the child nodes depends on the setInheritOrientation option of the child. In some cases you want a orientating of a parent node to apply to a child node (e.g. where the child node is a part of the same object, so you want it to be the same relative orientation based on the parent's orientation), but not in other cases (e.g. where the child node is just for positioning another object, you want it to maintain it's own orientation). The default is to inherit as with other transforms.
Note that rotations are oriented around the node's origin.

◆ setPosition() [1/2]

void Ogre::Node::setPosition ( const Vector3 pos)

Sets the position of the node relative to it's parent.

◆ setPosition() [2/2]

void Ogre::Node::setPosition ( Real  x,
Real  y,
Real  z 
)
inline

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

References setPosition().

Referenced by setPosition().

◆ getPosition()

const Vector3& Ogre::Node::getPosition ( void  ) const
inline

Gets the position of the node relative to it's parent.

◆ setScale() [1/2]

void Ogre::Node::setScale ( const Vector3 scale)

Sets the scaling factor applied to this node.

Remarks
Scaling factors, unlike other transforms, are not always inherited by child nodes. Whether or not scalings affect the size of the child nodes depends on the setInheritScale option of the child. In some cases you want a scaling factor of a parent node to apply to a child node (e.g. where the child node is a part of the same object, so you want it to be the same relative size based on the parent's size), but not in other cases (e.g. where the child node is just for positioning another object, you want it to maintain it's own size). The default is to inherit as with other transforms.
Note that like rotations, scalings are oriented around the node's origin.

◆ setScale() [2/2]

void Ogre::Node::setScale ( Real  x,
Real  y,
Real  z 
)
inline

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

References setScale().

Referenced by setScale().

◆ getScale()

const Vector3& Ogre::Node::getScale ( void  ) const
inline

Gets the scaling factor of this node.

◆ setInheritOrientation()

void Ogre::Node::setInheritOrientation ( bool  inherit)

Tells the node whether it should inherit orientation from it's parent node.

Remarks
Orientations, unlike other transforms, are not always inherited by child nodes. Whether or not orientations affect the orientation of the child nodes depends on the setInheritOrientation option of the child. In some cases you want a orientating of a parent node to apply to a child node (e.g. where the child node is a part of the same object, so you want it to be the same relative orientation based on the parent's orientation), but not in other cases (e.g. where the child node is just for positioning another object, you want it to maintain it's own orientation). The default is to inherit as with other transforms.
Parameters
inheritIf true, this node's orientation will be affected by its parent's orientation. If false, it will not be affected.

◆ getInheritOrientation()

bool Ogre::Node::getInheritOrientation ( void  ) const
inline

Returns true if this node is affected by orientation applied to the parent node.

Remarks
Orientations, unlike other transforms, are not always inherited by child nodes. Whether or not orientations affect the orientation of the child nodes depends on the setInheritOrientation option of the child. In some cases you want a orientating of a parent node to apply to a child node (e.g. where the child node is a part of the same object, so you want it to be the same relative orientation based on the parent's orientation), but not in other cases (e.g. where the child node is just for positioning another object, you want it to maintain it's own orientation). The default is to inherit as with other transforms.
See setInheritOrientation for more info.

◆ setInheritScale()

void Ogre::Node::setInheritScale ( bool  inherit)

Tells the node whether it should inherit scaling factors from it's parent node.

Remarks
Scaling factors, unlike other transforms, are not always inherited by child nodes. Whether or not scalings affect the size of the child nodes depends on the setInheritScale option of the child. In some cases you want a scaling factor of a parent node to apply to a child node (e.g. where the child node is a part of the same object, so you want it to be the same relative size based on the parent's size), but not in other cases (e.g. where the child node is just for positioning another object, you want it to maintain it's own size). The default is to inherit as with other transforms.
Parameters
inheritIf true, this node's scale will be affected by its parent's scale. If false, it will not be affected.

◆ getInheritScale()

bool Ogre::Node::getInheritScale ( void  ) const
inline

Returns true if this node is affected by scaling factors applied to the parent node.

Remarks
See setInheritScale for more info.

◆ scale() [1/2]

void Ogre::Node::scale ( const Vector3 scale)

Scales the node, combining it's current scale with the passed in scaling factor.

Remarks
This method applies an extra scaling factor to the node's existing scale, (unlike setScale which overwrites it) combining it's current scale with the new one. E.g. calling this method twice with Vector3(2,2,2) would have the same effect as setScale(Vector3(4,4,4)) if the existing scale was 1.
Note that like rotations, scalings are oriented around the node's origin.

◆ scale() [2/2]

void Ogre::Node::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.

◆ translate() [1/4]

void Ogre::Node::translate ( const Vector3 d,
TransformSpace  relativeTo = TS_PARENT 
)

Moves the node along the Cartesian axes.

This method moves the node by the supplied vector along the world Cartesian axes, i.e. along world x,y,z
Parameters
dVector with x,y,z values representing the translation.
relativeToThe space which this transform is relative to.

◆ translate() [2/4]

void Ogre::Node::translate ( Real  x,
Real  y,
Real  z,
TransformSpace  relativeTo = TS_PARENT 
)
inline

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

◆ translate() [3/4]

void Ogre::Node::translate ( const Matrix3 axes,
const Vector3 move,
TransformSpace  relativeTo = TS_PARENT 
)
inline

Moves the node along arbitrary axes.

Remarks
This method translates the node by a vector which is relative to a custom set of axes.
Parameters
axesA 3x3 Matrix containing 3 column vectors each representing the axes X, Y and Z respectively. In this format the standard cartesian axes would be expressed as:
    1 0 0
    0 1 0
    0 0 1
    
i.e. the identity matrix.
moveVector relative to the axes above.
relativeToThe space which this transform is relative to.

◆ translate() [4/4]

void Ogre::Node::translate ( const Matrix3 axes,
Real  x,
Real  y,
Real  z,
TransformSpace  relativeTo = TS_PARENT 
)
inline

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

◆ roll()

virtual void Ogre::Node::roll ( const Radian angle,
TransformSpace  relativeTo = TS_LOCAL 
)
inlinevirtual

Rotate the node around the Z-axis.

◆ pitch()

virtual void Ogre::Node::pitch ( const Radian angle,
TransformSpace  relativeTo = TS_LOCAL 
)
inlinevirtual

Rotate the node around the X-axis.

◆ yaw()

virtual void Ogre::Node::yaw ( const Radian angle,
TransformSpace  relativeTo = TS_LOCAL 
)
inlinevirtual

Rotate the node around the Y-axis.

Reimplemented in Ogre::SceneNode.

◆ rotate() [1/2]

void Ogre::Node::rotate ( const Vector3 axis,
const Radian angle,
TransformSpace  relativeTo = TS_LOCAL 
)
inline

Rotate the node around an arbitrary axis.

◆ rotate() [2/2]

void Ogre::Node::rotate ( const Quaternion q,
TransformSpace  relativeTo = TS_LOCAL 
)

Rotate the node around an arbitrary axis using a Quarternion.

◆ getLocalAxes()

Matrix3 Ogre::Node::getLocalAxes ( void  ) const

Gets a matrix whose columns are the local axes based on the nodes orientation relative to it's parent.

◆ createChild() [1/2]

virtual Node* Ogre::Node::createChild ( const Vector3 translate = Vector3::ZERO,
const Quaternion rotate = Quaternion::IDENTITY 
)
virtual

Creates an unnamed new Node as a child of this node.

Parameters
translateInitial translation offset of child relative to parent
rotateInitial rotation relative to parent

◆ createChild() [2/2]

virtual Node* Ogre::Node::createChild ( const String name,
const Vector3 translate = Vector3::ZERO,
const Quaternion rotate = Quaternion::IDENTITY 
)
virtual

Creates a new named Node as a child of this node.

Remarks
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.
Parameters
nameName of the Node to create
translateInitial translation offset of child relative to parent
rotateInitial rotation relative to parent

◆ addChild()

void Ogre::Node::addChild ( Node child)

Adds a (precreated) child scene node to this node.

If it is attached to another node, it must be detached first.

Parameters
childThe Node which is to become a child node of this one

◆ numChildren()

uint16 Ogre::Node::numChildren ( void  ) const
inline

Reports the number of child nodes under this one.

Deprecated:
use getChildren()

◆ getChild() [1/2]

Node* Ogre::Node::getChild ( unsigned short  index) const

Gets a pointer to a child node.

Remarks
There is an alternate getChild method which returns a named child.
Deprecated:
use getChildren()

◆ getChild() [2/2]

Node* Ogre::Node::getChild ( const String name) const

Gets a pointer to a named child node.

◆ getChildIterator() [1/2]

ChildNodeIterator Ogre::Node::getChildIterator ( void  )

◆ getChildIterator() [2/2]

ConstChildNodeIterator Ogre::Node::getChildIterator ( void  ) const

◆ getChildren()

const ChildNodeMap& Ogre::Node::getChildren ( ) const
inline

List of sub-nodes of this Node.

◆ removeChild() [1/3]

virtual Node* Ogre::Node::removeChild ( unsigned short  index)
virtual

Drops the specified child from this node.

Remarks
Does not delete the node, just detaches it from this parent, potentially to be reattached elsewhere. There is also an alternate version which drops a named child from this node.

Reimplemented in Ogre::OctreeNode.

◆ removeChild() [2/3]

virtual Node* Ogre::Node::removeChild ( Node child)
virtual

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.

Reimplemented in Ogre::OctreeNode.

◆ removeChild() [3/3]

virtual Node* Ogre::Node::removeChild ( const String name)
virtual

Drops the named child from this node.

Remarks
Does not delete the node, just detaches it from this parent, potentially to be reattached elsewhere.

Reimplemented in Ogre::OctreeNode.

◆ removeAllChildren()

virtual void Ogre::Node::removeAllChildren ( void  )
virtual

Removes all child Nodes attached to this node.

Does not delete the nodes, just detaches them from this parent, potentially to be reattached elsewhere.

Reimplemented in Ogre::OctreeNode.

◆ _setDerivedPosition()

void Ogre::Node::_setDerivedPosition ( const Vector3 pos)

Sets the final world position of the node directly.

Remarks
It's advisable to use the local setPosition if possible

◆ _setDerivedOrientation()

void Ogre::Node::_setDerivedOrientation ( const Quaternion q)

Sets the final world orientation of the node directly.

Remarks
It's advisable to use the local setOrientation if possible, this simply does the conversion for you.

◆ _getDerivedOrientation()

const Quaternion& Ogre::Node::_getDerivedOrientation ( void  ) const

Gets the orientation of the node as derived from all parents.

◆ _getDerivedPosition()

const Vector3& Ogre::Node::_getDerivedPosition ( void  ) const

Gets the position of the node as derived from all parents.

Referenced by Ogre::SceneManager::_populateLightList().

◆ _getDerivedScale()

const Vector3& Ogre::Node::_getDerivedScale ( void  ) const

Gets the scaling factor of the node as derived from all parents.

◆ _getFullTransform()

const Affine3& Ogre::Node::_getFullTransform ( void  ) const

Gets the full transformation matrix for this node.

Remarks
This method returns the full transformation matrix for this node, including the effect of any parent node transformations, provided they have been updated using the Node::_update method. This should only be called by a SceneManager which knows the derived transforms have been updated before calling this method. Applications using Ogre should just use the relative transforms.

◆ _update()

virtual void Ogre::Node::_update ( bool  updateChildren,
bool  parentHasChanged 
)
virtual

Internal method to update the Node.

Note
Updates this node and any relevant children to incorporate transforms etc. Don't call this yourself unless you are writing a SceneManager implementation.
Parameters
updateChildrenIf 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.
parentHasChangedThis 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 in Ogre::PCZSceneNode, Ogre::BspSceneNode, and Ogre::SceneNode.

◆ setListener()

void Ogre::Node::setListener ( Listener listener)
inline

Sets a listener for this Node.

Remarks
Note for size and performance reasons only one listener per node is allowed.

◆ getListener()

Listener* Ogre::Node::getListener ( void  ) const
inline

Gets the current listener for this Node.

◆ setInitialState()

void Ogre::Node::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.

Remarks
You never need to call this method unless you plan to animate this node. If you do plan to animate it, call this method once you've loaded the node with it's base state, ie the state on which all keyframes are based.
If you never call this method, the initial state is the identity transform, ie do nothing.

◆ resetToInitialState()

void Ogre::Node::resetToInitialState ( void  )

Resets the position / orientation / scale of this node to it's initial state, see setInitialState for more info.

◆ getInitialPosition()

const Vector3& Ogre::Node::getInitialPosition ( void  ) const
inline

Gets the initial position of this node, see setInitialState for more info.

Remarks
Also resets the cumulative animation weight used for blending.

◆ convertWorldToLocalPosition()

Vector3 Ogre::Node::convertWorldToLocalPosition ( const Vector3 worldPos)

Gets the local position, relative to this node, of the given world-space position.

◆ convertLocalToWorldPosition()

Vector3 Ogre::Node::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.

◆ convertWorldToLocalDirection()

Vector3 Ogre::Node::convertWorldToLocalDirection ( const Vector3 worldDir,
bool  useScale 
)

Gets the local direction, relative to this node, of the given world-space direction.

◆ convertLocalToWorldDirection()

Vector3 Ogre::Node::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.

◆ convertWorldToLocalOrientation()

Quaternion Ogre::Node::convertWorldToLocalOrientation ( const Quaternion worldOrientation)

Gets the local orientation, relative to this node, of the given world-space orientation.

◆ convertLocalToWorldOrientation()

Quaternion Ogre::Node::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.

◆ getInitialOrientation()

const Quaternion& Ogre::Node::getInitialOrientation ( void  ) const
inline

Gets the initial orientation of this node, see setInitialState for more info.

◆ getInitialScale()

const Vector3& Ogre::Node::getInitialScale ( void  ) const
inline

Gets the initial position of this node, see setInitialState for more info.

◆ getSquaredViewDepth()

Real Ogre::Node::getSquaredViewDepth ( const Camera cam) const

Helper function, get the squared view depth.


◆ needUpdate()

virtual void Ogre::Node::needUpdate ( bool  forceParentUpdate = false)
virtual

To be called in the event of transform changes to this node that require it's recalculation.

Remarks
This not only tags the node state as being 'dirty', it also requests it's parent to know about it's dirtiness so it will get an update next time.
Parameters
forceParentUpdateEven if the node thinks it has already told it's parent, tell it anyway

Reimplemented in Ogre::TagPoint, and Ogre::Bone.

◆ requestUpdate()

void Ogre::Node::requestUpdate ( Node child,
bool  forceParentUpdate = false 
)

Called by children to notify their parent that they need an update.

Parameters
childThe child Node to be updated
forceParentUpdateEven if the node thinks it has already told it's parent, tell it anyway

◆ cancelUpdate()

void Ogre::Node::cancelUpdate ( Node child)

Called by children to notify their parent that they no longer need an update.

◆ queueNeedUpdate()

static void Ogre::Node::queueNeedUpdate ( Node n)
static

Queue a 'needUpdate' call to a node safely.

Remarks
You can't call needUpdate() during the scene graph update, e.g. in response to a Node::Listener hook, because the graph is already being updated, and update flag changes cannot be made reliably in that context. Call this method if you need to queue a needUpdate call in this case.

◆ processQueuedUpdates()

static void Ogre::Node::processQueuedUpdates ( void  )
static

Process queued 'needUpdate' calls.

◆ setUserAny()

void Ogre::Node::setUserAny ( const Any anything)
inline

◆ getUserAny()

const Any& Ogre::Node::getUserAny ( void  ) const
inline

◆ getUserObjectBindings() [1/2]

UserObjectBindings& Ogre::Node::getUserObjectBindings ( )
inline

Class that provides convenient interface to establish a linkage between custom user application objects and Ogre core classes.

◆ getUserObjectBindings() [2/2]

const UserObjectBindings& Ogre::Node::getUserObjectBindings ( ) const
inline

This is an overloaded member function, provided for convenience. It differs from the above function only in what argument(s) it accepts.


The documentation for this class was generated from the following file: