[π€ ROS2?] /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/action/RunMotion
Quick snippets#
$ ros2 action send_goal /play_motion_builder_node/run play_motion_builder_msgs/action/RunMotion # press Tab to complete the message prototype
How to use in your code#
#!/usr/bin/env python
import rclpy
from rclpy.action import ActionClient
from rclpy.node import Node
from play_motion_builder_msgs.action import RunMotion
class RunActionClient(Node):
def __init__(self):
super().__init__('play_motion_builder_node_run_client')
self._action_client = ActionClient(self, RunMotion, '/play_motion_builder_node/run')
def send_goal(self, a, b):
goal_msg = RunMotion.Goal()
# TODO: adapt to the action's parameters
# check the play_motion_builder_msgs/action/RunMotionGoal message
# definition for the possible goal parameters
# goal_msg.a = a
# goal_msg.b = b
self._action_client.wait_for_server()
return self._action_client.send_goal_async(goal_msg)
if __name__ == '__main__':
rclpy.init(args=args)
action_client = RunActionClient()
# TODO: adapt to your action's parameters
future = action_client.send_goal(a, b)
rclpy.spin_until_future_complete(action_client, future)
rclpy.shutdown()
#include <functional>
#include <future>
#include <memory>
#include <string>
#include <sstream>
#include <chrono>
#include "play_motion_builder_msgs/action/run_motion.hpp"
#include "rclcpp/rclcpp.hpp"
#include "rclcpp_action/rclcpp_action.hpp"
#include "rclcpp_components/register_node_macro.hpp"
using namespace std::chrono_literals;
using namespace std;
class RunActionClient : public rclcpp::Node
{
public:
using RunMotion = play_motion_builder_msgs::action::RunMotion;
using GoalHandleRunMotion = rclcpp_action::ClientGoalHandle<RunMotion>;
explicit RunActionClient(const rclcpp::NodeOptions & options)
: Node("play_motion_builder_node_run_action_client", options)
{
this->client_ptr_ = rclcpp_action::create_client<RunMotion>(
this,
"/play_motion_builder_node/run");
this->timer_ = this->create_wall_timer(
500ms,
bind(&RunActionClient::send_goal, this));
}
void send_goal()
{
using namespace std::placeholders;
this->timer_->cancel();
if (!this->client_ptr_->wait_for_action_server()) {
RCLCPP_ERROR(this->get_logger(), "Action server not available after waiting");
rclcpp::shutdown();
}
auto goal_msg = RunMotion::Goal();
// check the play_motion_builder_msgs/action/RunMotionGoal message
// definition for the possible goal parameters
// goal_msg.... = ...;
RCLCPP_INFO(this->get_logger(), "Sending goal");
auto send_goal_options = rclcpp_action::Client<RunMotion>::SendGoalOptions();
send_goal_options.goal_response_callback =
bind(&RunActionClient::goal_response_callback, this, _1);
send_goal_options.feedback_callback =
bind(&RunActionClient::feedback_callback, this, _1, _2);
send_goal_options.result_callback =
bind(&RunActionClient::result_callback, this, _1);
this->client_ptr_->async_send_goal(goal_msg, send_goal_options);
}
private:
rclcpp_action::Client<RunMotion>::SharedPtr client_ptr_;
rclcpp::TimerBase::SharedPtr timer_;
void goal_response_callback(const GoalHandleRunMotion::SharedPtr & goal_handle)
{
if (!goal_handle) {
RCLCPP_ERROR(this->get_logger(), "Goal was rejected by server");
} else {
RCLCPP_INFO(this->get_logger(), "Goal accepted by server, waiting for result");
}
}
void feedback_callback(
GoalHandleRunMotion::SharedPtr,
const shared_ptr<const RunMotion::Feedback> feedback)
{
stringstream ss;
ss << "Next number in sequence received: ";
for (auto number : feedback->partial_sequence) {
ss << number << " ";
}
RCLCPP_INFO(this->get_logger(), ss.str().c_str());
}
void result_callback(const GoalHandleRunMotion::WrappedResult & result)
{
switch (result.code) {
case rclcpp_action::ResultCode::SUCCEEDED:
break;
case rclcpp_action::ResultCode::ABORTED:
RCLCPP_ERROR(this->get_logger(), "Goal was aborted");
return;
case rclcpp_action::ResultCode::CANCELED:
RCLCPP_ERROR(this->get_logger(), "Goal was canceled");
return;
default:
RCLCPP_ERROR(this->get_logger(), "Unknown result code");
return;
}
stringstream ss;
ss << "Result received: ";
for (auto number : result.result->sequence) {
ss << number << " ";
}
RCLCPP_INFO(this->get_logger(), ss.str().c_str());
rclcpp::shutdown();
}
}; // class RunActionClient
RCLCPP_COMPONENTS_REGISTER_NODE(RunActionClient)
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 js-api for the general documentation of the REST endpoints and code samples.