/usr/include/OGRE/OgreNode.h is in libogre-1.9-dev 1.9.0+dfsg1-4.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161 162 163 164 165 166 167 168 169 170 171 172 173 174 175 176 177 178 179 180 181 182 183 184 185 186 187 188 189 190 191 192 193 194 195 196 197 198 199 200 201 202 203 204 205 206 207 208 209 210 211 212 213 214 215 216 217 218 219 220 221 222 223 224 225 226 227 228 229 230 231 232 233 234 235 236 237 238 239 240 241 242 243 244 245 246 247 248 249 250 251 252 253 254 255 256 257 258 259 260 261 262 263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 300 301 302 303 304 305 306 307 308 309 310 311 312 313 314 315 316 317 318 319 320 321 322 323 324 325 326 327 328 329 330 331 332 333 334 335 336 337 338 339 340 341 342 343 344 345 346 347 348 349 350 351 352 353 354 355 356 357 358 359 360 361 362 363 364 365 366 367 368 369 370 371 372 373 374 375 376 377 378 379 380 381 382 383 384 385 386 387 388 389 390 391 392 393 394 395 396 397 398 399 400 401 402 403 404 405 406 407 408 409 410 411 412 413 414 415 416 417 418 419 420 421 422 423 424 425 426 427 428 429 430 431 432 433 434 435 436 437 438 439 440 441 442 443 444 445 446 447 448 449 450 451 452 453 454 455 456 457 458 459 460 461 462 463 464 465 466 467 468 469 470 471 472 473 474 475 476 477 478 479 480 481 482 483 484 485 486 487 488 489 490 491 492 493 494 495 496 497 498 499 500 501 502 503 504 505 506 507 508 509 510 511 512 513 514 515 516 517 518 519 520 521 522 523 524 525 526 527 528 529 530 531 532 533 534 535 536 537 538 539 540 541 542 543 544 545 546 547 548 549 550 551 552 553 554 555 556 557 558 559 560 561 562 563 564 565 566 567 568 569 570 571 572 573 574 575 576 577 578 579 580 581 582 583 584 585 586 587 588 589 590 591 592 593 594 595 596 597 598 599 600 601 602 603 604 605 606 607 608 609 610 611 612 613 614 615 616 617 618 619 620 621 622 623 624 625 626 627 628 629 630 631 632 633 634 635 636 637 638 639 640 641 642 643 644 645 646 647 648 649 650 651 652 653 654 655 656 657 658 659 660 661 662 663 664 665 666 667 668 669 670 671 672 673 674 675 676 677 678 679 680 681 682 683 684 685 686 687 688 689 690 691 692 693 694 695 696 697 698 699 700 701 702 703 704 705 706 707 708 709 710 711 712 713 714 715 716 717 718 719 720 721 722 723 724 725 726 727 728 729 730 731 732 733 734 735 736 737 738 739 740 741 742 743 744 745 746 747 748 749 750 751 752 753 754 755 756 757 758 759 760 761 762 763 764 765 766 767 768 769 770 771 772 773 774 775 776 777 778 779 780 781 782 | /*
-----------------------------------------------------------------------------
This source file is part of OGRE
(Object-oriented Graphics Rendering Engine)
For the latest info, see http://www.ogre3d.org/
Copyright (c) 2000-2013 Torus Knot Software Ltd
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
-----------------------------------------------------------------------------
*/
#ifndef _Node_H__
#define _Node_H__
#include "OgrePrerequisites.h"
#include "OgreCommon.h"
#include "OgreMatrix3.h"
#include "OgreMatrix4.h"
#include "OgreQuaternion.h"
#include "OgreString.h"
#include "OgreRenderable.h"
#include "OgreIteratorWrappers.h"
#include "OgreMesh.h"
#include "OgreUserObjectBindings.h"
#include "OgreHeaderPrefix.h"
namespace Ogre {
class NameGenerator;
/** \addtogroup Core
* @{
*/
/** \addtogroup Scene
* @{
*/
/** 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.
@par
This is an abstract class - concrete classes are based on this for specific purposes,
e.g. SceneNode, Bone
*/
class _OgreExport Node : public NodeAlloc
{
public:
/** Enumeration denoting the spaces which a transform can be relative to.
*/
enum TransformSpace
{
/// Transform is relative to the local space
TS_LOCAL,
/// Transform is relative to the space of the parent node
TS_PARENT,
/// Transform is relative to world space
TS_WORLD
};
typedef HashMap<String, Node*> ChildNodeMap;
typedef MapIterator<ChildNodeMap> ChildNodeIterator;
typedef ConstMapIterator<ChildNodeMap> ConstChildNodeIterator;
/** Listener which gets called back on Node events.
*/
class _OgreExport Listener
{
public:
Listener() {}
virtual ~Listener() {}
/** Called when a node gets updated.
@remarks
Note that this happens when the node's derived update happens,
not every time a method altering it's state occurs. There may
be several state-changing calls but only one of these calls,
when the node graph is fully updated.
*/
virtual void nodeUpdated(const Node*) {}
/** Node is being destroyed */
virtual void nodeDestroyed(const Node*) {}
/** Node has been attached to a parent */
virtual void nodeAttached(const Node*) {}
/** Node has been detached from a parent */
virtual void nodeDetached(const Node*) {}
};
/** Inner class for displaying debug renderable for Node. */
class DebugRenderable : public Renderable, public NodeAlloc
{
protected:
Node* mParent;
MeshPtr mMeshPtr;
MaterialPtr mMat;
Real mScaling;
public:
DebugRenderable(Node* parent);
~DebugRenderable();
const MaterialPtr& getMaterial(void) const;
void getRenderOperation(RenderOperation& op);
void getWorldTransforms(Matrix4* xform) const;
Real getSquaredViewDepth(const Camera* cam) const;
const LightList& getLights(void) const;
void setScaling(Real s) { mScaling = s; }
};
protected:
/// Pointer to parent node
Node* mParent;
/// Collection of pointers to direct children; hashmap for efficiency
ChildNodeMap mChildren;
typedef set<Node*>::type ChildUpdateSet;
/// List of children which need updating, used if self is not out of date but children are
mutable ChildUpdateSet mChildrenToUpdate;
/// Flag to indicate own transform from parent is out of date
mutable bool mNeedParentUpdate;
/// Flag indicating that all children need to be updated
mutable bool mNeedChildUpdate;
/// Flag indicating that parent has been notified about update request
mutable bool mParentNotified ;
/// Flag indicating that the node has been queued for update
mutable bool mQueuedForUpdate;
/// Friendly name of this node, can be automatically generated if you don't care
String mName;
/// Incremented count for next name extension
static NameGenerator msNameGenerator;
/// Stores the orientation of the node relative to it's parent.
Quaternion mOrientation;
/// Stores the position/translation of the node relative to its parent.
Vector3 mPosition;
/// Stores the scaling factor applied to this node
Vector3 mScale;
/// Stores whether this node inherits orientation from it's parent
bool mInheritOrientation;
/// Stores whether this node inherits scale from it's parent
bool mInheritScale;
/// Only available internally - notification of parent.
virtual void setParent(Node* parent);
/** Cached combined orientation.
@par
This member is the orientation derived by combining the
local transformations and those of it's parents.
This is updated when _updateFromParent is called by the
SceneManager or the nodes parent.
*/
mutable Quaternion mDerivedOrientation;
/** Cached combined position.
@par
This member is the position derived by combining the
local transformations and those of it's parents.
This is updated when _updateFromParent is called by the
SceneManager or the nodes parent.
*/
mutable Vector3 mDerivedPosition;
/** Cached combined scale.
@par
This member is the position derived by combining the
local transformations and those of it's parents.
This is updated when _updateFromParent is called by the
SceneManager or the nodes parent.
*/
mutable Vector3 mDerivedScale;
/** Triggers the node to update it's combined transforms.
@par
This method is called internally by Ogre to ask the node
to update it's complete transformation based on it's parents
derived transform.
*/
virtual void _updateFromParent(void) const;
/** Class-specific implementation of _updateFromParent.
@remarks
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)
*/
virtual void updateFromParentImpl(void) const;
/** Internal method for creating a new child node - must be overridden per subclass. */
virtual Node* createChildImpl(void) = 0;
/** Internal method for creating a new child node - must be overridden per subclass. */
virtual Node* createChildImpl(const String& name) = 0;
/// The position to use as a base for keyframe animation
Vector3 mInitialPosition;
/// The orientation to use as a base for keyframe animation
Quaternion mInitialOrientation;
/// The scale to use as a base for keyframe animation
Vector3 mInitialScale;
/// Cached derived transform as a 4x4 matrix
mutable Matrix4 mCachedTransform;
mutable bool mCachedTransformOutOfDate;
/** Node listener - only one allowed (no list) for size & performance reasons. */
Listener* mListener;
typedef vector<Node*>::type QueuedUpdates;
static QueuedUpdates msQueuedUpdates;
DebugRenderable* mDebug;
/// User objects binding.
UserObjectBindings mUserObjectBindings;
public:
/** Constructor, should only be called by parent, not directly.
@remarks
Generates a name.
*/
Node();
/** Constructor, should only be called by parent, not directly.
@remarks
Assigned a name.
*/
Node(const String& name);
virtual ~Node();
/** Returns the name of the node. */
const String& getName(void) const;
/** Gets this node's parent (NULL if this is the root).
*/
virtual Node* getParent(void) const;
/** Returns a quaternion representing the nodes orientation.
*/
virtual const Quaternion & getOrientation() const;
/** 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.
@par
Note that rotations are oriented around the node's origin.
*/
virtual void setOrientation( const Quaternion& q );
/** Sets the orientation of this node via quaternion parameters.
@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.
@par
Note that rotations are oriented around the node's origin.
*/
virtual void setOrientation( Real w, Real x, Real y, Real z);
/** 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.
@par
Note that rotations are oriented around the node's origin.
*/
virtual void resetOrientation(void);
/** Sets the position of the node relative to it's parent.
*/
virtual void setPosition(const Vector3& pos);
/** Sets the position of the node relative to it's parent.
*/
virtual void setPosition(Real x, Real y, Real z);
/** Gets the position of the node relative to it's parent.
*/
virtual const Vector3 & getPosition(void) const;
/** 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.
@par
Note that like rotations, scalings are oriented around the node's origin.
*/
virtual void 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.
@par
Note that like rotations, scalings are oriented around the node's origin.
*/
virtual void setScale(Real x, Real y, Real z);
/** Gets the scaling factor of this node.
*/
virtual const Vector3 & getScale(void) const;
/** 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.
@param inherit If true, this node's orientation will be affected by its parent's orientation.
If false, it will not be affected.
*/
virtual void setInheritOrientation(bool inherit);
/** 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.
@remarks
See setInheritOrientation for more info.
*/
virtual bool getInheritOrientation(void) const;
/** 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.
@param inherit If true, this node's scale will be affected by its parent's scale. If false,
it will not be affected.
*/
virtual void setInheritScale(bool inherit);
/** Returns true if this node is affected by scaling factors applied to the parent node.
@remarks
See setInheritScale for more info.
*/
virtual bool getInheritScale(void) const;
/** 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.
@par
Note that like rotations, scalings are oriented around the node's origin.
*/
virtual void 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.
@par
Note that like rotations, scalings are oriented around the node's origin.
*/
virtual void scale(Real x, Real y, Real z);
/** Moves the node along the Cartesian axes.
@par
This method moves the node by the supplied vector along the
world Cartesian axes, i.e. along world x,y,z
@param d
Vector with x,y,z values representing the translation.
@param relativeTo
The space which this transform is relative to.
*/
virtual void translate(const Vector3& d, TransformSpace relativeTo = TS_PARENT);
/** Moves the node along the Cartesian axes.
@par
This method moves the node by the supplied vector along the
world Cartesian axes, i.e. along world x,y,z
@param x
Real @c x value representing the translation.
@param y
Real @c y value representing the translation.
@param z
Real @c z value representing the translation.
@param relativeTo
The space which this transform is relative to.
*/
virtual void translate(Real x, Real y, Real z, TransformSpace relativeTo = TS_PARENT);
/** Moves the node along arbitrary axes.
@remarks
This method translates the node by a vector which is relative to
a custom set of axes.
@param axes
A 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:
<pre>
1 0 0
0 1 0
0 0 1
</pre>
i.e. the identity matrix.
@param move
Vector relative to the axes above.
@param relativeTo
The space which this transform is relative to.
*/
virtual void translate(const Matrix3& axes, const Vector3& move, TransformSpace relativeTo = TS_PARENT);
/** Moves the node along arbitrary axes.
@remarks
This method translates the node by a vector which is relative to
a custom set of axes.
@param axes
A 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
<pre>
1 0 0
0 1 0
0 0 1
</pre>
i.e. the identity matrix.
@param x
The @c x translation component relative to the axes above.
@param y
The @c y translation component relative to the axes above.
@param z
The @c z translation component relative to the axes above.
@param relativeTo
The space which this transform is relative to.
*/
virtual void translate(const Matrix3& axes, Real x, Real y, Real z, TransformSpace relativeTo = TS_PARENT);
/** Rotate the node around the Z-axis.
*/
virtual void roll(const Radian& angle, TransformSpace relativeTo = TS_LOCAL);
/** Rotate the node around the X-axis.
*/
virtual void pitch(const Radian& angle, TransformSpace relativeTo = TS_LOCAL);
/** Rotate the node around the Y-axis.
*/
virtual void yaw(const Radian& angle, TransformSpace relativeTo = TS_LOCAL);
/** Rotate the node around an arbitrary axis.
*/
virtual void rotate(const Vector3& axis, const Radian& angle, TransformSpace relativeTo = TS_LOCAL);
/** Rotate the node around an aritrary axis using a Quarternion.
*/
virtual void rotate(const Quaternion& q, TransformSpace relativeTo = TS_LOCAL);
/** Gets a matrix whose columns are the local axes based on
the nodes orientation relative to it's parent. */
virtual Matrix3 getLocalAxes(void) const;
/** Creates an unnamed new Node as a child of this node.
@param translate
Initial translation offset of child relative to parent
@param rotate
Initial rotation relative to parent
*/
virtual Node* createChild(
const Vector3& translate = Vector3::ZERO,
const Quaternion& rotate = Quaternion::IDENTITY );
/** 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.
@param translate
Initial translation offset of child relative to parent
@param rotate
Initial rotation relative to parent
*/
virtual Node* createChild(const String& name, const Vector3& translate = Vector3::ZERO, const Quaternion& rotate = Quaternion::IDENTITY);
/** Adds a (precreated) child scene node to this node. If it is attached to another node,
it must be detached first.
@param child The Node which is to become a child node of this one
*/
virtual void addChild(Node* child);
/** Reports the number of child nodes under this one.
*/
virtual unsigned short numChildren(void) const;
/** Gets a pointer to a child node.
@remarks
There is an alternate getChild method which returns a named child.
*/
virtual Node* getChild(unsigned short index) const;
/** Gets a pointer to a named child node.
*/
virtual Node* getChild(const String& name) const;
/** Retrieves an iterator for efficiently looping through all children of this node.
@remarks
Using this is faster than repeatedly calling getChild if you want to go through
all (or most of) the children of this node.
Note that the returned iterator is only valid whilst no children are added or
removed from this node. Thus you should not store this returned iterator for
later use, nor should you add / remove children whilst iterating through it;
store up changes for later. Note that calling methods on returned items in
the iterator IS allowed and does not invalidate the iterator.
*/
virtual ChildNodeIterator getChildIterator(void);
/** Retrieves an iterator for efficiently looping through all children of this node.
@remarks
Using this is faster than repeatedly calling getChild if you want to go through
all (or most of) the children of this node.
Note that the returned iterator is only valid whilst no children are added or
removed from this node. Thus you should not store this returned iterator for
later use, nor should you add / remove children whilst iterating through it;
store up changes for later. Note that calling methods on returned items in
the iterator IS allowed and does not invalidate the iterator.
*/
virtual ConstChildNodeIterator getChildIterator(void) const;
/** 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.
*/
virtual Node* removeChild(unsigned short index);
/** 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.
*/
virtual Node* removeChild(Node* child);
/** Drops the named child from this node.
@remarks
Does not delete the node, just detaches it from
this parent, potentially to be reattached elsewhere.
*/
virtual Node* removeChild(const String& name);
/** Removes all child Nodes attached to this node. Does not delete the nodes, just detaches them from
this parent, potentially to be reattached elsewhere.
*/
virtual void removeAllChildren(void);
/** Sets the final world position of the node directly.
@remarks
It's advisable to use the local setPosition if possible
*/
virtual void _setDerivedPosition(const Vector3& pos);
/** 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.
*/
virtual void _setDerivedOrientation(const Quaternion& q);
/** Gets the orientation of the node as derived from all parents.
*/
virtual const Quaternion & _getDerivedOrientation(void) const;
/** Gets the position of the node as derived from all parents.
*/
virtual const Vector3 & _getDerivedPosition(void) const;
/** Gets the scaling factor of the node as derived from all parents.
*/
virtual const Vector3 & _getDerivedScale(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.
*/
virtual const Matrix4& _getFullTransform(void) const;
/** 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.
@param updateChildren
If @c 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.
@param 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.
*/
virtual void _update(bool updateChildren, bool parentHasChanged);
/** Sets a listener for this Node.
@remarks
Note for size and performance reasons only one listener per node is
allowed.
*/
virtual void setListener(Listener* listener) { mListener = listener; }
/** Gets the current listener for this Node.
*/
virtual Listener* getListener(void) const { return mListener; }
/** 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.
@par
If you never call this method, the initial state is the identity transform, ie do nothing.
*/
virtual void setInitialState(void);
/** Resets the position / orientation / scale of this node to it's initial state, see setInitialState for more info. */
virtual void resetToInitialState(void);
/** Gets the initial position of this node, see setInitialState for more info.
@remarks
Also resets the cumulative animation weight used for blending.
*/
virtual const Vector3& getInitialPosition(void) const;
/** Gets the local position, relative to this node, of the given world-space position */
virtual Vector3 convertWorldToLocalPosition( const Vector3 &worldPos );
/** Gets the world position of a point in the node local space
useful for simple transforms that don't require a child node.*/
virtual Vector3 convertLocalToWorldPosition( const Vector3 &localPos );
/** Gets the local orientation, relative to this node, of the given world-space orientation */
virtual Quaternion convertWorldToLocalOrientation( const Quaternion &worldOrientation );
/** Gets the world orientation of an orientation in the node local space
useful for simple transforms that don't require a child node.*/
virtual Quaternion convertLocalToWorldOrientation( const Quaternion &localOrientation );
/** Gets the initial orientation of this node, see setInitialState for more info. */
virtual const Quaternion& getInitialOrientation(void) const;
/** Gets the initial position of this node, see setInitialState for more info. */
virtual const Vector3& getInitialScale(void) const;
/** Helper function, get the squared view depth. */
virtual Real getSquaredViewDepth(const Camera* cam) const;
/** 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.
@param forceParentUpdate Even if the node thinks it has already told it's
parent, tell it anyway
*/
virtual void needUpdate(bool forceParentUpdate = false);
/** Called by children to notify their parent that they need an update.
@param forceParentUpdate Even if the node thinks it has already told it's
parent, tell it anyway
*/
virtual void requestUpdate(Node* child, bool forceParentUpdate = false);
/** Called by children to notify their parent that they no longer need an update. */
virtual void cancelUpdate(Node* child);
/** Get a debug renderable for rendering the Node. */
virtual DebugRenderable* getDebugRenderable(Real scaling);
/** 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.
*/
static void queueNeedUpdate(Node* n);
/** Process queued 'needUpdate' calls. */
static void processQueuedUpdates(void);
/** @deprecated use UserObjectBindings::setUserAny via getUserObjectBindings() instead.
Sets any kind of user value on this object.
@remarks
This method allows you to associate any user value you like with
this Node. This can be a pointer back to one of your own
classes for instance.
*/
OGRE_DEPRECATED virtual void setUserAny(const Any& anything) { getUserObjectBindings().setUserAny(anything); }
/** @deprecated use UserObjectBindings::getUserAny via getUserObjectBindings() instead.
Retrieves the custom user value associated with this object.
*/
OGRE_DEPRECATED virtual const Any& getUserAny(void) const { return getUserObjectBindings().getUserAny(); }
/** 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.
@see UserObjectBindings::setUserAny.
*/
UserObjectBindings& getUserObjectBindings() { return mUserObjectBindings; }
/** 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.
@see UserObjectBindings::setUserAny.
*/
const UserObjectBindings& getUserObjectBindings() const { return mUserObjectBindings; }
};
/** @} */
/** @} */
} // namespace Ogre
#include "OgreHeaderSuffix.h"
#endif // _Node_H__
|