All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
Public Member Functions | Protected Member Functions | Protected Attributes | List of all members
gazebo::physics::Entity Class Referenceabstract

Base class for all physics objects in Gazebo. More...

#include <physics/physics.hh>

Inheritance diagram for gazebo::physics::Entity:
Inheritance graph
[legend]
Collaboration diagram for gazebo::physics::Entity:
Collaboration graph
[legend]

Public Member Functions

 Entity (BasePtr _parent)
 Constructor. More...
 
virtual ~Entity ()
 Destructor. More...
 
virtual void Fini ()
 Finalize the entity. More...
 
virtual math::Box GetBoundingBox () const
 Return the bounding box for the entity. More...
 
CollisionPtr GetChildCollision (const std::string &_name)
 Get a child collision entity, if one exists. More...
 
LinkPtr GetChildLink (const std::string &_name)
 Get a child linke entity, if one exists. More...
 
math::Box GetCollisionBoundingBox () const
 Returns collision bounding box. More...
 
const math::PoseGetDirtyPose () const
 Returns Entity::dirtyPose. More...
 
math::Pose GetInitialRelativePose () const
 Get the initial relative pose. More...
 
void GetNearestEntityBelow (double &_distBelow, std::string &_entityName)
 Get the distance to the nearest entity below (along the Z-axis) this entity. More...
 
ModelPtr GetParentModel ()
 Get the parent model, if one exists. More...
 
virtual math::Vector3 GetRelativeAngularAccel () const
 Get the angular acceleration of the entity. More...
 
virtual math::Vector3 GetRelativeAngularVel () const
 Get the angular velocity of the entity. More...
 
virtual math::Vector3 GetRelativeLinearAccel () const
 Get the linear acceleration of the entity. More...
 
virtual math::Vector3 GetRelativeLinearVel () const
 Get the linear velocity of the entity. More...
 
math::Pose GetRelativePose () const
 Get the pose of the entity relative to its parent. More...
 
virtual math::Vector3 GetWorldAngularAccel () const
 Get the angular acceleration of the entity in the world frame. More...
 
virtual math::Vector3 GetWorldAngularVel () const
 Get the angular velocity of the entity in the world frame. More...
 
virtual math::Vector3 GetWorldLinearAccel () const
 Get the linear acceleration of the entity in the world frame. More...
 
virtual math::Vector3 GetWorldLinearVel () const
 Get the linear velocity of the entity in the world frame. More...
 
virtual const math::PoseGetWorldPose () const
 Get the absolute pose of the entity. More...
 
bool IsCanonicalLink () const
 A helper function that checks if this is a canonical body. More...
 
bool IsStatic () const
 Return whether this entity is static. More...
 
virtual void Load (sdf::ElementPtr _sdf)
 Load the entity. More...
 
void PlaceOnEntity (const std::string &_entityName)
 Move this entity to be ontop of another entity by name. More...
 
void PlaceOnNearestEntityBelow ()
 Move this entity to be ontop of the nearest entity below. More...
 
virtual void Reset ()
 Reset the entity. More...
 
void SetAnimation (const common::PoseAnimationPtr &_anim, boost::function< void()> _onComplete)
 Set an animation for this entity. More...
 
void SetAnimation (common::PoseAnimationPtr _anim)
 Set an animation for this entity. More...
 
void SetCanonicalLink (bool _value)
 Set to true if this entity is a canonical link for a model. More...
 
void SetInitialRelativePose (const math::Pose &_pose)
 Set the initial pose. More...
 
virtual void SetName (const std::string &_name)
 Set the name of the entity. More...
 
void SetRelativePose (const math::Pose &_pose, bool _notify=true, bool _publish=true)
 Set the pose of the entity relative to its parent. More...
 
void SetStatic (const bool &_static)
 Set whether this entity is static: immovable. More...
 
void SetWorldPose (const math::Pose &_pose, bool _notify=true, bool _publish=true)
 Set the world pose of the entity. More...
 
void SetWorldTwist (const math::Vector3 &_linear, const math::Vector3 &_angular, bool _updateChildren=true)
 Set angular and linear rates of an physics::Entity. More...
 
virtual void StopAnimation ()
 Stop the current animation, if any. More...
 
virtual void UpdateParameters (sdf::ElementPtr _sdf)
 Update the parameters using new sdf values. More...
 
- Public Member Functions inherited from gazebo::physics::Base
 Base (BasePtr _parent)
 Constructor. More...
 
virtual ~Base ()
 Destructor. More...
 
void AddChild (BasePtr _child)
 Add a child to this entity. More...
 
void AddType (EntityType _type)
 Add a type specifier. More...
 
BasePtr GetByName (const std::string &_name)
 Get by name. More...
 
BasePtr GetChild (unsigned int _i) const
 Get a child by index. More...
 
BasePtr GetChild (const std::string &_name)
 Get a child by name. More...
 
unsigned int GetChildCount () const
 Get the number of children. More...
 
uint32_t GetId () const
 Return the ID of this entity. More...
 
std::string GetName () const
 Return the name of the entity. More...
 
BasePtr GetParent () const
 Get the parent. More...
 
int GetParentId () const
 Return the ID of the parent. More...
 
bool GetSaveable () const
 Get whether the object should be "saved", when the user selects to save the world to xml. More...
 
std::string GetScopedName (bool _prependWorldName=false) const
 Return the name of this entity with the model scope model1::...::modelN::entityName. More...
 
virtual const sdf::ElementPtr GetSDF ()
 Get the SDF values for the object. More...
 
unsigned int GetType () const
 Get the full type definition. More...
 
const WorldPtrGetWorld () const
 Get the World this object is in. More...
 
bool HasType (const EntityType &_t) const
 Returns true if this object's type definition has the given type. More...
 
virtual void Init ()
 Initialize the object. More...
 
bool IsSelected () const
 True if the entity is selected by the user. More...
 
bool operator== (const Base &_ent) const
 Returns true if the entities are the same. More...
 
void Print (const std::string &_prefix)
 Print this object to screen via gzmsg. More...
 
virtual void RemoveChild (unsigned int _id)
 Remove a child from this entity. More...
 
void RemoveChild (const std::string &_name)
 Remove a child by name. More...
 
void RemoveChildren ()
 Remove all children. More...
 
virtual void Reset (Base::EntityType _resetType)
 Calls recursive Reset on one of the Base::EntityType's. More...
 
void SetParent (BasePtr _parent)
 Set the parent. More...
 
void SetSaveable (bool _v)
 Set whether the object should be "saved", when the user selects to save the world to xml. More...
 
virtual bool SetSelected (bool _show)
 Set whether this entity has been selected by the user through the gui. More...
 
void SetWorld (const WorldPtr &_newWorld)
 Set the world this object belongs to. More...
 
virtual void Update ()
 Update the object. More...
 

Protected Member Functions

virtual void OnPoseChange ()=0
 This function is called when the entity's (or one of its parents) pose of the parent has changed. More...
 
- Protected Member Functions inherited from gazebo::physics::Base
void ComputeScopedName ()
 Compute the scoped name of this object based on its parents. More...
 

Protected Attributes

common::PoseAnimationPtr animation
 Current pose animation. More...
 
event::ConnectionPtr animationConnection
 Connection used to update an animation. More...
 
math::Pose animationStartPose
 Start pose of an animation. More...
 
std::vector< event::ConnectionPtrconnections
 All our event connections. More...
 
math::Pose dirtyPose
 The pose set by a physics engine. More...
 
transport::NodePtr node
 Communication node. More...
 
EntityPtr parentEntity
 A helper that prevents numerous dynamic_casts. More...
 
common::Time prevAnimationTime
 Previous time an animation was updated. More...
 
transport::PublisherPtr requestPub
 Request publisher. More...
 
math::Vector3 scale
 Scale of the entity. More...
 
transport::PublisherPtr visPub
 Visual publisher. More...
 
msgs::Visual * visualMsg
 Visual message container. More...
 
math::Pose worldPose
 World pose of the entity. More...
 
- Protected Attributes inherited from gazebo::physics::Base
Base_V children
 Children of this entity. More...
 
BasePtr parent
 Parent of this entity. More...
 
sdf::ElementPtr sdf
 The SDF values for this object. More...
 
WorldPtr world
 Pointer to the world. More...
 

Additional Inherited Members

- Public Types inherited from gazebo::physics::Base
enum  EntityType {
  BASE = 0x00000000, ENTITY = 0x00000001, MODEL = 0x00000002, LINK = 0x00000004,
  COLLISION = 0x00000008, ACTOR = 0x00000016, LIGHT = 0x00000010, VISUAL = 0x00000020,
  JOINT = 0x00000040, BALL_JOINT = 0x00000080, HINGE2_JOINT = 0x00000100, HINGE_JOINT = 0x00000200,
  SLIDER_JOINT = 0x00000400, SCREW_JOINT = 0x00000800, UNIVERSAL_JOINT = 0x00001000, GEARBOX_JOINT = 0x00002000,
  SHAPE = 0x00010000, BOX_SHAPE = 0x00020000, CYLINDER_SHAPE = 0x00040000, HEIGHTMAP_SHAPE = 0x00080000,
  MAP_SHAPE = 0x00100000, MULTIRAY_SHAPE = 0x00200000, RAY_SHAPE = 0x00400000, PLANE_SHAPE = 0x00800000,
  SPHERE_SHAPE = 0x01000000, MESH_SHAPE = 0x02000000, POLYLINE_SHAPE = 0x04000000, SENSOR_COLLISION = 0x10000000
}
 Unique identifiers for all entity types. More...
 

Detailed Description

Base class for all physics objects in Gazebo.

Constructor & Destructor Documentation

gazebo::physics::Entity::Entity ( BasePtr  _parent)
explicit

Constructor.

Parameters
[in]_parentParent of the entity.
virtual gazebo::physics::Entity::~Entity ( )
virtual

Destructor.

Member Function Documentation

virtual void gazebo::physics::Entity::Fini ( )
virtual
virtual math::Box gazebo::physics::Entity::GetBoundingBox ( ) const
virtual
CollisionPtr gazebo::physics::Entity::GetChildCollision ( const std::string &  _name)

Get a child collision entity, if one exists.

Parameters
[in]_nameName of the child collision object.
Returns
Pointer to the Collision object, or NULL if not found.
LinkPtr gazebo::physics::Entity::GetChildLink ( const std::string &  _name)

Get a child linke entity, if one exists.

Parameters
[in]_nameName of the child Link object.
Returns
Pointer to the Link object, or NULL if not found.
math::Box gazebo::physics::Entity::GetCollisionBoundingBox ( ) const

Returns collision bounding box.

Returns
Collsiion boundin box.
const math::Pose& gazebo::physics::Entity::GetDirtyPose ( ) const

Returns Entity::dirtyPose.

The dirty pose is the pose set by the physics engine before it's value is propagated to the rest of the simulator.

Returns
The dirty pose of the entity.
math::Pose gazebo::physics::Entity::GetInitialRelativePose ( ) const

Get the initial relative pose.

Returns
The initial relative pose.
void gazebo::physics::Entity::GetNearestEntityBelow ( double &  _distBelow,
std::string &  _entityName 
)

Get the distance to the nearest entity below (along the Z-axis) this entity.

Parameters
[out]_distBelowThe distance to the nearest entity below.
[out]_entityNameThe name of the nearest entity below.
ModelPtr gazebo::physics::Entity::GetParentModel ( )

Get the parent model, if one exists.

Returns
Pointer to a model, or NULL if no parent model exists.
virtual math::Vector3 gazebo::physics::Entity::GetRelativeAngularAccel ( ) const
inlinevirtual

Get the angular acceleration of the entity.

Returns
A math::Vector3 for the acceleration.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

virtual math::Vector3 gazebo::physics::Entity::GetRelativeAngularVel ( ) const
inlinevirtual

Get the angular velocity of the entity.

Returns
A math::Vector3 for the velocity.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

virtual math::Vector3 gazebo::physics::Entity::GetRelativeLinearAccel ( ) const
inlinevirtual

Get the linear acceleration of the entity.

Returns
A math::Vector3 for the acceleration.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

virtual math::Vector3 gazebo::physics::Entity::GetRelativeLinearVel ( ) const
inlinevirtual

Get the linear velocity of the entity.

Returns
A math::Vector3 for the linear velocity.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

math::Pose gazebo::physics::Entity::GetRelativePose ( ) const

Get the pose of the entity relative to its parent.

Returns
The pose of the entity relative to its parent.
virtual math::Vector3 gazebo::physics::Entity::GetWorldAngularAccel ( ) const
inlinevirtual

Get the angular acceleration of the entity in the world frame.

Returns
A math::Vector3 for the acceleration.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

virtual math::Vector3 gazebo::physics::Entity::GetWorldAngularVel ( ) const
inlinevirtual

Get the angular velocity of the entity in the world frame.

Returns
A math::Vector3 for the velocity.

Reimplemented in gazebo::physics::Collision, gazebo::physics::Model, gazebo::physics::ODELink, gazebo::physics::DARTLink, gazebo::physics::BulletLink, and gazebo::physics::SimbodyLink.

virtual math::Vector3 gazebo::physics::Entity::GetWorldLinearAccel ( ) const
inlinevirtual

Get the linear acceleration of the entity in the world frame.

Returns
A math::Vector3 for the acceleration.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

virtual math::Vector3 gazebo::physics::Entity::GetWorldLinearVel ( ) const
inlinevirtual

Get the linear velocity of the entity in the world frame.

Returns
A math::Vector3 for the linear velocity.

Reimplemented in gazebo::physics::Link, gazebo::physics::Collision, and gazebo::physics::Model.

virtual const math::Pose& gazebo::physics::Entity::GetWorldPose ( ) const
inlinevirtual

Get the absolute pose of the entity.

Returns
The absolute pose of the entity.

Reimplemented in gazebo::physics::Collision.

bool gazebo::physics::Entity::IsCanonicalLink ( ) const
inline

A helper function that checks if this is a canonical body.

Returns
True if the link is canonical.
bool gazebo::physics::Entity::IsStatic ( ) const

Return whether this entity is static.

Returns
True if static.
virtual void gazebo::physics::Entity::Load ( sdf::ElementPtr  _sdf)
virtual
virtual void gazebo::physics::Entity::OnPoseChange ( )
protectedpure virtual
void gazebo::physics::Entity::PlaceOnEntity ( const std::string &  _entityName)

Move this entity to be ontop of another entity by name.

Parameters
[in]_entityNameName of the Entity this Entity should be ontop of.
void gazebo::physics::Entity::PlaceOnNearestEntityBelow ( )

Move this entity to be ontop of the nearest entity below.

virtual void gazebo::physics::Entity::Reset ( )
virtual

Reset the entity.

Reimplemented from gazebo::physics::Base.

Reimplemented in gazebo::physics::Model, and gazebo::physics::Link.

void gazebo::physics::Entity::SetAnimation ( const common::PoseAnimationPtr _anim,
boost::function< void()>  _onComplete 
)

Set an animation for this entity.

Parameters
[in]_animPose animation.
[in]_onCompleteCallback for when the animation completes.
void gazebo::physics::Entity::SetAnimation ( common::PoseAnimationPtr  _anim)

Set an animation for this entity.

Parameters
[in]_animPose animation.
void gazebo::physics::Entity::SetCanonicalLink ( bool  _value)

Set to true if this entity is a canonical link for a model.

Parameters
[in]_valueTrue if the link is canonical.
void gazebo::physics::Entity::SetInitialRelativePose ( const math::Pose _pose)

Set the initial pose.

Parameters
[in]_poseThe initial pose.
virtual void gazebo::physics::Entity::SetName ( const std::string &  _name)
virtual

Set the name of the entity.

Parameters
[in]_nameThe new name.

Reimplemented from gazebo::physics::Base.

void gazebo::physics::Entity::SetRelativePose ( const math::Pose _pose,
bool  _notify = true,
bool  _publish = true 
)

Set the pose of the entity relative to its parent.

Parameters
[in]_poseThe new pose.
[in]_notifyTrue = tell children of the pose change.
[in]_publishTrue to publish the pose.
void gazebo::physics::Entity::SetStatic ( const bool &  _static)

Set whether this entity is static: immovable.

Parameters
[in]_staticTrue = static.
void gazebo::physics::Entity::SetWorldPose ( const math::Pose _pose,
bool  _notify = true,
bool  _publish = true 
)

Set the world pose of the entity.

Parameters
[in]_poseThe new world pose.
[in]_notifyTrue = tell children of the pose change.
[in]_publishTrue to publish the pose.
void gazebo::physics::Entity::SetWorldTwist ( const math::Vector3 _linear,
const math::Vector3 _angular,
bool  _updateChildren = true 
)

Set angular and linear rates of an physics::Entity.

Parameters
[in]_linearLinear twist.
[in]_angularAngular twist.
[in]_updateChildrenTrue to pass this update to child entities.
virtual void gazebo::physics::Entity::StopAnimation ( )
virtual

Stop the current animation, if any.

Reimplemented in gazebo::physics::Model.

virtual void gazebo::physics::Entity::UpdateParameters ( sdf::ElementPtr  _sdf)
virtual

Update the parameters using new sdf values.

Parameters
[in]_sdfSDF to update from.

Reimplemented from gazebo::physics::Base.

Reimplemented in gazebo::physics::Actor, gazebo::physics::Link, gazebo::physics::Model, and gazebo::physics::Collision.

Member Data Documentation

common::PoseAnimationPtr gazebo::physics::Entity::animation
protected

Current pose animation.

event::ConnectionPtr gazebo::physics::Entity::animationConnection
protected

Connection used to update an animation.

math::Pose gazebo::physics::Entity::animationStartPose
protected

Start pose of an animation.

std::vector<event::ConnectionPtr> gazebo::physics::Entity::connections
protected

All our event connections.

math::Pose gazebo::physics::Entity::dirtyPose
protected

The pose set by a physics engine.

transport::NodePtr gazebo::physics::Entity::node
protected

Communication node.

EntityPtr gazebo::physics::Entity::parentEntity
protected

A helper that prevents numerous dynamic_casts.

common::Time gazebo::physics::Entity::prevAnimationTime
protected

Previous time an animation was updated.

transport::PublisherPtr gazebo::physics::Entity::requestPub
protected

Request publisher.

math::Vector3 gazebo::physics::Entity::scale
protected

Scale of the entity.

transport::PublisherPtr gazebo::physics::Entity::visPub
protected

Visual publisher.

msgs::Visual* gazebo::physics::Entity::visualMsg
protected

Visual message container.

math::Pose gazebo::physics::Entity::worldPose
mutableprotected

World pose of the entity.


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