[π€ ROS2?] /execute_task
#
Caution
This documentation page has been auto-generated.
It may be missing some details.
/execute_task
Quick Facts
- Category
- Message type
pal_task_msgs/action/ExecuteTask
Quick snippets#
$ ros2 action send_goal /execute_task pal_task_msgs/action/ExecuteTask # 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 pal_task_msgs.action import ExecuteTask
class ExecuteTaskActionClient(Node):
def __init__(self):
super().__init__('execute_task_client')
self._action_client = ActionClient(self, ExecuteTask, '/execute_task')
def send_goal(self, a, b):
goal_msg = ExecuteTask.Goal()
# TODO: adapt to the action's parameters
# check the pal_task_msgs/action/ExecuteTaskGoal 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 = ExecuteTaskActionClient()
# 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 "pal_task_msgs/action/execute_task.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 ExecuteTaskActionClient : public rclcpp::Node
{
public:
using ExecuteTask = pal_task_msgs::action::ExecuteTask;
using GoalHandleExecuteTask = rclcpp_action::ClientGoalHandle<ExecuteTask>;
explicit ExecuteTaskActionClient(const rclcpp::NodeOptions & options)
: Node("execute_task_action_client", options)
{
this->client_ptr_ = rclcpp_action::create_client<ExecuteTask>(
this,
"/execute_task");
this->timer_ = this->create_wall_timer(
500ms,
bind(&ExecuteTaskActionClient::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 = ExecuteTask::Goal();
// check the pal_task_msgs/action/ExecuteTaskGoal message
// definition for the possible goal parameters
// goal_msg.... = ...;
RCLCPP_INFO(this->get_logger(), "Sending goal");
auto send_goal_options = rclcpp_action::Client<ExecuteTask>::SendGoalOptions();
send_goal_options.goal_response_callback =
bind(&ExecuteTaskActionClient::goal_response_callback, this, _1);
send_goal_options.feedback_callback =
bind(&ExecuteTaskActionClient::feedback_callback, this, _1, _2);
send_goal_options.result_callback =
bind(&ExecuteTaskActionClient::result_callback, this, _1);
this->client_ptr_->async_send_goal(goal_msg, send_goal_options);
}
private:
rclcpp_action::Client<ExecuteTask>::SharedPtr client_ptr_;
rclcpp::TimerBase::SharedPtr timer_;
void goal_response_callback(const GoalHandleExecuteTask::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(
GoalHandleExecuteTask::SharedPtr,
const shared_ptr<const ExecuteTask::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 GoalHandleExecuteTask::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 ExecuteTaskActionClient
RCLCPP_COMPONENTS_REGISTER_NODE(ExecuteTaskActionClient)
You can also access this action from a webpage displayed on the robotβs touchscreen via this endpoint:
http://<robot>-0c/action/execute_task_now
(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.