23#ifndef EASYNAV_PLANNER__PLANNERNODE_HPP_
24#define EASYNAV_PLANNER__PLANNERNODE_HPP_
26#include "rclcpp/macros.hpp"
27#include "rclcpp_lifecycle/lifecycle_node.hpp"
28#include "easynav_core/PlannerMethodBase.hpp"
29#include "pluginlib/class_loader.hpp"
30#include "nav_msgs/msg/path.hpp"
46 using
CallbackReturnT = rclcpp_lifecycle::node_interfaces::LifecycleNodeInterface::CallbackReturn;
53 const rclcpp::NodeOptions & options = rclcpp::NodeOptions());
104 [[nodiscard]] nav_msgs::msg::Path
get_path() const;
114 std::unique_ptr<pluginlib::ClassLoader<PlannerMethodBase>> planner_loader_;
117 std::shared_ptr<PlannerMethodBase> planner_method_ {
nullptr};
A blackboard-like structure to hold the current state of the navigation system.
A generic, type-safe, lock-free blackboard to hold runtime state.
Definition NavState.hpp:62
CallbackReturnT on_activate(const rclcpp_lifecycle::State &state)
Activate the node.
Definition PlannerNode.cpp:116
CallbackReturnT on_configure(const rclcpp_lifecycle::State &state)
Configure the node.
Definition PlannerNode.cpp:70
void cycle(std::shared_ptr< NavState > nav_state)
Execute a non-real-time cycle.
Definition PlannerNode.cpp:153
CallbackReturnT on_shutdown(const rclcpp_lifecycle::State &state)
Shutdown the node.
Definition PlannerNode.cpp:139
CallbackReturnT on_cleanup(const rclcpp_lifecycle::State &state)
Clean up the node.
Definition PlannerNode.cpp:132
nav_msgs::msg::Path get_path() const
Get the current planned path.
CallbackReturnT on_error(const rclcpp_lifecycle::State &state)
Handle lifecycle transition errors.
Definition PlannerNode.cpp:146
rclcpp_lifecycle::node_interfaces::LifecycleNodeInterface::CallbackReturn CallbackReturnT
Definition PlannerNode.hpp:46
PlannerNode(const rclcpp::NodeOptions &options=rclcpp::NodeOptions())
Constructor.
Definition PlannerNode.cpp:38
CallbackReturnT on_deactivate(const rclcpp_lifecycle::State &state)
Deactivate the node.
Definition PlannerNode.cpp:124
Definition RTTFBuffer.hpp:30
Definition PointPerception.hpp:56