DART 6.10.1
|
Entity class is a base class for any objects that exist in the kinematic tree structure of DART. More...
#include <Entity.hpp>
Public Types | |
using | EntitySignal = common::Signal< void(const Entity *)> |
using | FrameChangedSignal = common::Signal< void(const Entity *, const Frame *_oldFrame, const Frame *_newFrame)> |
using | NameChangedSignal = common::Signal< void(const Entity *, const std::string &_oldName, const std::string &_newName)> |
Public Member Functions | |
Entity (Frame *_refFrame, bool _quiet) | |
Constructor for typical usage. | |
Entity () | |
Default constructor, delegates to Entity(ConstructAbstract_t) | |
Entity (const Entity &)=delete | |
virtual | ~Entity () |
Destructor. | |
virtual const std::string & | setName (const std::string &_name)=0 |
Set name. | |
virtual const std::string & | getName () const =0 |
Return the name of this Entity. | |
Frame * | getParentFrame () |
Get the parent (reference) frame of this Entity. | |
const Frame * | getParentFrame () const |
Get the parent (reference) frame of this Entity. | |
bool | descendsFrom (const Frame *_someFrame) const |
Returns true if and only if this Entity is itself (i.e. | |
bool | isFrame () const |
True iff this Entity is also a Frame. | |
bool | isQuiet () const |
Returns true if this Entity is set to be quiet. | |
virtual void | notifyTransformUpdate () |
Notify the transformation update of this Entity that its parent Frame's pose is needed. | |
virtual void | dirtyTransform () |
Notify the transformation update of this Entity that its parent Frame's pose is needed. | |
bool | needsTransformUpdate () const |
Returns true iff a transform update is needed for this Entity. | |
virtual void | notifyVelocityUpdate () |
Notify the velocity update of this Entity that its parent Frame's velocity is needed. | |
virtual void | dirtyVelocity () |
Notify the velocity update of this Entity that its parent Frame's velocity is needed. | |
bool | needsVelocityUpdate () const |
Returns true iff a velocity update is needed for this Entity. | |
virtual void | notifyAccelerationUpdate () |
Notify the acceleration of this Entity that its parent Frame's acceleration is needed. | |
virtual void | dirtyAcceleration () |
Notify the acceleration of this Entity that its parent Frame's acceleration is needed. | |
bool | needsAccelerationUpdate () const |
Returns true iff an acceleration update is needed for this Entity. | |
Protected Types | |
enum | ConstructFrameTag { ConstructFrame } |
Used when constructing a Frame class, because the Frame constructor will take care of setting up the parameters you pass into it. More... | |
enum | ConstructAbstractTag { ConstructAbstract } |
Used when constructing a pure abstract class, because calling the Entity constructor is just a formality. More... | |
Protected Member Functions | |
Entity (ConstructFrameTag) | |
Entity (ConstructAbstractTag) | |
virtual void | changeParentFrame (Frame *_newParentFrame) |
Used by derived classes to change their parent frames. | |
void | sendDestructionNotification () const |
Send a destruction notification to all Observers. | |
void | addObserver (Observer *_observer) const |
Add an Observer to the list of Observers. | |
void | removeObserver (Observer *_observer) const |
Remove an Observer from the list of Observers. | |
Protected Attributes | |
Frame * | mParentFrame |
Parent frame of this Entity. | |
bool | mNeedTransformUpdate |
Does this Entity need a Transform update. | |
bool | mNeedVelocityUpdate |
Does this Entity need a Velocity update. | |
bool | mNeedAccelerationUpdate |
Does this Entity need an Acceleration update. | |
FrameChangedSignal | mFrameChangedSignal |
Frame changed signal. | |
NameChangedSignal | mNameChangedSignal |
Name changed signal. | |
EntitySignal | mTransformUpdatedSignal |
Transform changed signal. | |
EntitySignal | mVelocityChangedSignal |
Velocity changed signal. | |
EntitySignal | mAccelerationChangedSignal |
Acceleration changed signal. | |
std::set< Observer * > | mObservers |
List of current Observers. | |
Friends | |
class | Frame |
Slot registers | |
common::SlotRegister< FrameChangedSignal > | onFrameChanged |
Slot register for frame changed signal. | |
common::SlotRegister< NameChangedSignal > | onNameChanged |
Slot register for name changed signal. | |
common::SlotRegister< EntitySignal > | onTransformUpdated |
Slot register for transform updated signal. | |
common::SlotRegister< EntitySignal > | onVelocityChanged |
Slot register for velocity updated signal. | |
common::SlotRegister< EntitySignal > | onAccelerationChanged |
Slot register for acceleration updated signal. | |
const bool | mAmQuiet |
Whether or not this Entity is set to be quiet. | |
bool | mAmFrame |
Whether or not this Entity is a Frame. | |
Entity class is a base class for any objects that exist in the kinematic tree structure of DART.
Entities all share the following properties: they exist within a reference frame, have a name, and are visualizable. However, different Entity types may have different policies about how/if their reference frame or name can be changed. Use the Detachable class to create an Entity whose reference Frame can be changed arbitrarily.
using dart::dynamics::Entity::EntitySignal = common::Signal<void(const Entity*)> |
using dart::dynamics::Entity::FrameChangedSignal = common::Signal<void( const Entity*, const Frame* _oldFrame, const Frame* _newFrame)> |
using dart::dynamics::Entity::NameChangedSignal = common::Signal<void( const Entity*, const std::string& _oldName, const std::string& _newName)> |
|
protected |
Used when constructing a pure abstract class, because calling the Entity constructor is just a formality.
Enumerator | |
---|---|
ConstructAbstract |
|
protected |
|
explicit |
Constructor for typical usage.
dart::dynamics::Entity::Entity | ( | ) |
Default constructor, delegates to Entity(ConstructAbstract_t)
|
delete |
|
virtual |
Destructor.
|
explicitprotected |
|
explicitprotected |
|
protectedinherited |
Add an Observer to the list of Observers.
|
protectedvirtual |
Used by derived classes to change their parent frames.
Reimplemented in dart::dynamics::Frame.
bool dart::dynamics::Entity::descendsFrom | ( | const Frame * | _someFrame | ) | const |
|
virtual |
Notify the acceleration of this Entity that its parent Frame's acceleration is needed.
Reimplemented in dart::dynamics::BodyNode, dart::dynamics::Frame, and dart::dynamics::PointMassNotifier.
|
virtual |
Notify the transformation update of this Entity that its parent Frame's pose is needed.
Reimplemented in dart::dynamics::BodyNode, dart::dynamics::Frame, and dart::dynamics::PointMassNotifier.
|
virtual |
Notify the velocity update of this Entity that its parent Frame's velocity is needed.
Reimplemented in dart::dynamics::BodyNode, dart::dynamics::Frame, and dart::dynamics::PointMassNotifier.
|
pure virtual |
Return the name of this Entity.
Implemented in dart::dynamics::BodyNode, dart::dynamics::PointMassNotifier, dart::dynamics::SimpleFrame, dart::dynamics::WorldFrame, and dart::dynamics::JacobianNode.
const Frame * dart::dynamics::Entity::getParentFrame | ( | ) | const |
Get the parent (reference) frame of this Entity.
bool dart::dynamics::Entity::isQuiet | ( | ) | const |
Returns true if this Entity is set to be quiet.
A quiet entity is unknown to its parent Frame. It will not be tracked by its parent; it will not receive notifications from its parent, and it will not be rendered. The advantage to a quiet Entity is that it has less overhead when constructing and deconstructing, which makes it more suitable for temporary objects.
bool dart::dynamics::Entity::needsAccelerationUpdate | ( | ) | const |
Returns true iff an acceleration update is needed for this Entity.
bool dart::dynamics::Entity::needsTransformUpdate | ( | ) | const |
Returns true iff a transform update is needed for this Entity.
bool dart::dynamics::Entity::needsVelocityUpdate | ( | ) | const |
Returns true iff a velocity update is needed for this Entity.
|
virtual |
|
virtual |
|
virtual |
|
protectedinherited |
Remove an Observer from the list of Observers.
|
protectedinherited |
Send a destruction notification to all Observers.
This will cause all Observers to behave as if this Subject has been permanently deleted, so it should only be called when that behavior is desired.
|
pure virtual |
Set name.
Some implementations of Entity may make alterations to the name that gets passed in. The final name that this entity will use gets passed back in the return of this function.
Implemented in dart::dynamics::BodyNode, dart::dynamics::PointMassNotifier, dart::dynamics::SimpleFrame, dart::dynamics::WorldFrame, and dart::dynamics::JacobianNode.
|
friend |
|
protected |
Acceleration changed signal.
|
private |
Whether or not this Entity is set to be quiet.
|
protected |
Frame changed signal.
|
protected |
Name changed signal.
|
mutableprotected |
Does this Entity need an Acceleration update.
|
mutableprotected |
Does this Entity need a Transform update.
|
mutableprotected |
Does this Entity need a Velocity update.
|
mutableprotectedinherited |
List of current Observers.
|
protected |
Transform changed signal.
|
protected |
Velocity changed signal.
common::SlotRegister<EntitySignal> dart::dynamics::Entity::onAccelerationChanged |
Slot register for acceleration updated signal.
common::SlotRegister<FrameChangedSignal> dart::dynamics::Entity::onFrameChanged |
Slot register for frame changed signal.
common::SlotRegister<NameChangedSignal> dart::dynamics::Entity::onNameChanged |
Slot register for name changed signal.
common::SlotRegister<EntitySignal> dart::dynamics::Entity::onTransformUpdated |
Slot register for transform updated signal.
common::SlotRegister<EntitySignal> dart::dynamics::Entity::onVelocityChanged |
Slot register for velocity updated signal.