/play_motion_builder_node/run
#
Caution
This documentation page has been auto-generated.
It may be missing some details.
/play_motion_builder_node/run
Quick Facts
- Category
- Message type
play_motion_builder_msgs/RunMotion
Quick snippets#
$ rostopic pub /play_motion_builder_node/run/goal play_motion_builder_msgs/RunMotionActionGoal # press Tab to complete the message prototype
How to use in your code#
#!/usr/bin/env python
import rospy
import actionlib
from play_motion_builder_msgs.msg import *
if __name__ == "__main__":
client = actionlib.SimpleActionClient("/play_motion_builder_node/run", play_motion_builder_msgs.msg.RunMotionAction)
client.wait_for_server()
# check the play_motion_builder_msgs/RunMotionGoal message
# definition for the possible goal parameters
goal = play_motion_builder_msgs.msg.RunMotionGoal(param1=..., param2=...)
client.send_goal(goal)
client.wait_for_result()
rospy.loginfo("Action returned: %s" % client.get_result())
#include <ros/ros.h>
#include <actionlib/client/simple_action_client.h>
#include <actionlib/client/terminal_state.h>
#include <play_motion_builder_msgs/RunMotionAction.h>
int main (int argc, char **argv)
{
ros::init(argc, argv, "play_motion_builder_node_run_action_client");
// create the action client
// true causes the client to spin its own thread
actionlib::SimpleActionClient<:play_motion_builder_msgs::RunMotionAction> ac("/play_motion_builder_node/run", true);
ROS_INFO("Waiting for action server to start.");
// wait for the action server to start
ac.waitForServer(); //will wait for infinite time
ROS_INFO("Action server started, sending goal.");
// send a goal to the action
play_motion_builder_msgs::RunMotionGoal goal;
// check the play_motion_builder_msgs/RunMotionGoal message
// definition for the possible goal parameters
// goal.... = ...;
ac.sendGoal(goal);
//wait for the action to return
bool finished_before_timeout = ac.waitForResult(ros::Duration(30.0));
if (finished_before_timeout)
{
actionlib::SimpleClientGoalState state = ac.getState();
ROS_INFO("Action finished: %s",state.toString().c_str());
}
else
{
ROS_INFO("Action did not finish before the time out.");
ac.cancelGoal();
}
return 0;
}
You can also access this action from a webpage displayed on the robot’s touchscreen via this endpoint:
http://<robot>-0c/action/motion_builder_run
(replace <robot>-0c
by the serial number of your own robot).
See REST interface for the general documentation of the REST endpoints and code samples.