15 #ifndef NAV2_BEHAVIOR_TREE__PLUGINS__ACTION__NAVIGATE_THROUGH_POSES_ACTION_HPP_
16 #define NAV2_BEHAVIOR_TREE__PLUGINS__ACTION__NAVIGATE_THROUGH_POSES_ACTION_HPP_
21 #include "nav_msgs/msg/goals.hpp"
22 #include "nav2_msgs/action/navigate_through_poses.hpp"
23 #include "nav2_behavior_tree/bt_action_node.hpp"
25 namespace nav2_behavior_tree
35 using Action = nav2_msgs::action::NavigateThroughPoses;
36 using ActionResult = Action::Result;
46 const std::string & xml_tag_name,
47 const std::string & action_name,
48 const BT::NodeConfiguration & conf);
83 BT::RegisterJsonDefinition<nav_msgs::msg::Goals>();
87 BT::InputPort<nav_msgs::msg::Goals>(
88 "goals",
"Destinations to plan through"),
89 BT::InputPort<std::string>(
"behavior_tree",
"Behavior tree to run"),
90 BT::OutputPort<ActionResult::_error_code_type>(
91 "error_code_id",
"The navigate through poses error code"),
92 BT::OutputPort<std::string>(
93 "error_msg",
"The navigate through poses error msg"),
Abstract class representing an action based BT node.
static BT::PortsList providedBasicPorts(BT::PortsList addition)
Any subclass of BtActionNode that accepts parameters must provide a providedPorts method and call pro...
A nav2_behavior_tree::BtActionNode class that wraps nav2_msgs::action::NavigateThroughPoses.
void on_timeout() override
Function to perform work in a BT Node when the action server times out Such as setting the error code...
BT::NodeStatus on_cancelled() override
Function to perform some user-defined operation upon cancellation of the action.
NavigateThroughPosesAction(const std::string &xml_tag_name, const std::string &action_name, const BT::NodeConfiguration &conf)
A constructor for nav2_behavior_tree::NavigateThroughPosesAction.
static BT::PortsList providedPorts()
Creates list of BT ports.
BT::NodeStatus on_success() override
Function to perform some user-defined operation upon successful completion of the action.
void on_tick() override
Function to perform some user-defined operation on tick.
BT::NodeStatus on_aborted() override
Function to perform some user-defined operation upon abortion of the action.