Actor.hh
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2012-2015 Open Source Robotics Foundation
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16 */
17 #ifndef _ACTOR_HH_
18 #define _ACTOR_HH_
19 
20 #include <string>
21 #include <map>
22 #include <vector>
23 
24 #include "gazebo/physics/Model.hh"
25 #include "gazebo/common/Time.hh"
28 #include "gazebo/util/system.hh"
29 
30 namespace gazebo
31 {
32  namespace common
33  {
34  class Mesh;
35  class Color;
36  }
37 
38  namespace physics
39  {
42  {
44  public: TrajectoryInfo();
45 
47  public: unsigned int id;
48 
50  public: std::string type;
51 
53  public: double duration;
54 
56  public: double startTime;
57 
59  public: double endTime;
60 
62  public: bool translated;
63  };
64 
67 
72  {
75  public: explicit Actor(BasePtr _parent);
76 
78  public: virtual ~Actor();
79 
82  public: void Load(sdf::ElementPtr _sdf);
83 
85  public: virtual void Init();
86 
88  public: virtual void Play();
89 
91  public: virtual void Stop();
92 
94  public: virtual bool IsActive();
95 
97  public: void Update();
98 
100  public: virtual void Fini();
101 
104  public: virtual void UpdateParameters(sdf::ElementPtr _sdf);
105 
108  public: virtual const sdf::ElementPtr GetSDF();
109 
115  private: void AddSphereInertia(sdf::ElementPtr _linkSdf,
116  const math::Pose &_pose,
117  double _mass, double _radius);
118 
124  private: void AddSphereCollision(sdf::ElementPtr _linkSdf,
125  const std::string &_name,
126  const math::Pose &_pose,
127  double _radius);
128 
136  private: void AddSphereVisual(sdf::ElementPtr _linkSdf,
137  const std::string &_name,
138  const math::Pose &_pose,
139  double _radius,
140  const std::string &_material,
141  const common::Color &_ambient);
142 
150  private: void AddBoxVisual(sdf::ElementPtr _linkSdf,
151  const std::string &_name,
152  const math::Pose &_pose,
153  const math::Vector3 &_size,
154  const std::string &_material,
155  const common::Color &_ambient);
156 
161  private: void AddActorVisual(sdf::ElementPtr _linkSdf,
162  const std::string &_name,
163  const math::Pose &_pose);
164 
167  private: void LoadAnimation(sdf::ElementPtr _sdf);
168 
171  private: void LoadScript(sdf::ElementPtr _sdf);
172 
179  private: void SetPose(std::map<std::string, math::Matrix4> _frame,
180  std::map<std::string, std::string> _skelMap, double _time)
181  GAZEBO_DEPRECATED(6.0);
182 
187  private: void SetPose(
188  std::map<std::string, ignition::math::Matrix4d> _frame,
189  std::map<std::string, std::string> _skelMap, double _time);
190 
192  protected: const common::Mesh *mesh;
193 
196 
198  protected: std::string skinFile;
199 
201  protected: double skinScale;
202 
204  protected: double startDelay;
205 
207  protected: double scriptLength;
208 
210  protected: double lastScriptTime;
211 
213  protected: bool loop;
214 
216  protected: bool active;
217 
219  protected: bool autoStart;
220 
222  protected: LinkPtr mainLink;
223 
226 
229 
231  protected: std::map<unsigned int, common::PoseAnimation*> trajectories;
232 
234  protected: std::vector<TrajectoryInfo> trajInfo;
235 
237  protected: std::map<std::string, common::SkeletonAnimation*>
239 
241  protected: std::map<std::string, std::map<std::string, std::string> >
243 
245  protected: std::map<std::string, bool> interpolateX;
246 
248  protected: math::Vector3 lastPos;
249 
251  protected: double pathLength;
252 
254  protected: unsigned int lastTraj;
255 
257  protected: std::string visualName;
258 
260  protected: uint32_t visualId;
261 
264 
266  protected: std::string oldAction;
267  };
269  }
270 }
271 #endif
A 3D mesh.
Definition: Mesh.hh:44
boost::shared_ptr< Base > BasePtr
Definition: PhysicsTypes.hh:68
bool autoStart
True if the actor should start running automatically.
Definition: Actor.hh:219
double endTime
End time of the trajectory.
Definition: Actor.hh:59
#define GZ_PHYSICS_VISIBLE
Definition: system.hh:318
A skeleton.
Definition: Skeleton.hh:53
Encapsulates a position and rotation in three space.
Definition: Pose.hh:37
LinkPtr mainLink
Base link.
Definition: Actor.hh:222
std::string oldAction
THe old action.
Definition: Actor.hh:266
double pathLength
Length of the actor's path.
Definition: Actor.hh:251
The Vector3 class represents the generic vector containing 3 elements.
Definition: Vector3.hh:39
unsigned int id
ID of the trajectory.
Definition: Actor.hh:47
std::map< std::string, common::SkeletonAnimation * > skelAnimation
Skeleton animations.
Definition: Actor.hh:238
double skinScale
Scaling factor to apply to the skin.
Definition: Actor.hh:201
Actor class enables GPU based mesh model / skeleton scriptable animation.
Definition: Actor.hh:71
#define GAZEBO_DEPRECATED(version)
Definition: CommonTypes.hh:47
const common::Mesh * mesh
Pointer to the actor's mesh.
Definition: Actor.hh:192
double lastScriptTime
Time the scipt was last updated.
Definition: Actor.hh:210
common::Skeleton * skeleton
The actor's skeleton.
Definition: Actor.hh:195
A model is a collection of links, joints, and plugins.
Definition: Model.hh:52
uint32_t visualId
ID for this visual.
Definition: Actor.hh:260
std::string visualName
Name of the visual.
Definition: Actor.hh:257
bool active
True if the actor is being updated.
Definition: Actor.hh:216
Information about a trajectory for an Actor.
Definition: Actor.hh:41
double startTime
Start time of the trajectory.
Definition: Actor.hh:56
std::string type
Type of trajectory.
Definition: Actor.hh:50
double scriptLength
Time length of a scipt.
Definition: Actor.hh:207
bool translated
True if the trajectory is tranlated.
Definition: Actor.hh:62
unsigned int lastTraj
THe last trajectory.
Definition: Actor.hh:254
double duration
Duration of the trajectory.
Definition: Actor.hh:53
Defines a color.
Definition: Color.hh:36
bool loop
True if the animation should loop.
Definition: Actor.hh:213
std::vector< TrajectoryInfo > trajInfo
Trajectory information.
Definition: Actor.hh:234
GAZEBO_VISIBLE void Init(google::protobuf::Message &_message, const std::string &_id="")
Initialize a message.
math::Vector3 lastPos
Last position of the actor.
Definition: Actor.hh:248
std::map< std::string, bool > interpolateX
True to interpolate along x direction.
Definition: Actor.hh:245
std::map< unsigned int, common::PoseAnimation * > trajectories
All the trajectories.
Definition: Actor.hh:231
std::map< std::string, std::map< std::string, std::string > > skelNodesMap
Skeleton to naode map.
Definition: Actor.hh:242
transport::PublisherPtr bonePosePub
Where to send bone info.
Definition: Actor.hh:263
common::Time playStartTime
Time when the animation was started.
Definition: Actor.hh:228
std::string skinFile
Filename for the skin.
Definition: Actor.hh:198
boost::shared_ptr< Publisher > PublisherPtr
Definition: TransportTypes.hh:49
common::Time prevFrameTime
Time of the previous frame.
Definition: Actor.hh:225
boost::shared_ptr< Link > LinkPtr
Definition: PhysicsTypes.hh:92
A Time class, can be used to hold wall- or sim-time.
Definition: Time.hh:39
double startDelay
Amount of time to delay start by.
Definition: Actor.hh:204