Compare commits
55 Commits
0f58db3481
...
3.0
| Author | SHA1 | Date | |
|---|---|---|---|
| 5583b3e0f2 | |||
| 7baa7000b8 | |||
| c05a3e4439 | |||
| d38f6b3954 | |||
| 9a4bb95c4c | |||
| 76ee97f2ec | |||
| aa63caa188 | |||
| e90a84c229 | |||
| ae32077fe2 | |||
| 180a646e35 | |||
| 98ce71eb69 | |||
| c36f3737ba | |||
| f0d987da39 | |||
| 6d3af679a9 | |||
| 1c12239478 | |||
| 3f1f762f9b | |||
| ddb7df7c50 | |||
| 75cbf5a7ef | |||
| ae2f647fc9 | |||
| 9e7d98934d | |||
| 66d26e4f22 | |||
| 7512b6261a | |||
| 85355581d1 | |||
| 7afd85e2c6 | |||
| 4617ce85b6 | |||
| a1cc2fccb1 | |||
| 57caf8d213 | |||
| 5550e1cf3b | |||
| b690e93650 | |||
| 06c2d01b4a | |||
| ff8a90cbaa | |||
| 83f0e85e4a | |||
| ab3e65de1b | |||
| 34cabd2083 | |||
| b7e4c73c14 | |||
| 95c6fe0f1e | |||
| 5069931a87 | |||
| 99f014e14c | |||
| 3f3425228c | |||
| 81714a242d | |||
| 5e2f7bc712 | |||
| c0ceccf32c | |||
| 6e320bbe5c | |||
| bf74ae84ba | |||
| a43b714f01 | |||
| cab5655769 | |||
| fd022bd9d7 | |||
| 7b3c5b8d5f | |||
| 15f842d703 | |||
| 1fa6af01fd | |||
| 85789855a8 | |||
| 620db96de0 | |||
| 575e190988 | |||
| 3f93370462 | |||
| ebda1f81a1 |
1
.gitignore
vendored
1
.gitignore
vendored
@@ -421,3 +421,4 @@ FodyWeavers.xsd
|
||||
build
|
||||
install
|
||||
devel
|
||||
|
||||
|
||||
3
.gitmodules
vendored
3
.gitmodules
vendored
@@ -28,3 +28,6 @@
|
||||
[submodule "src/Libraries/xmlrpcpp"]
|
||||
path = src/Libraries/xmlrpcpp
|
||||
url = https://git.pnkr.asia/DuongTD/xmlrpcpp.git
|
||||
[submodule "src/Libraries/laser_filter"]
|
||||
path = src/Libraries/laser_filter
|
||||
url = https://git.pnkr.asia/DuongTD/laser_filter.git
|
||||
|
||||
@@ -51,6 +51,7 @@ sudo apt-get install -y \
|
||||
libyaml-cpp-dev \
|
||||
libpcl-dev \
|
||||
libgoogle-glog-dev
|
||||
sudo apt install liborocos-kdl-dev
|
||||
|
||||
# Optional: Cài đặt Google Test (nếu muốn build tests)
|
||||
sudo apt-get install -y libgtest-dev
|
||||
|
||||
@@ -30,10 +30,6 @@ message(STATUS "========================================")
|
||||
# Build các packages theo thứ tự phụ thuộc
|
||||
# 1. Core libraries (header-only hoặc base libraries)
|
||||
|
||||
if (NOT TARGET tf3)
|
||||
add_subdirectory(${CMAKE_SOURCE_DIR}/src/Libraries/tf3)
|
||||
endif()
|
||||
|
||||
if (NOT TARGET robot_time)
|
||||
add_subdirectory(${CMAKE_SOURCE_DIR}/src/Libraries/robot_time)
|
||||
endif()
|
||||
@@ -78,6 +74,10 @@ if (NOT TARGET robot_nav_2d_utils)
|
||||
add_subdirectory(${CMAKE_SOURCE_DIR}/src/Libraries/robot_nav_2d_utils)
|
||||
endif()
|
||||
|
||||
if (NOT TARGET laser_filter)
|
||||
add_subdirectory(${CMAKE_SOURCE_DIR}/src/Libraries/laser_filter)
|
||||
endif()
|
||||
|
||||
if (NOT TARGET robot_nav_core)
|
||||
add_subdirectory(${CMAKE_SOURCE_DIR}/src/Navigations/Cores/robot_nav_core)
|
||||
endif()
|
||||
|
||||
@@ -1,4 +1,5 @@
|
||||
obstacle_layer:
|
||||
enabled: true
|
||||
track_unknown_space: true
|
||||
transform_tolerance: 0.2
|
||||
topic: "map"
|
||||
|
||||
@@ -1,4 +1,4 @@
|
||||
robot_base_frame: base_footprint
|
||||
robot_base_frame: base_link
|
||||
transform_tolerance: 1.0
|
||||
obstacle_range: 3.0
|
||||
#mark_threshold: 1
|
||||
@@ -25,7 +25,7 @@ obstacles:
|
||||
data_type: LaserScan
|
||||
clearing: false
|
||||
marking: true
|
||||
inf_is_valid: false
|
||||
inf_is_valid: true
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
f_scan_clearing:
|
||||
@@ -33,7 +33,7 @@ obstacles:
|
||||
data_type: LaserScan
|
||||
clearing: true
|
||||
marking: false
|
||||
inf_is_valid: false
|
||||
inf_is_valid: true
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
b_scan_marking:
|
||||
@@ -41,7 +41,7 @@ obstacles:
|
||||
data_type: LaserScan
|
||||
clearing: false
|
||||
marking: true
|
||||
inf_is_valid: false
|
||||
inf_is_valid: true
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
b_scan_clearing:
|
||||
@@ -49,118 +49,8 @@ obstacles:
|
||||
data_type: LaserScan
|
||||
clearing: true
|
||||
marking: false
|
||||
inf_is_valid: false
|
||||
inf_is_valid: true
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
|
||||
|
||||
global_costmap:
|
||||
robot_base_frame: base_footprint
|
||||
transform_tolerance: 1.0
|
||||
obstacle_range: 3.0
|
||||
#mark_threshold: 1
|
||||
publish_voxel_map: true
|
||||
footprint_padding: 0.0
|
||||
|
||||
navigation_map:
|
||||
map_topic: /map
|
||||
map_pkg: managerments
|
||||
map_file: maze
|
||||
|
||||
virtual_walls_map:
|
||||
map_topic: /virtual_walls/map
|
||||
namespace: /virtual_walls
|
||||
map_pkg: managerments
|
||||
map_file: maze
|
||||
use_maximum: true
|
||||
lethal_cost_threshold: 100
|
||||
|
||||
obstacles:
|
||||
observation_sources: f_scan_marking f_scan_clearing b_scan_marking b_scan_clearing
|
||||
f_scan_marking:
|
||||
topic: /f_scan
|
||||
data_type: LaserScan
|
||||
clearing: false
|
||||
marking: true
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
f_scan_clearing:
|
||||
topic: /f_scan
|
||||
data_type: LaserScan
|
||||
clearing: true
|
||||
marking: false
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
b_scan_marking:
|
||||
topic: /b_scan
|
||||
data_type: LaserScan
|
||||
clearing: false
|
||||
marking: true
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
b_scan_clearing:
|
||||
topic: /b_scan
|
||||
data_type: LaserScan
|
||||
clearing: true
|
||||
marking: false
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
local_costmap:
|
||||
robot_base_frame: base_footprint
|
||||
transform_tolerance: 1.0
|
||||
obstacle_range: 3.0
|
||||
#mark_threshold: 1
|
||||
publish_voxel_map: true
|
||||
footprint_padding: 0.0
|
||||
|
||||
navigation_map:
|
||||
map_topic: /map
|
||||
map_pkg: managerments
|
||||
map_file: maze
|
||||
|
||||
virtual_walls_map:
|
||||
map_topic: /virtual_walls/map
|
||||
namespace: /virtual_walls
|
||||
map_pkg: managerments
|
||||
map_file: maze
|
||||
use_maximum: true
|
||||
lethal_cost_threshold: 100
|
||||
|
||||
obstacles:
|
||||
observation_sources: f_scan_marking f_scan_clearing b_scan_marking b_scan_clearing
|
||||
f_scan_marking:
|
||||
topic: /f_scan
|
||||
data_type: LaserScan
|
||||
clearing: false
|
||||
marking: true
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
f_scan_clearing:
|
||||
topic: /f_scan
|
||||
data_type: LaserScan
|
||||
clearing: true
|
||||
marking: false
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
b_scan_marking:
|
||||
topic: /b_scan
|
||||
data_type: LaserScan
|
||||
clearing: false
|
||||
marking: true
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
b_scan_clearing:
|
||||
topic: /b_scan
|
||||
data_type: LaserScan
|
||||
clearing: true
|
||||
marking: false
|
||||
inf_is_valid: false
|
||||
min_obstacle_height: 0.0
|
||||
max_obstacle_height: 0.25
|
||||
@@ -1,6 +1,6 @@
|
||||
global_costmap:
|
||||
library_path: libplugins
|
||||
robot_base_frame: base_footprint
|
||||
robot_base_frame: base_link
|
||||
global_frame: map
|
||||
update_frequency: 1.0
|
||||
publish_frequency: 1.0
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
local_costmap:
|
||||
library_path: libplugins
|
||||
global_frame: odom
|
||||
robot_base_frame: base_footprint
|
||||
robot_base_frame: base_link
|
||||
update_frequency: 6.0
|
||||
publish_frequency: 6.0
|
||||
rolling_window: true
|
||||
|
||||
@@ -1,4 +1,3 @@
|
||||
base_global_planner: CustomPlanner
|
||||
CustomPlanner:
|
||||
library_path: libcustom_planner
|
||||
environment_type: XYThetaLattice
|
||||
|
||||
11
config/dock_global_params.yaml
Normal file
11
config/dock_global_params.yaml
Normal file
@@ -0,0 +1,11 @@
|
||||
DockPlanner:
|
||||
library_path: libdock_planner
|
||||
MyGlobalPlanner:
|
||||
cost_threshold: 200 # Ngưỡng chi phí vật cản (0-255)
|
||||
safety_distance: 2 # Khoảng cách an toàn (cells)
|
||||
use_dijkstra: false # Sử dụng Dijkstra thay vì A*
|
||||
|
||||
# File: config/costmap_params.yaml
|
||||
global_costmap:
|
||||
inflation_radius: 0.3 # Bán kính phình vật cản
|
||||
cost_scaling_factor: 10.0 # Hệ số tỷ lệ chi phí
|
||||
@@ -1,12 +1,34 @@
|
||||
position_planner_name: PNKXLocalPlanner
|
||||
docking_planner_name: PNKXDockingLocalPlanner
|
||||
go_straight_planner_name: PNKXGoStraightLocalPlanner
|
||||
rotate_planner_name: PNKXRotateLocalPlanner
|
||||
base_local_planner: LocalPlannerAdapter
|
||||
base_global_planner: CustomPlanner
|
||||
|
||||
PNKXLocalPlanner:
|
||||
base_local_planner: LocalPlannerAdapter
|
||||
base_global_planner: CustomPlanner
|
||||
|
||||
PNKXDockingLocalPlanner:
|
||||
base_local_planner: LocalPlannerAdapter
|
||||
base_global_planner: TwoPointsPlanner
|
||||
|
||||
PNKXGoStraightLocalPlanner:
|
||||
base_local_planner: LocalPlannerAdapter
|
||||
base_global_planner: TwoPointsPlanner
|
||||
|
||||
PNKXRotateLocalPlanner:
|
||||
base_local_planner: LocalPlannerAdapter
|
||||
base_global_planner: TwoPointsPlanner
|
||||
|
||||
### replanning
|
||||
controller_frequency: 20.0 # run controller at 15.0 Hz
|
||||
controller_frequency: 30.0 # run controller at 15.0 Hz
|
||||
controller_patience: 0.0 # if the controller failed, clear obstacles and retry; after 15.0 s, abort and replan
|
||||
planner_frequency: 0.0 # don't continually replan (only when controller failed)
|
||||
planner_patience: 5.0 # if the first planning attempt failed, abort planning retries after 5.0 s...
|
||||
max_planning_retries: 5 # ... or after 10 attempts (whichever happens first)
|
||||
planner_patience: 2.0 # if the first planning attempt failed, abort planning retries after 5.0 s...
|
||||
max_planning_retries: 0 # ... or after 10 attempts (whichever happens first)
|
||||
oscillation_timeout: -1 # abort controller and trigger recovery behaviors after 30.0 s
|
||||
oscillation_distance: 0.4
|
||||
oscillation_distance: 0.5
|
||||
### recovery behaviors
|
||||
recovery_behavior_enabled: true
|
||||
recovery_behaviors: [
|
||||
|
||||
@@ -62,7 +62,7 @@ publish_acceleration: false
|
||||
# estimation node from robot_localization! However, that instance should *not* fuse the global data.
|
||||
map_frame: map # Defaults to "map" if unspecified
|
||||
odom_frame: $(arg tf_prefix)odom # Defaults to "odom" if unspecified
|
||||
base_link_frame: $(arg tf_prefix)base_footprint # Defaults to "base_link" if unspecified
|
||||
base_link_frame: $(arg tf_prefix)base_link # Defaults to "base_link" if unspecified
|
||||
world_frame: $(arg tf_prefix)odom # Defaults to the value of odom_frame if unspecified
|
||||
|
||||
# The filter accepts an arbitrary number of inputs from each input message type (robot_nav_msgs/Odometry,
|
||||
|
||||
@@ -25,7 +25,7 @@ Amcl:
|
||||
update_min_d: 0.05
|
||||
update_min_a: 0.05
|
||||
odom_frame_id: odom
|
||||
base_frame_id: base_footprint
|
||||
base_frame_id: base_link
|
||||
global_frame_id: map
|
||||
resample_interval: 1
|
||||
transform_tolerance: 0.2
|
||||
|
||||
@@ -25,7 +25,7 @@ wheel_radius_multiplier : 1.0 # default: 1.0
|
||||
cmd_vel_timeout: 1.0
|
||||
|
||||
# frame_ids (same as real MiR platform)
|
||||
base_frame_id: base_footprint # default: base_link base_footprint
|
||||
base_frame_id: base_link # default: base_link base_link
|
||||
odom_frame_id: odom # default: odom
|
||||
|
||||
# Velocity and acceleration limits
|
||||
|
||||
@@ -1,16 +1,9 @@
|
||||
yaw_goal_tolerance: 0.03
|
||||
xy_goal_tolerance: 0.02
|
||||
min_approach_linear_velocity: 0.05
|
||||
|
||||
position_planner_name: PNKXLocalPlanner
|
||||
docking_planner_name: PNKXDockingLocalPlanner
|
||||
go_straight_planner_name: PNKXGoStraightLocalPlanner
|
||||
rotate_planner_name: PNKXRotateLocalPlanner
|
||||
|
||||
base_local_planner: LocalPlannerAdapter
|
||||
LocalPlannerAdapter:
|
||||
library_path: liblocal_planner_adapter
|
||||
yaw_goal_tolerance: 0.017
|
||||
xy_goal_tolerance: 0.03
|
||||
min_approach_linear_velocity: 0.06 # The minimum velocity (m/s) threshold to apply when approaching the goal to ensure progress. Must be > 0.01. (default: 0.05)
|
||||
|
||||
PNKXLocalPlanner:
|
||||
# Algorithm
|
||||
library_path: libpnkx_local_planner
|
||||
@@ -55,15 +48,15 @@ LimitedAccelGenerator:
|
||||
min_vel_y: 0.0 # diff drive robot
|
||||
|
||||
max_speed_xy: 2.0 # max_trans_vel: 0.8 # choose slightly less than the base's capability
|
||||
min_speed_xy: 0.1 # min_trans_vel: 0.1 # this is the min trans velocity when there is negligible rotational velocity
|
||||
min_speed_xy: 0.25 # min_trans_vel: 0.1 # this is the min trans velocity when there is negligible rotational velocity
|
||||
|
||||
max_vel_theta: 0.9 # max_rot_vel: 1.0 # choose slightly less than the base's capability
|
||||
min_vel_theta: 0.04 # min_rot_vel: 0.1 default: 0.4 # this is the min angular velocity when there is negligible translational velocity
|
||||
max_vel_theta: 0.4 # max_rot_vel: 1.0 # choose slightly less than the base's capability
|
||||
min_vel_theta: 0.05 # min_rot_vel: 0.1 default: 0.4 # this is the min angular velocity when there is negligible translational velocity
|
||||
|
||||
acc_lim_x: 1.0
|
||||
acc_lim_x: 1.5
|
||||
acc_lim_y: 0.0 # diff drive robot
|
||||
acc_lim_theta: 0.9
|
||||
decel_lim_x: -1.0
|
||||
acc_lim_theta: 1.5
|
||||
decel_lim_x: -1.5
|
||||
decel_lim_y: -0.0
|
||||
decel_lim_theta: -1.5
|
||||
|
||||
@@ -81,9 +74,53 @@ LimitedAccelGenerator:
|
||||
|
||||
MKTAlgorithmDiffPredictiveTrajectory:
|
||||
library_path: libmkt_algorithm_diff
|
||||
avoid_obstacles: false
|
||||
xy_local_goal_tolerance: 0.01
|
||||
angle_threshold: 0.6
|
||||
xy_local_goal_tolerance: 0.02
|
||||
angle_threshold: 0.47
|
||||
index_samples: 60
|
||||
follow_step_path: true
|
||||
|
||||
# Kalman filter tuning (filters v and w commands)
|
||||
kf_q_v: 0.25
|
||||
kf_q_w: 0.8
|
||||
kf_r_v: 0.05
|
||||
kf_r_w: 0.08
|
||||
kf_p0: 0.5
|
||||
kf_filter_angular: false
|
||||
|
||||
# Lookahead
|
||||
use_velocity_scaled_lookahead_dist: true # Whether to use the velocity scaled lookahead distances or constant lookahead_distance. (default: false)
|
||||
# only when false:
|
||||
lookahead_dist: 0.5 # The lookahead distance (m) to use to find the lookahead point. (default: 0.6)
|
||||
# only when true:
|
||||
min_lookahead_dist: 0.6 # The minimum lookahead distance (m) threshold. (default: 0.3)
|
||||
max_lookahead_dist: 2.0 # The maximum lookahead distance (m) threshold. (default: 0.9)
|
||||
lookahead_time: 1.9 # The time (s) to project the velocity by, a.k.a. lookahead gain. (default: 1.5)
|
||||
min_journey_squared: 0.2 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
max_journey_squared: 0.5 # Maximum squared journey to consider for goal (default: 0.2)
|
||||
max_lateral_accel: 0.9 # Max lateral accel for speed reduction on curves (m/s^2)
|
||||
|
||||
# Rotate to heading param - onle one of use_rotate_to_heading and allow_reversing can be set to true
|
||||
use_rotate_to_heading: true # Whether to enable rotating to rough heading and goal orientation when using holonomic planners. Recommended on for all robot types that can rotate in place. (default: true)
|
||||
# only when true:
|
||||
rotate_to_heading_min_angle: 0.03 # The difference in the path orientation and the starting robot orientation (radians) to trigger a rotate in place. (default: 0.785)
|
||||
angular_decel_zone: 0.1
|
||||
|
||||
# stoped
|
||||
rot_stopped_velocity: 0.05
|
||||
trans_stopped_velocity: 0.06
|
||||
|
||||
use_final_heading_alignment: true
|
||||
final_heading_xy_tolerance: 0.1
|
||||
final_heading_angle_tolerance: 0.05
|
||||
final_heading_min_velocity: 0.05
|
||||
final_heading_kp_angular: 1.2
|
||||
final_heading_ki_angular: 0.002
|
||||
final_heading_kd_angular: 0.12
|
||||
|
||||
MKTAlgorithmDiffGoStraight:
|
||||
library_path: libmkt_algorithm_diff
|
||||
xy_local_goal_tolerance: 0.02
|
||||
angle_threshold: 0.8
|
||||
index_samples: 60
|
||||
follow_step_path: true
|
||||
|
||||
@@ -92,11 +129,12 @@ MKTAlgorithmDiffPredictiveTrajectory:
|
||||
# only when false:
|
||||
lookahead_dist: 0.5 # The lookahead distance (m) to use to find the lookahead point. (default: 0.6)
|
||||
# only when true:
|
||||
min_lookahead_dist: 1.0 # The minimum lookahead distance (m) threshold. (default: 0.3)
|
||||
min_lookahead_dist: 0.6 # The minimum lookahead distance (m) threshold. (default: 0.3)
|
||||
max_lookahead_dist: 2.0 # The maximum lookahead distance (m) threshold. (default: 0.9)
|
||||
lookahead_time: 1.6 # The time (s) to project the velocity by, a.k.a. lookahead gain. (default: 1.5)
|
||||
min_journey_squared: 0.3 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
max_journey_squared: 0.8 # Maximum squared journey to consider for goal (default: 0.2)
|
||||
lookahead_time: 2.0 # The time (s) to project the velocity by, a.k.a. lookahead gain. (default: 1.5)
|
||||
min_journey_squared: 1.0 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
max_journey_squared: 1.0 # Maximum squared journey to consider for goal (default: 0.2)
|
||||
max_lateral_accel: 0.9 # Max lateral accel for speed reduction on curves (m/s^2)
|
||||
|
||||
# Rotate to heading param - onle one of use_rotate_to_heading and allow_reversing can be set to true
|
||||
use_rotate_to_heading: true # Whether to enable rotating to rough heading and goal orientation when using holonomic planners. Recommended on for all robot types that can rotate in place. (default: true)
|
||||
@@ -105,70 +143,35 @@ MKTAlgorithmDiffPredictiveTrajectory:
|
||||
angular_decel_zone: 0.1
|
||||
|
||||
# stoped
|
||||
rot_stopped_velocity: 0.1
|
||||
trans_stopped_velocity: 0.1
|
||||
|
||||
# Regulated linear velocity scaling
|
||||
use_regulated_linear_velocity_scaling: false # Whether to use the regulated features for path curvature (e.g. slow on high curvature paths). (default: true)
|
||||
# only when true:
|
||||
regulated_linear_scaling_min_radius: 0.6 # The turning radius (m) for which the regulation features are triggered. Remember, sharper turns have smaller radii. (default: 0.9)
|
||||
regulated_linear_scaling_min_speed: 0.15 # The minimum speed (m/s) for which any of the regulated heuristics can send, to ensure process is still achievable even in high cost spaces with high curvature. Must be > 0.1. (default: 0.25)
|
||||
|
||||
# Inflation cost scaling (Limit velocity by proximity to obstacles)
|
||||
use_cost_regulated_linear_velocity_scaling: false # Whether to use the regulated features for proximity to obstacles (e.g. slow in close proximity to obstacles). (default: true)
|
||||
inflation_cost_scaling_factor: 2.0 # (default: 3.0) # must be > 0
|
||||
cost_scaling_dist: 0.2 # (default: 0.6)
|
||||
cost_scaling_gain: 2.0 # (default: 1.0)
|
||||
|
||||
MKTAlgorithmDiffGoStraight:
|
||||
library_path: libmkt_algorithm_diff
|
||||
avoid_obstacles: false
|
||||
xy_local_goal_tolerance: 0.01
|
||||
angle_threshold: 0.6
|
||||
index_samples: 60
|
||||
follow_step_path: true
|
||||
|
||||
# Lookahead
|
||||
use_velocity_scaled_lookahead_dist: true # Whether to use the velocity scaled lookahead distances or constant lookahead_distance. (default: false)
|
||||
# only when false:
|
||||
lookahead_dist: 0.5 # The lookahead distance (m) to use to find the lookahead point. (default: 0.6)
|
||||
# only when true:
|
||||
min_lookahead_dist: 0.8 # The minimum lookahead distance (m) threshold. (default: 0.3)
|
||||
max_lookahead_dist: 1.5 # The maximum lookahead distance (m) threshold. (default: 0.9)
|
||||
lookahead_time: 2.5 # The time (s) to project the velocity by, a.k.a. lookahead gain. (default: 1.5)
|
||||
min_journey_squared: 0.3 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
max_journey_squared: 0.6 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
|
||||
# Rotate to heading param - onle one of use_rotate_to_heading and allow_reversing can be set to true
|
||||
use_rotate_to_heading: true # Whether to enable rotating to rough heading and goal orientation when using holonomic planners. Recommended on for all robot types that can rotate in place. (default: true)
|
||||
# only when true:
|
||||
rotate_to_heading_min_angle: 0.35 # The difference in the path orientation and the starting robot orientation (radians) to trigger a rotate in place. (default: 0.785)
|
||||
|
||||
# stoped
|
||||
rot_stopped_velocity: 0.03
|
||||
rot_stopped_velocity: 0.05
|
||||
trans_stopped_velocity: 0.06
|
||||
|
||||
use_regulated_linear_velocity_scaling: false
|
||||
use_cost_regulated_linear_velocity_scaling: false
|
||||
use_final_heading_alignment: true
|
||||
final_heading_xy_tolerance: 0.1
|
||||
final_heading_angle_tolerance: 0.05
|
||||
final_heading_min_velocity: 0.05
|
||||
final_heading_kp_angular: 1.5
|
||||
final_heading_ki_angular: 0.2
|
||||
final_heading_kd_angular: 0.05
|
||||
|
||||
MKTAlgorithmDiffRotateToGoal:
|
||||
library_path: libmkt_algorithm_diff
|
||||
avoid_obstacles: false
|
||||
xy_local_goal_tolerance: 0.01
|
||||
angle_threshold: 0.6
|
||||
xy_local_goal_tolerance: 0.02
|
||||
angle_threshold: 0.47
|
||||
index_samples: 60
|
||||
follow_step_path: true
|
||||
|
||||
# Lookahead
|
||||
use_velocity_scaled_lookahead_dist: true # Whether to use the velocity scaled lookahead distances or constant lookahead_distance. (default: false)
|
||||
# only when false:
|
||||
lookahead_dist: 0.325 # The lookahead distance (m) to use to find the lookahead point. (default: 0.6)
|
||||
lookahead_dist: 0.5 # The lookahead distance (m) to use to find the lookahead point. (default: 0.6)
|
||||
# only when true:
|
||||
min_lookahead_dist: 0.8 # The minimum lookahead distance (m) threshold. (default: 0.3)
|
||||
max_lookahead_dist: 1.5 # The maximum lookahead distance (m) threshold. (default: 0.9)
|
||||
lookahead_time: 1.8 # The time (s) to project the velocity by, a.k.a. lookahead gain. (default: 1.5)
|
||||
min_journey_squared: 0.3 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
max_journey_squared: 0.6 # Maximum squared journey to consider for goal (default: 0.2)
|
||||
min_lookahead_dist: 0.6 # The minimum lookahead distance (m) threshold. (default: 0.3)
|
||||
max_lookahead_dist: 2.0 # The maximum lookahead distance (m) threshold. (default: 0.9)
|
||||
lookahead_time: 1.9 # The time (s) to project the velocity by, a.k.a. lookahead gain. (default: 1.5)
|
||||
min_journey_squared: 0.2 # Minimum squared journey to consider for goal (default: 0.2)
|
||||
max_journey_squared: 0.8 # Maximum squared journey to consider for goal (default: 0.2)
|
||||
max_lateral_accel: 0.9 # Max lateral accel for speed reduction on curves (m/s^2)
|
||||
|
||||
# Rotate to heading param - onle one of use_rotate_to_heading and allow_reversing can be set to true
|
||||
use_rotate_to_heading: true # Whether to enable rotating to rough heading and goal orientation when using holonomic planners. Recommended on for all robot types that can rotate in place. (default: true)
|
||||
@@ -177,24 +180,20 @@ MKTAlgorithmDiffRotateToGoal:
|
||||
angular_decel_zone: 0.1
|
||||
|
||||
# stoped
|
||||
rot_stopped_velocity: 0.03
|
||||
rot_stopped_velocity: 0.05
|
||||
trans_stopped_velocity: 0.06
|
||||
|
||||
# Regulated linear velocity scaling
|
||||
use_regulated_linear_velocity_scaling: false # Whether to use the regulated features for path curvature (e.g. slow on high curvature paths). (default: true)
|
||||
# only when true:
|
||||
regulated_linear_scaling_min_radius: 0.6 # The turning radius (m) for which the regulation features are triggered. Remember, sharper turns have smaller radii. (default: 0.9)
|
||||
regulated_linear_scaling_min_speed: 0.05 # The minimum speed (m/s) for which any of the regulated heuristics can send, to ensure process is still achievable even in high cost spaces with high curvature. Must be > 0.1. (default: 0.25)
|
||||
|
||||
# Inflation cost scaling (Limit velocity by proximity to obstacles)
|
||||
use_cost_regulated_linear_velocity_scaling: false # Whether to use the regulated features for proximity to obstacles (e.g. slow in close proximity to obstacles). (default: true)
|
||||
inflation_cost_scaling_factor: 2.0 # (default: 3.0) # must be > 0
|
||||
cost_scaling_dist: 0.2 # (default: 0.6)
|
||||
cost_scaling_gain: 2.0 # (default: 1.0)
|
||||
|
||||
use_final_heading_alignment: true
|
||||
final_heading_xy_tolerance: 0.1
|
||||
final_heading_angle_tolerance: 0.05
|
||||
final_heading_min_velocity: 0.05
|
||||
final_heading_kp_angular: 2.0
|
||||
near_goal_heading_kp: 1.5
|
||||
near_goal_heading_ki: 0.0
|
||||
near_goal_heading_kd: 0.0
|
||||
|
||||
GoalChecker:
|
||||
library_path: libmkt_plugins_goal_checker
|
||||
|
||||
SimpleGoalChecker:
|
||||
library_path: libmkt_plugins_simple_goal_checker
|
||||
library_path: libmkt_plugins_goal_checker
|
||||
@@ -1,4 +1,3 @@
|
||||
base_global_planner: TwoPointsPlanner
|
||||
TwoPointsPlanner:
|
||||
library_path: libtwo_points_planner
|
||||
lethal_obstacle: 20
|
||||
@@ -1,360 +0,0 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Runtime.CompilerServices;
|
||||
|
||||
namespace NavigationExample
|
||||
{
|
||||
/// <summary>
|
||||
/// C# P/Invoke wrapper for Navigation C API
|
||||
/// </summary>
|
||||
public class NavigationAPI
|
||||
{
|
||||
private const string DllName = "libnav_c_api.so"; // Linux
|
||||
// For Windows: "nav_c_api.dll"
|
||||
// For macOS: "libnav_c_api.dylib"
|
||||
|
||||
// ============================================================================
|
||||
// Enums
|
||||
// ============================================================================
|
||||
public enum NavigationState
|
||||
{
|
||||
Pending = 0,
|
||||
Active = 1,
|
||||
Preempted = 2,
|
||||
Succeeded = 3,
|
||||
Aborted = 4,
|
||||
Rejected = 5,
|
||||
Preempting = 6,
|
||||
Recalling = 7,
|
||||
Recalled = 8,
|
||||
Lost = 9,
|
||||
Planning = 10,
|
||||
Controlling = 11,
|
||||
Clearing = 12,
|
||||
Paused = 13
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
// Structures
|
||||
// ============================================================================
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Point
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose2D
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double theta;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Quaternion
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
public double w;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Position
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose
|
||||
{
|
||||
public Position position;
|
||||
public Quaternion orientation;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Header
|
||||
{
|
||||
public uint seq;
|
||||
public long sec;
|
||||
public uint nsec;
|
||||
public IntPtr frame_id; // char*
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PoseStamped
|
||||
{
|
||||
public Header header;
|
||||
public Pose pose;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Vector3
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NavFeedback
|
||||
{
|
||||
public NavigationState navigation_state;
|
||||
public IntPtr feed_back_str; // char*
|
||||
public Pose2D current_pose;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool goal_checked;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool is_ready;
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
// String Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void nav_c_api_free_string(IntPtr str);
|
||||
|
||||
// ============================================================================
|
||||
// State Conversion
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
public static extern IntPtr navigation_state_to_string(NavigationState state);
|
||||
|
||||
// ============================================================================
|
||||
// Helper Functions
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_offset_goal_2d(
|
||||
double pose_x, double pose_y, double pose_theta,
|
||||
string frame_id, double offset_distance,
|
||||
ref PoseStamped out_goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_offset_goal_stamped(
|
||||
ref PoseStamped in_pose, double offset_distance,
|
||||
ref PoseStamped out_goal);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Handle Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern IntPtr navigation_create();
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_destroy(IntPtr handle);
|
||||
|
||||
// ============================================================================
|
||||
// TF Listener Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern IntPtr tf_listener_create();
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void tf_listener_destroy(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf_listener_set_static_transform(
|
||||
IntPtr tf_handle,
|
||||
string parent_frame,
|
||||
string child_frame,
|
||||
double x, double y, double z,
|
||||
double qx, double qy, double qz, double qw);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Interface Methods
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_initialize(IntPtr handle, IntPtr tf_handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_robot_footprint(
|
||||
IntPtr handle, Point[] points, UIntPtr point_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_to(
|
||||
IntPtr handle, ref PoseStamped goal,
|
||||
double xy_goal_tolerance, double yaw_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_dock_to(
|
||||
IntPtr handle, string marker, ref PoseStamped goal,
|
||||
double xy_goal_tolerance, double yaw_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_straight_to(
|
||||
IntPtr handle, ref PoseStamped goal, double xy_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_rotate_to(
|
||||
IntPtr handle, ref PoseStamped goal, double yaw_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_pause(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_resume(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_cancel(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_twist_linear(
|
||||
IntPtr handle, double linear_x, double linear_y, double linear_z);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_twist_angular(
|
||||
IntPtr handle, double angular_x, double angular_y, double angular_z);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_pose_stamped(
|
||||
IntPtr handle, ref PoseStamped out_pose);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_pose_2d(
|
||||
IntPtr handle, ref Pose2D out_pose);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_feedback(
|
||||
IntPtr handle, ref NavFeedback out_feedback);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_free_feedback(ref NavFeedback feedback);
|
||||
|
||||
// ============================================================================
|
||||
// Helper Methods for String Conversion
|
||||
// ============================================================================
|
||||
public static string MarshalString(IntPtr ptr)
|
||||
{
|
||||
if (ptr == IntPtr.Zero)
|
||||
return string.Empty;
|
||||
return Marshal.PtrToStringAnsi(ptr);
|
||||
}
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
// Example Usage
|
||||
// ============================================================================
|
||||
class Program
|
||||
{
|
||||
// Helper method để hiển thị file và line number tự động
|
||||
static void LogError(string message,
|
||||
[CallerFilePath] string filePath = "",
|
||||
[CallerLineNumber] int lineNumber = 0,
|
||||
[CallerMemberName] string memberName = "")
|
||||
{
|
||||
// Lấy tên file từ đường dẫn đầy đủ
|
||||
string fileName = System.IO.Path.GetFileName(filePath);
|
||||
Console.WriteLine($"[{fileName}:{lineNumber}] {memberName}: {message}");
|
||||
}
|
||||
|
||||
static void Main(string[] args)
|
||||
{
|
||||
// Create TF listener
|
||||
IntPtr tfHandle = NavigationAPI.tf_listener_create();
|
||||
if (tfHandle == IntPtr.Zero)
|
||||
{
|
||||
LogError("Failed to create TF listener");
|
||||
return;
|
||||
}
|
||||
|
||||
// Inject a static TF so costmap can immediately canTransform(map <-> base_link).
|
||||
// If you already publish TF from localization/odometry, you can remove this call.
|
||||
if (!NavigationAPI.tf_listener_set_static_transform(tfHandle, "map", "odom",
|
||||
0, 0, 0,
|
||||
0, 0, 0, 1))
|
||||
{
|
||||
LogError("Failed to inject static TF map -> odom");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!NavigationAPI.tf_listener_set_static_transform(tfHandle, "odom", "base_footprint",
|
||||
0, 0, 0,
|
||||
0, 0, 0, 1))
|
||||
{
|
||||
LogError("Failed to inject static TF map -> base_link");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!NavigationAPI.tf_listener_set_static_transform(tfHandle, "base_footprint", "base_link",
|
||||
0, 0, 0,
|
||||
0, 0, 0, 1))
|
||||
{
|
||||
LogError("Failed to inject static TF map -> base_link");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
// Create navigation instance
|
||||
IntPtr navHandle = NavigationAPI.navigation_create();
|
||||
if (navHandle == IntPtr.Zero)
|
||||
{
|
||||
LogError("Failed to create navigation instance");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
// Initialize navigation
|
||||
if (!NavigationAPI.navigation_initialize(navHandle, tfHandle))
|
||||
{
|
||||
LogError("Failed to initialize navigation");
|
||||
NavigationAPI.navigation_destroy(navHandle);
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
// Set robot footprint
|
||||
NavigationAPI.Point[] footprint = new NavigationAPI.Point[]
|
||||
{
|
||||
new NavigationAPI.Point { x = 0.3, y = -0.2, z = 0.0 },
|
||||
new NavigationAPI.Point { x = 0.3, y = 0.2, z = 0.0 },
|
||||
new NavigationAPI.Point { x = -0.3, y = 0.2, z = 0.0 },
|
||||
new NavigationAPI.Point { x = -0.3, y = -0.2, z = 0.0 }
|
||||
};
|
||||
NavigationAPI.navigation_set_robot_footprint(navHandle, footprint, new UIntPtr((uint)footprint.Length));
|
||||
|
||||
// Get robot pose
|
||||
NavigationAPI.Pose2D robotPose = new NavigationAPI.Pose2D();
|
||||
if (NavigationAPI.navigation_get_robot_pose_2d(navHandle, ref robotPose))
|
||||
{
|
||||
Console.WriteLine($"Robot pose: x={robotPose.x}, y={robotPose.y}, theta={robotPose.theta}");
|
||||
}
|
||||
|
||||
// Get navigation feedback
|
||||
NavigationAPI.NavFeedback feedback = new NavigationAPI.NavFeedback();
|
||||
if (NavigationAPI.navigation_get_feedback(navHandle, ref feedback))
|
||||
{
|
||||
string stateStr = NavigationAPI.MarshalString(
|
||||
NavigationAPI.navigation_state_to_string(feedback.navigation_state));
|
||||
string feedbackStr = NavigationAPI.MarshalString(feedback.feed_back_str);
|
||||
Console.WriteLine($"State: {stateStr}, Feedback: {feedbackStr}");
|
||||
NavigationAPI.navigation_free_feedback(ref feedback);
|
||||
}
|
||||
|
||||
// Cleanup
|
||||
NavigationAPI.navigation_destroy(navHandle);
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
299
examples/NavigationExample/NavigationAPI.cs
Normal file
299
examples/NavigationExample/NavigationAPI.cs
Normal file
@@ -0,0 +1,299 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
using NavigationExample;
|
||||
|
||||
namespace NavigationExample
|
||||
{
|
||||
/// <summary>
|
||||
/// C# P/Invoke wrapper for Navigation C API
|
||||
/// </summary>
|
||||
public class NavigationAPI
|
||||
{
|
||||
private const string DllName = "/usr/local/lib/libnav_c_api.so"; // Linux
|
||||
// For Windows: "nav_c_api.dll"
|
||||
// For macOS: "libnav_c_api.dylib"
|
||||
|
||||
// ============================================================================
|
||||
// Enums
|
||||
// ============================================================================
|
||||
public enum NavigationState
|
||||
{
|
||||
Pending = 0,
|
||||
Active = 1,
|
||||
Preempted = 2,
|
||||
Succeeded = 3,
|
||||
Aborted = 4,
|
||||
Rejected = 5,
|
||||
Preempting = 6,
|
||||
Recalling = 7,
|
||||
Recalled = 8,
|
||||
Lost = 9,
|
||||
Planning = 10,
|
||||
Controlling = 11,
|
||||
Clearing = 12,
|
||||
Paused = 13
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NavFeedback
|
||||
{
|
||||
public NavigationState navigation_state;
|
||||
public IntPtr feed_back_str; // char*; free with nav_c_api_free_string
|
||||
public Pose2D current_pose;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool goal_checked;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool is_ready;
|
||||
}
|
||||
|
||||
|
||||
/// <summary>Planner data output (plan, costmap, footprint).</summary>
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PlannerDataOutput
|
||||
{
|
||||
public Path2D plan;
|
||||
public OccupancyGrid costmap;
|
||||
public OccupancyGridUpdate costmap_update;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool is_costmap_updated;
|
||||
public PolygonStamped footprint;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NavigationHandle
|
||||
{
|
||||
public IntPtr ptr;
|
||||
}
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
public static extern Header header_create(string frame_id);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
public static extern Header header_set_data(
|
||||
uint seq,
|
||||
uint sec,
|
||||
uint nsec,
|
||||
string frame_id);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern Time time_create();
|
||||
|
||||
/// <summary>Free a string allocated by the API (strdup).</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void nav_c_api_free_string(IntPtr str);
|
||||
|
||||
/// <summary>Convert NavigationState to string; caller must free with nav_c_api_free_string.</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
public static extern IntPtr navigation_state_to_string(NavigationState state);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_feedback(NavigationHandle handle, ref NavFeedback out_feedback);
|
||||
|
||||
|
||||
/// <summary>Helper: copy unmanaged char* to managed string; does not free the pointer.</summary>
|
||||
public static string MarshalString(IntPtr p)
|
||||
{
|
||||
if (p == IntPtr.Zero) return string.Empty;
|
||||
return Marshal.PtrToStringAnsi(p) ?? string.Empty;
|
||||
}
|
||||
|
||||
/// <summary>Free strings inside NavFeedback (feed_back_str). Call after navigation_get_feedback when done.</summary>
|
||||
public static void navigation_free_feedback(ref NavFeedback feedback)
|
||||
{
|
||||
if (feedback.feed_back_str != IntPtr.Zero)
|
||||
{
|
||||
nav_c_api_free_string(feedback.feed_back_str);
|
||||
feedback.feed_back_str = IntPtr.Zero;
|
||||
}
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Handle Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern NavigationHandle navigation_create();
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_destroy(NavigationHandle handle);
|
||||
|
||||
/// <summary>Initialize navigation using an existing tf3 buffer (from libtf3). Caller owns the buffer and must call tf3_buffer_destroy after navigation_destroy.</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_initialize(NavigationHandle handle, IntPtr tf3_buffer);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_robot_footprint(NavigationHandle handle, Point[] points, UIntPtr point_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_footprint(NavigationHandle handle, ref Point[] out_points, ref UIntPtr out_count);
|
||||
|
||||
/// <summary>Send a goal for the robot to navigate to (global frame).</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_to(NavigationHandle handle, PoseStamped goal);
|
||||
|
||||
/// <summary>Navigate using an Order message (graph nodes/edges). Order must be built or obtained from native side; call order_free when done if it was allocated by native.</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_to_order(NavigationHandle handle, Order order, PoseStamped goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_to_nodes_edges(NavigationHandle handle, IntPtr nodes, UIntPtr node_count, IntPtr edges, UIntPtr edge_count, PoseStamped goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_dock_to(NavigationHandle handle, string marker, PoseStamped goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_dock_to_order(NavigationHandle handle, Order order, string marker, PoseStamped goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_dock_to_nodes_edges(NavigationHandle handle, string marker, Node[] nodes, Edge[] edges, PoseStamped goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_straight_to(NavigationHandle handle, double distance);
|
||||
|
||||
/// <summary>Rotate in place to align with target orientation (radians).</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_rotate_to(NavigationHandle handle, double goal_yaw);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_pause(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_resume(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_cancel(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_twist_linear(NavigationHandle handle, double linear_x, double linear_y, double linear_z);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_twist_angular(NavigationHandle handle, double angular_x, double angular_y, double angular_z);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_pose_stamped(NavigationHandle handle, ref PoseStamped out_pose);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_pose_2d(NavigationHandle handle, ref Pose2D out_pose);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_twist(NavigationHandle handle, ref Twist2DStamped out_twist);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Data Management
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_add_laser_scan(NavigationHandle handle, string laser_scan_name, LaserScan laser_scan);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_add_odometry(NavigationHandle handle, string odometry_name, Odometry odometry);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_add_static_map(NavigationHandle handle, string map_name, OccupancyGrid occupancy_grid);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_static_map(NavigationHandle handle, string map_name, ref OccupancyGrid occupancy_grid);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_add_point_cloud(NavigationHandle handle, string point_cloud_name, PointCloud point_cloud);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_add_point_cloud2(NavigationHandle handle, string point_cloud2_name, PointCloud2 point_cloud2);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_laser_scan(NavigationHandle handle, string laser_scan_name, ref LaserScan out_scan);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_point_cloud(NavigationHandle handle, string point_cloud_name, ref PointCloud out_cloud);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_point_cloud2(NavigationHandle handle, string point_cloud2_name, ref PointCloud2 out_cloud);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_static_map(NavigationHandle handle, string map_name);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_laser_scan(NavigationHandle handle, string laser_scan_name);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_point_cloud(NavigationHandle handle, string point_cloud_name);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_point_cloud2(NavigationHandle handle, string point_cloud2_name);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_all_static_maps(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_all_laser_scans(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_all_point_clouds(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_all_point_cloud2s(NavigationHandle handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_remove_all_data(NavigationHandle handle);
|
||||
|
||||
/// <summary>Get all static maps. out_maps must be pre-allocated; use navigation_get_all_static_maps_count or similar to get count first if needed.</summary>
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_all_static_maps(NavigationHandle handle, [Out] NamedOccupancyGrid[] out_maps, ref UIntPtr out_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_all_laser_scans(NavigationHandle handle, [Out] NamedLaserScan[] out_scans, ref UIntPtr out_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_all_point_clouds(NavigationHandle handle, [Out] NamedPointCloud[] out_clouds, ref UIntPtr out_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_all_point_cloud2s(NavigationHandle handle, [Out] NamedPointCloud2[] out_clouds, ref UIntPtr out_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_global_data(NavigationHandle handle, ref PlannerDataOutput out_data);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_local_data(NavigationHandle handle, ref PlannerDataOutput out_data);
|
||||
}
|
||||
}
|
||||
@@ -1,10 +1,12 @@
|
||||
<Project Sdk="Microsoft.NET.Sdk">
|
||||
<PropertyGroup>
|
||||
<OutputType>Exe</OutputType>
|
||||
<TargetFramework>net6.0</TargetFramework>
|
||||
<RuntimeIdentifier>linux-x64</RuntimeIdentifier>
|
||||
<TargetFramework>net10.0</TargetFramework>
|
||||
<AllowUnsafeBlocks>true</AllowUnsafeBlocks>
|
||||
</PropertyGroup>
|
||||
<ItemGroup>
|
||||
<PackageReference Include="SixLabors.ImageSharp" Version="3.1.7" />
|
||||
</ItemGroup>
|
||||
<ItemGroup>
|
||||
<None Include="libnav_c_api.so">
|
||||
<CopyToOutputDirectory>Always</CopyToOutputDirectory>
|
||||
|
||||
@@ -1,253 +1,25 @@
|
||||
using System;
|
||||
using System.Globalization;
|
||||
using System.IO;
|
||||
using System.Runtime.InteropServices;
|
||||
using System.Runtime.CompilerServices;
|
||||
using System.Text.RegularExpressions;
|
||||
using SixLabors.ImageSharp;
|
||||
using SixLabors.ImageSharp.PixelFormats;
|
||||
using NavigationExample;
|
||||
|
||||
|
||||
namespace NavigationExample
|
||||
{
|
||||
/// <summary>
|
||||
/// C# P/Invoke wrapper for Navigation C API
|
||||
/// </summary>
|
||||
public class NavigationAPI
|
||||
/// <summary>Thông tin map đọc từ file YAML (maze.yaml).</summary>
|
||||
public struct MazeMapConfig
|
||||
{
|
||||
private const string DllName = "libnav_c_api.so"; // Linux
|
||||
// For Windows: "nav_c_api.dll"
|
||||
// For macOS: "libnav_c_api.dylib"
|
||||
|
||||
// ============================================================================
|
||||
// Enums
|
||||
// ============================================================================
|
||||
public enum NavigationState
|
||||
{
|
||||
Pending = 0,
|
||||
Active = 1,
|
||||
Preempted = 2,
|
||||
Succeeded = 3,
|
||||
Aborted = 4,
|
||||
Rejected = 5,
|
||||
Preempting = 6,
|
||||
Recalling = 7,
|
||||
Recalled = 8,
|
||||
Lost = 9,
|
||||
Planning = 10,
|
||||
Controlling = 11,
|
||||
Clearing = 12,
|
||||
Paused = 13
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
// Structures
|
||||
// ============================================================================
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Point
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose2D
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double theta;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Quaternion
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
public double w;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Position
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose
|
||||
{
|
||||
public Position position;
|
||||
public Quaternion orientation;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Header
|
||||
{
|
||||
public uint seq;
|
||||
public long sec;
|
||||
public uint nsec;
|
||||
public IntPtr frame_id; // char*
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PoseStamped
|
||||
{
|
||||
public Header header;
|
||||
public Pose pose;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Vector3
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NavFeedback
|
||||
{
|
||||
public NavigationState navigation_state;
|
||||
public IntPtr feed_back_str; // char*
|
||||
public Pose2D current_pose;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool goal_checked;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool is_ready;
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
// String Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void nav_c_api_free_string(IntPtr str);
|
||||
|
||||
// ============================================================================
|
||||
// State Conversion
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
public static extern IntPtr navigation_state_to_string(NavigationState state);
|
||||
|
||||
// ============================================================================
|
||||
// Helper Functions
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_offset_goal_2d(
|
||||
double pose_x, double pose_y, double pose_theta,
|
||||
string frame_id, double offset_distance,
|
||||
ref PoseStamped out_goal);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_offset_goal_stamped(
|
||||
ref PoseStamped in_pose, double offset_distance,
|
||||
ref PoseStamped out_goal);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Handle Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern IntPtr navigation_create();
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_destroy(IntPtr handle);
|
||||
|
||||
// ============================================================================
|
||||
// TF Listener Management
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern IntPtr tf_listener_create();
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void tf_listener_destroy(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf_listener_set_static_transform(
|
||||
IntPtr tf_handle,
|
||||
string parent_frame,
|
||||
string child_frame,
|
||||
double x, double y, double z,
|
||||
double qx, double qy, double qz, double qw);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Interface Methods
|
||||
// ============================================================================
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_initialize(IntPtr handle, IntPtr tf_handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_robot_footprint(
|
||||
IntPtr handle, Point[] points, UIntPtr point_count);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_to(
|
||||
IntPtr handle, ref PoseStamped goal,
|
||||
double xy_goal_tolerance, double yaw_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_dock_to(
|
||||
IntPtr handle, string marker, ref PoseStamped goal,
|
||||
double xy_goal_tolerance, double yaw_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_move_straight_to(
|
||||
IntPtr handle, ref PoseStamped goal, double xy_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_rotate_to(
|
||||
IntPtr handle, ref PoseStamped goal, double yaw_goal_tolerance);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_pause(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_resume(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_cancel(IntPtr handle);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_twist_linear(
|
||||
IntPtr handle, double linear_x, double linear_y, double linear_z);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_set_twist_angular(
|
||||
IntPtr handle, double angular_x, double angular_y, double angular_z);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_pose_stamped(
|
||||
IntPtr handle, ref PoseStamped out_pose);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_robot_pose_2d(
|
||||
IntPtr handle, ref Pose2D out_pose);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool navigation_get_feedback(
|
||||
IntPtr handle, ref NavFeedback out_feedback);
|
||||
|
||||
[DllImport(DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void navigation_free_feedback(ref NavFeedback feedback);
|
||||
|
||||
// ============================================================================
|
||||
// Helper Methods for String Conversion
|
||||
// ============================================================================
|
||||
public static string MarshalString(IntPtr ptr)
|
||||
{
|
||||
if (ptr == IntPtr.Zero)
|
||||
return string.Empty;
|
||||
return Marshal.PtrToStringAnsi(ptr);
|
||||
}
|
||||
public string ImagePath; // đường dẫn đầy đủ tới file ảnh
|
||||
public float Resolution;
|
||||
public double OriginX, OriginY, OriginZ;
|
||||
public int Negate; // 0 hoặc 1
|
||||
public double OccupiedThresh;
|
||||
public double FreeThresh;
|
||||
}
|
||||
|
||||
// ============================================================================
|
||||
@@ -255,6 +27,105 @@ namespace NavigationExample
|
||||
// ============================================================================
|
||||
class Program
|
||||
{
|
||||
/// <summary>
|
||||
/// Đọc file maze.yaml (image, resolution, origin, negate, occupied_thresh, free_thresh).
|
||||
/// ImagePath được resolve tuyệt đối theo thư mục chứa file yaml.
|
||||
/// </summary>
|
||||
static bool TryLoadMazeYaml(string yamlPath, out MazeMapConfig config)
|
||||
{
|
||||
config = default;
|
||||
if (string.IsNullOrEmpty(yamlPath) || !File.Exists(yamlPath))
|
||||
return false;
|
||||
string dir = Path.GetDirectoryName(Path.GetFullPath(yamlPath)) ?? "";
|
||||
try
|
||||
{
|
||||
string[] lines = File.ReadAllLines(yamlPath);
|
||||
foreach (string line in lines)
|
||||
{
|
||||
string trimmed = line.Trim();
|
||||
if (trimmed.Length == 0 || trimmed.StartsWith("#")) continue;
|
||||
int colon = trimmed.IndexOf(':');
|
||||
if (colon <= 0) continue;
|
||||
string key = trimmed.Substring(0, colon).Trim();
|
||||
string value = trimmed.Substring(colon + 1).Trim();
|
||||
if (key == "image")
|
||||
config.ImagePath = Path.Combine(dir, value);
|
||||
else if (key == "resolution" && float.TryParse(value, NumberStyles.Float, CultureInfo.InvariantCulture, out float res))
|
||||
config.Resolution = res;
|
||||
else if (key == "origin")
|
||||
{
|
||||
var m = Regex.Match(value, @"\[\s*([-\d.]+\s*),\s*([-\d.]+\s*),\s*([-\d.]+)\s*\]");
|
||||
if (m.Success)
|
||||
{
|
||||
config.OriginX = double.Parse(m.Groups[1].Value, CultureInfo.InvariantCulture);
|
||||
config.OriginY = double.Parse(m.Groups[2].Value, CultureInfo.InvariantCulture);
|
||||
config.OriginZ = double.Parse(m.Groups[3].Value, CultureInfo.InvariantCulture);
|
||||
}
|
||||
}
|
||||
else if (key == "negate" && int.TryParse(value, out int neg))
|
||||
config.Negate = neg;
|
||||
else if (key == "occupied_thresh" && double.TryParse(value, NumberStyles.Float, CultureInfo.InvariantCulture, out double ot))
|
||||
config.OccupiedThresh = ot;
|
||||
else if (key == "free_thresh" && double.TryParse(value, NumberStyles.Float, CultureInfo.InvariantCulture, out double ft))
|
||||
config.FreeThresh = ft;
|
||||
}
|
||||
return !string.IsNullOrEmpty(config.ImagePath);
|
||||
}
|
||||
catch
|
||||
{
|
||||
return false;
|
||||
}
|
||||
}
|
||||
|
||||
/// <summary>
|
||||
/// Đọc file ảnh PNG và chuyển pixel sang byte[] occupancy (0=free, 100=occupied, 255=unknown).
|
||||
/// Dùng negate, occupied_thresh, free_thresh từ maze.yaml nếu cung cấp.
|
||||
/// </summary>
|
||||
static byte[] LoadMazePixelsAsOccupancy(string imagePath, out int width, out int height,
|
||||
int negate = 0, double occupiedThresh = 0.65, double freeThresh = 0.196)
|
||||
{
|
||||
width = 0;
|
||||
height = 0;
|
||||
if (string.IsNullOrEmpty(imagePath) || !File.Exists(imagePath))
|
||||
{
|
||||
LogError($"File not found: {imagePath}");
|
||||
return null;
|
||||
}
|
||||
try
|
||||
{
|
||||
using var image = Image.Load<Rgba32>(imagePath);
|
||||
int w = image.Width;
|
||||
int h = image.Height;
|
||||
width = w;
|
||||
height = h;
|
||||
byte[] data = new byte[w * h];
|
||||
image.ProcessPixelRows(accessor =>
|
||||
{
|
||||
for (int y = 0; y < accessor.Height; y++)
|
||||
{
|
||||
Span<Rgba32> row = accessor.GetRowSpan(y);
|
||||
for (int x = 0; x < row.Length; x++)
|
||||
{
|
||||
ref readonly Rgba32 p = ref row[x];
|
||||
double gray = (p.R + p.G + p.B) / 255.0 / 3.0;
|
||||
if (negate != 0) gray = 1.0 - gray;
|
||||
byte occ;
|
||||
if (gray <= freeThresh) occ = 0;
|
||||
else if (gray >= occupiedThresh) occ = 100;
|
||||
else occ = 255; // unknown
|
||||
data[y * w + x] = occ;
|
||||
}
|
||||
}
|
||||
});
|
||||
return data;
|
||||
}
|
||||
catch (Exception ex)
|
||||
{
|
||||
LogError($"Load image failed: {ex.Message}");
|
||||
return null;
|
||||
}
|
||||
}
|
||||
|
||||
// Helper method để hiển thị file và line number tự động
|
||||
static void LogError(string message,
|
||||
[CallerFilePath] string filePath = "",
|
||||
@@ -268,93 +139,359 @@ namespace NavigationExample
|
||||
|
||||
static void Main(string[] args)
|
||||
{
|
||||
// Create TF listener
|
||||
IntPtr tfHandle = NavigationAPI.tf_listener_create();
|
||||
if (tfHandle == IntPtr.Zero)
|
||||
// Create tf3 buffer (replaces TF listener; used for all static transforms and navigation init)
|
||||
IntPtr tf3Buffer = TF3API.tf3_buffer_create(10);
|
||||
if (tf3Buffer == IntPtr.Zero)
|
||||
{
|
||||
LogError("Failed to create TF listener");
|
||||
LogError("Failed to create tf3 buffer (libtf3.so may be missing)");
|
||||
return;
|
||||
}
|
||||
Console.WriteLine($"[NavigationExample] TF3 buffer created, handle = 0x{tf3Buffer.ToInt64():X16}");
|
||||
string version = Marshal.PtrToStringAnsi(TF3API.tf3_get_version()) ?? "?";
|
||||
Console.WriteLine($"[TF3] {version}");
|
||||
|
||||
// Inject static transforms: map -> odom -> base_footprint -> base_link
|
||||
var tMapOdom = TF3API.CreateStaticTransform("map", "odom", 0, 0, 0, 0, 0, 0, 1);
|
||||
var tOdomFoot = TF3API.CreateStaticTransform("odom", "base_footprint", 0, 0, 0, 0, 0, 0, 1);
|
||||
var tFootLink = TF3API.CreateStaticTransform("base_footprint", "base_link", 0, 0, 0, 0, 0, 0, 1);
|
||||
if (!TF3API.tf3_set_transform(tf3Buffer, ref tMapOdom, "NavigationExample", true) ||
|
||||
!TF3API.tf3_set_transform(tf3Buffer, ref tOdomFoot, "NavigationExample", true) ||
|
||||
!TF3API.tf3_set_transform(tf3Buffer, ref tFootLink, "NavigationExample", true))
|
||||
{
|
||||
LogError("Failed to set static TF");
|
||||
TF3API.tf3_buffer_destroy(tf3Buffer);
|
||||
return;
|
||||
}
|
||||
|
||||
// Inject a static TF so costmap can immediately canTransform(map <-> base_link).
|
||||
// If you already publish TF from localization/odometry, you can remove this call.
|
||||
if (!NavigationAPI.tf_listener_set_static_transform(tfHandle, "map", "odom",
|
||||
0, 0, 0,
|
||||
0, 0, 0, 1))
|
||||
{
|
||||
LogError("Failed to inject static TF map -> odom");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!NavigationAPI.tf_listener_set_static_transform(tfHandle, "odom", "base_footprint",
|
||||
0, 0, 0,
|
||||
0, 0, 0, 1))
|
||||
{
|
||||
LogError("Failed to inject static TF map -> base_link");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
if (!NavigationAPI.tf_listener_set_static_transform(tfHandle, "base_footprint", "base_link",
|
||||
0, 0, 0,
|
||||
0, 0, 0, 1))
|
||||
{
|
||||
LogError("Failed to inject static TF map -> base_link");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
return;
|
||||
}
|
||||
|
||||
// Create navigation instance
|
||||
IntPtr navHandle = NavigationAPI.navigation_create();
|
||||
if (navHandle == IntPtr.Zero)
|
||||
// Create navigation instance and initialize with tf3 buffer
|
||||
NavigationAPI.NavigationHandle navHandle = NavigationAPI.navigation_create();
|
||||
if (navHandle.ptr == IntPtr.Zero)
|
||||
{
|
||||
LogError("Failed to create navigation instance");
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
TF3API.tf3_buffer_destroy(tf3Buffer);
|
||||
return;
|
||||
}
|
||||
|
||||
// Initialize navigation
|
||||
if (!NavigationAPI.navigation_initialize(navHandle, tfHandle))
|
||||
if (!NavigationAPI.navigation_initialize(navHandle, tf3Buffer))
|
||||
{
|
||||
LogError("Failed to initialize navigation");
|
||||
LogError("Failed to initialize navigation with tf3 buffer");
|
||||
NavigationAPI.navigation_destroy(navHandle);
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
TF3API.tf3_buffer_destroy(tf3Buffer);
|
||||
return;
|
||||
}
|
||||
|
||||
while (true)
|
||||
{
|
||||
NavigationAPI.NavFeedback feedback = new NavigationAPI.NavFeedback();
|
||||
if (NavigationAPI.navigation_get_feedback(navHandle, ref feedback))
|
||||
{
|
||||
if (feedback.is_ready)
|
||||
{
|
||||
Console.WriteLine("Navigation is ready");
|
||||
break;
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("Navigation is not ready");
|
||||
}
|
||||
}
|
||||
System.Threading.Thread.Sleep(100);
|
||||
}
|
||||
Console.WriteLine("[NavigationExample] Navigation initialized successfully");
|
||||
|
||||
|
||||
// Set robot footprint
|
||||
NavigationAPI.Point[] footprint = new NavigationAPI.Point[]
|
||||
Point[] footprint = new Point[]
|
||||
{
|
||||
new NavigationAPI.Point { x = 0.3, y = -0.2, z = 0.0 },
|
||||
new NavigationAPI.Point { x = 0.3, y = 0.2, z = 0.0 },
|
||||
new NavigationAPI.Point { x = -0.3, y = 0.2, z = 0.0 },
|
||||
new NavigationAPI.Point { x = -0.3, y = -0.2, z = 0.0 }
|
||||
new Point { x = 0.3, y = -0.2, z = 0.0 },
|
||||
new Point { x = 0.3, y = 0.2, z = 0.0 },
|
||||
new Point { x = -0.3, y = 0.2, z = 0.0 },
|
||||
new Point { x = -0.3, y = -0.2, z = 0.0 }
|
||||
};
|
||||
NavigationAPI.navigation_set_robot_footprint(navHandle, footprint, new UIntPtr((uint)footprint.Length));
|
||||
|
||||
// Get robot pose
|
||||
NavigationAPI.Pose2D robotPose = new NavigationAPI.Pose2D();
|
||||
if (NavigationAPI.navigation_get_robot_pose_2d(navHandle, ref robotPose))
|
||||
|
||||
IntPtr fFrameId = Marshal.StringToHGlobalAnsi("fscan");
|
||||
Header fscanHeader = NavigationAPI.header_create(Marshal.PtrToStringAnsi(fFrameId));
|
||||
LaserScan fscanHandle;
|
||||
fscanHandle.header = fscanHeader;
|
||||
fscanHandle.angle_min = -1.57f;
|
||||
fscanHandle.angle_max = 1.57f;
|
||||
fscanHandle.angle_increment = 0.785f;
|
||||
fscanHandle.time_increment = 0.0f;
|
||||
fscanHandle.scan_time = 0.1f;
|
||||
fscanHandle.range_min = 0.05f;
|
||||
fscanHandle.range_max = 10.0f;
|
||||
fscanHandle.ranges = Marshal.AllocHGlobal(sizeof(float) * 5);
|
||||
Marshal.Copy(new float[] { 1.0f, 1.2f, 1.1f, 0.9f, 1.3f }, 0, fscanHandle.ranges, 5);
|
||||
fscanHandle.ranges_count = new UIntPtr(5);
|
||||
fscanHandle.intensities = Marshal.AllocHGlobal(sizeof(float) * 5);
|
||||
Marshal.Copy(new float[] { 100.0f, 120.0f, 110.0f, 90.0f, 130.0f }, 0, fscanHandle.intensities, 5);
|
||||
fscanHandle.intensities_count = new UIntPtr(5);
|
||||
NavigationAPI.navigation_add_laser_scan(navHandle, "/fscan", fscanHandle);
|
||||
|
||||
IntPtr bFrameId = Marshal.StringToHGlobalAnsi("bscan");
|
||||
Header bscanHeader = NavigationAPI.header_create(Marshal.PtrToStringAnsi(bFrameId));
|
||||
LaserScan bscanHandle;
|
||||
bscanHandle.header = bscanHeader;
|
||||
bscanHandle.angle_min = 1.57f;
|
||||
bscanHandle.angle_max = -1.57f;
|
||||
bscanHandle.angle_increment = -0.785f;
|
||||
bscanHandle.time_increment = 0.0f;
|
||||
bscanHandle.scan_time = 0.1f;
|
||||
bscanHandle.range_min = 0.05f;
|
||||
bscanHandle.range_max = 10.0f;
|
||||
bscanHandle.ranges = Marshal.AllocHGlobal(sizeof(float) * 5);
|
||||
Marshal.Copy(new float[] { 1.0f, 1.2f, 1.1f, 0.9f, 1.3f }, 0, bscanHandle.ranges, 5);
|
||||
bscanHandle.ranges_count = new UIntPtr(5);
|
||||
bscanHandle.intensities = Marshal.AllocHGlobal(sizeof(float) * 5);
|
||||
Marshal.Copy(new float[] { 100.0f, 120.0f, 110.0f, 90.0f, 130.0f }, 0, bscanHandle.intensities, 5);
|
||||
bscanHandle.intensities_count = new UIntPtr(5);
|
||||
NavigationAPI.navigation_add_laser_scan(navHandle, "/bscan", bscanHandle);
|
||||
|
||||
IntPtr oFrameId = Marshal.StringToHGlobalAnsi("odom");
|
||||
Header odometryHeader = NavigationAPI.header_create(Marshal.PtrToStringAnsi(oFrameId));
|
||||
Odometry odometryHandle = new Odometry();
|
||||
odometryHandle.header = odometryHeader;
|
||||
IntPtr childFrameId = Marshal.StringToHGlobalAnsi("base_footprint");
|
||||
odometryHandle.child_frame_id = childFrameId;
|
||||
odometryHandle.pose.pose.position.x = 0.0;
|
||||
odometryHandle.pose.pose.position.y = 0.0;
|
||||
odometryHandle.pose.pose.position.z = 0.0;
|
||||
odometryHandle.pose.pose.orientation.x = 0.0;
|
||||
odometryHandle.pose.pose.orientation.y = 0.0;
|
||||
odometryHandle.pose.pose.orientation.z = 0.0;
|
||||
odometryHandle.pose.pose.orientation.w = 1.0;
|
||||
|
||||
double[] pose_covariance = new double[36];
|
||||
for(int i = 0; i < pose_covariance.Length; i++) {
|
||||
pose_covariance[i] = 0.0;
|
||||
}
|
||||
odometryHandle.pose.covariance = Marshal.AllocHGlobal(sizeof(double) * pose_covariance.Length);
|
||||
Marshal.Copy(pose_covariance, 0, odometryHandle.pose.covariance, pose_covariance.Length);
|
||||
odometryHandle.pose.covariance_count = new UIntPtr((uint)pose_covariance.Length);
|
||||
|
||||
odometryHandle.twist.twist.linear.x = 0.0;
|
||||
odometryHandle.twist.twist.linear.y = 0.0;
|
||||
odometryHandle.twist.twist.linear.z = 0.0;
|
||||
odometryHandle.twist.twist.angular.x = 0.0;
|
||||
odometryHandle.twist.twist.angular.y = 0.0;
|
||||
odometryHandle.twist.twist.angular.z = 0.0;
|
||||
double[] twist_covariance = new double[36];
|
||||
for(int i = 0; i < twist_covariance.Length; i++) {
|
||||
twist_covariance[i] = 0.0;
|
||||
}
|
||||
odometryHandle.twist.covariance = Marshal.AllocHGlobal(sizeof(double) * twist_covariance.Length);
|
||||
Marshal.Copy(twist_covariance, 0, odometryHandle.twist.covariance, twist_covariance.Length);
|
||||
odometryHandle.twist.covariance_count = new UIntPtr((uint)twist_covariance.Length);
|
||||
NavigationAPI.navigation_add_odometry(navHandle, "odometry", odometryHandle);
|
||||
|
||||
// Add static map: đọc maze.yaml rồi load ảnh và cập nhật mapMetaData
|
||||
string mapYamlPath = "maze.yaml";
|
||||
int mapWidth, mapHeight;
|
||||
byte[] data;
|
||||
MazeMapConfig mapConfig;
|
||||
if (TryLoadMazeYaml(mapYamlPath, out mapConfig))
|
||||
{
|
||||
Console.WriteLine($"Robot pose: x={robotPose.x}, y={robotPose.y}, theta={robotPose.theta}");
|
||||
data = LoadMazePixelsAsOccupancy(mapConfig.ImagePath, out mapWidth, out mapHeight,
|
||||
mapConfig.Negate, mapConfig.OccupiedThresh, mapConfig.FreeThresh);
|
||||
if (data == null)
|
||||
{
|
||||
mapWidth = 3;
|
||||
mapHeight = 10;
|
||||
data = new byte[30];
|
||||
for (int i = 0; i < data.Length; i++) data[i] = 100;
|
||||
Console.WriteLine("YAML loaded but image failed; using default map 3x10");
|
||||
}
|
||||
else
|
||||
{
|
||||
Console.WriteLine("Loaded map from {0}: {1}x{2}, resolution={3}, origin=({4},{5},{6})",
|
||||
mapConfig.ImagePath, mapWidth, mapHeight, mapConfig.Resolution,
|
||||
mapConfig.OriginX, mapConfig.OriginY, mapConfig.OriginZ);
|
||||
}
|
||||
}
|
||||
else
|
||||
{
|
||||
mapWidth = 3;
|
||||
mapHeight = 10;
|
||||
data = new byte[30];
|
||||
for (int i = 0; i < data.Length; i++) data[i] = 100;
|
||||
mapConfig = default;
|
||||
mapConfig.Resolution = 0.05f;
|
||||
mapConfig.OriginX = mapConfig.OriginY = mapConfig.OriginZ = 0.0;
|
||||
Console.WriteLine("maze.yaml not found, using default map 3x10");
|
||||
}
|
||||
|
||||
// Get navigation feedback
|
||||
NavigationAPI.NavFeedback feedback = new NavigationAPI.NavFeedback();
|
||||
if (NavigationAPI.navigation_get_feedback(navHandle, ref feedback))
|
||||
Time mapLoadTime = NavigationAPI.time_create();
|
||||
MapMetaData mapMetaData = new MapMetaData();
|
||||
mapMetaData.map_load_time = mapLoadTime;
|
||||
mapMetaData.resolution = mapConfig.Resolution;
|
||||
mapMetaData.width = (uint)mapWidth;
|
||||
mapMetaData.height = (uint)mapHeight;
|
||||
mapMetaData.origin = new Pose();
|
||||
mapMetaData.origin.position.x = mapConfig.OriginX;
|
||||
mapMetaData.origin.position.y = mapConfig.OriginY;
|
||||
mapMetaData.origin.position.z = mapConfig.OriginZ;
|
||||
mapMetaData.origin.orientation.x = 0.0;
|
||||
mapMetaData.origin.orientation.y = 0.0;
|
||||
mapMetaData.origin.orientation.z = 0.0;
|
||||
mapMetaData.origin.orientation.w = 1.0;
|
||||
OccupancyGrid occupancyGrid = new OccupancyGrid();
|
||||
IntPtr mapFrameId = Marshal.StringToHGlobalAnsi("map");
|
||||
occupancyGrid.header = NavigationAPI.header_create(Marshal.PtrToStringAnsi(mapFrameId));
|
||||
occupancyGrid.info = mapMetaData;
|
||||
occupancyGrid.data = Marshal.AllocHGlobal(sizeof(byte) * data.Length);
|
||||
Marshal.Copy(data, 0, occupancyGrid.data, data.Length);
|
||||
occupancyGrid.data_count = new UIntPtr((uint)data.Length);
|
||||
Console.WriteLine("data length: {0} {1}", data.Length, occupancyGrid.data_count);
|
||||
Console.WriteLine("C# OccupancyGrid sizeof={0} data_off={1} data_count_off={2}",
|
||||
Marshal.SizeOf<OccupancyGrid>(),
|
||||
Marshal.OffsetOf<OccupancyGrid>("data"),
|
||||
Marshal.OffsetOf<OccupancyGrid>("data_count"));
|
||||
|
||||
NavigationAPI.navigation_add_static_map(navHandle, "/map", occupancyGrid);
|
||||
|
||||
Twist2DStamped twist = new Twist2DStamped();
|
||||
if (NavigationAPI.navigation_get_twist(navHandle, ref twist))
|
||||
{
|
||||
string stateStr = NavigationAPI.MarshalString(
|
||||
NavigationAPI.navigation_state_to_string(feedback.navigation_state));
|
||||
string feedbackStr = NavigationAPI.MarshalString(feedback.feed_back_str);
|
||||
Console.WriteLine($"State: {stateStr}, Feedback: {feedbackStr}");
|
||||
NavigationAPI.navigation_free_feedback(ref feedback);
|
||||
Console.WriteLine(
|
||||
"Twist: {0}, {1}, {2}, {3}",
|
||||
NavigationAPI.MarshalString(twist.header.frame_id), twist.velocity.x, twist.velocity.y, twist.velocity.theta);
|
||||
}
|
||||
|
||||
// Cleanup
|
||||
// Build order (thao cách bom order): header + nodes + edges giống C++
|
||||
Order order = new Order();
|
||||
order.headerId = 1;
|
||||
order.timestamp = Marshal.StringToHGlobalAnsi("2026-02-28 10:00:00");
|
||||
order.version = Marshal.StringToHGlobalAnsi("1.0.0");
|
||||
order.manufacturer = Marshal.StringToHGlobalAnsi("Manufacturer");
|
||||
order.serialNumber = Marshal.StringToHGlobalAnsi("Serial Number");
|
||||
order.orderId = Marshal.StringToHGlobalAnsi("Order ID");
|
||||
order.orderUpdateId = 1;
|
||||
|
||||
// Nodes: giống for (auto node : order.nodes) { node_msg.nodeId = ...; node_msg.nodePosition.x = ...; order_msg.nodes.push_back(node_msg); }
|
||||
int nodeCount = 1;
|
||||
order.nodes = Marshal.AllocHGlobal(Marshal.SizeOf<Node>() * nodeCount);
|
||||
order.nodes_count = new UIntPtr((uint)nodeCount);
|
||||
Node node1 = new Node();
|
||||
node1.nodeId = Marshal.StringToHGlobalAnsi("node-1");
|
||||
node1.sequenceId = 0;
|
||||
node1.nodeDescription = Marshal.StringToHGlobalAnsi("Goal node");
|
||||
node1.released = 0;
|
||||
node1.nodePosition.x = 1.0;
|
||||
node1.nodePosition.y = 1.0;
|
||||
node1.nodePosition.theta = 0.0;
|
||||
node1.nodePosition.allowedDeviationXY = 0.1f;
|
||||
node1.nodePosition.allowedDeviationTheta = 0.05f;
|
||||
node1.nodePosition.mapId = Marshal.StringToHGlobalAnsi("map");
|
||||
node1.nodePosition.mapDescription = Marshal.StringToHGlobalAnsi("");
|
||||
node1.actions = IntPtr.Zero;
|
||||
node1.actions_count = UIntPtr.Zero;
|
||||
Marshal.StructureToPtr(node1, order.nodes, false);
|
||||
|
||||
// Edges: rỗng trong ví dụ này; nếu cần thì alloc và fill tương tự (edge_msg.edgeId, trajectory.controlPoints, ...)
|
||||
order.edges = IntPtr.Zero;
|
||||
order.edges_count = UIntPtr.Zero;
|
||||
order.zoneSetId = Marshal.StringToHGlobalAnsi("");
|
||||
|
||||
PoseStamped goal = new PoseStamped();
|
||||
goal.header = NavigationAPI.header_create(Marshal.PtrToStringAnsi(mapFrameId));
|
||||
goal.pose.position.x = 0.01;
|
||||
goal.pose.position.y = 0.01;
|
||||
goal.pose.position.z = 0.0;
|
||||
goal.pose.orientation.x = 0.0;
|
||||
goal.pose.orientation.y = 0.0;
|
||||
goal.pose.orientation.z = 0.0;
|
||||
goal.pose.orientation.w = 1.0;
|
||||
|
||||
|
||||
// Console.WriteLine("Docking to docking_point");
|
||||
NavigationAPI.navigation_dock_to(navHandle, "charger", goal);
|
||||
|
||||
// NavigationAPI.navigation_move_to_nodes_edges(navHandle, order.nodes, order.nodes_count, order.edges, order.edges_count, goal);
|
||||
|
||||
// NavigationAPI.navigation_move_to_order(navHandle, order, goal);
|
||||
NavigationAPI.navigation_set_twist_linear(navHandle, 0.1, 0.0, 0.0);
|
||||
NavigationAPI.navigation_set_twist_angular(navHandle, 0.0, 0.0, 0.2);
|
||||
|
||||
// NavigationAPI.navigation_move_straight_to(navHandle, 1.0);
|
||||
|
||||
while (true)
|
||||
{
|
||||
System.Threading.Thread.Sleep(100);
|
||||
// NavigationAPI.NavFeedback feedback = new NavigationAPI.NavFeedback();
|
||||
// if (NavigationAPI.navigation_get_feedback(navHandle, ref feedback))
|
||||
// {
|
||||
// if (feedback.navigation_state == NavigationAPI.NavigationState.Succeeded)
|
||||
// {
|
||||
// Console.WriteLine("Navigation is Succeeded");
|
||||
// break;
|
||||
// }
|
||||
// }
|
||||
|
||||
// NavigationAPI.PlannerDataOutput globalData = new NavigationAPI.PlannerDataOutput();
|
||||
// if (NavigationAPI.navigation_get_global_data(navHandle, ref globalData))
|
||||
// {
|
||||
// int n = (int)(uint)globalData.plan.poses_count;
|
||||
// int poseSize = Marshal.SizeOf<Pose2DStamped>();
|
||||
// for (int i = 0; i < n; i++)
|
||||
// {
|
||||
// IntPtr posePtr = IntPtr.Add(globalData.plan.poses, i * poseSize);
|
||||
// Pose2DStamped p = Marshal.PtrToStructure<Pose2DStamped>(posePtr);
|
||||
// double p_x = p.pose.x;
|
||||
// double p_y = p.pose.y;
|
||||
// double p_theta = p.pose.theta;
|
||||
// Console.WriteLine("Plan: {0}, {1}, {2}", p_x, p_y, p_theta);
|
||||
// }
|
||||
// if(globalData.is_costmap_updated) {
|
||||
// for(int i = 0; i < (int)(uint)globalData.costmap.data_count; i++) {
|
||||
// byte cellValue = Marshal.ReadByte(globalData.costmap.data, i);
|
||||
// Console.WriteLine("Costmap: {0} {1}", i, cellValue);
|
||||
// }
|
||||
// }
|
||||
// else {
|
||||
// Console.WriteLine("Global Costmap is not updated");
|
||||
// }
|
||||
// }
|
||||
|
||||
// NavigationAPI.PlannerDataOutput localData = new NavigationAPI.PlannerDataOutput();
|
||||
// if(NavigationAPI.navigation_get_local_data(navHandle, ref localData))
|
||||
// {
|
||||
// int n = (int)(uint)localData.plan.poses_count;
|
||||
// int poseSize = Marshal.SizeOf<Pose2DStamped>();
|
||||
// for (int i = 0; i < n; i++)
|
||||
// {
|
||||
// IntPtr posePtr = IntPtr.Add(localData.plan.poses, i * poseSize);
|
||||
// Pose2DStamped p = Marshal.PtrToStructure<Pose2DStamped>(posePtr);
|
||||
// double p_x = p.pose.x;
|
||||
// double p_y = p.pose.y;
|
||||
// double p_theta = p.pose.theta;
|
||||
// Console.WriteLine("Plan: {0}, {1}, {2}", p_x, p_y, p_theta);
|
||||
// }
|
||||
// if(localData.is_costmap_updated) {
|
||||
// for(int i = 0; i < (int)(uint)localData.costmap.data_count; i++) {
|
||||
// byte cellValue = Marshal.ReadByte(localData.costmap.data, i);
|
||||
// Console.WriteLine("Costmap: {0} {1}", i, cellValue);
|
||||
// }
|
||||
// }
|
||||
// else {
|
||||
// Console.WriteLine("Local Costmap is not updated");
|
||||
// }
|
||||
// }
|
||||
}
|
||||
// Cleanup (destroy nav first, then tf3 buffer)
|
||||
|
||||
NavigationAPI.navigation_destroy(navHandle);
|
||||
NavigationAPI.tf_listener_destroy(tfHandle);
|
||||
TF3API.tf3_buffer_destroy(tf3Buffer);
|
||||
Console.WriteLine("Press any key to exit...");
|
||||
try
|
||||
{
|
||||
Console.ReadKey(intercept: true);
|
||||
}
|
||||
catch (InvalidOperationException)
|
||||
{
|
||||
// Running without a real console (e.g. redirected/automated run).
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
133
examples/NavigationExample/TF3API.cs
Normal file
133
examples/NavigationExample/TF3API.cs
Normal file
@@ -0,0 +1,133 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
namespace NavigationExample
|
||||
{
|
||||
|
||||
// ============================================================================
|
||||
// TF3 C API - P/Invoke wrapper for libtf3 (tf3 BufferCore)
|
||||
// ============================================================================
|
||||
public static class TF3API
|
||||
{
|
||||
private const string Tf3DllName = "/usr/local/lib/libtf3.so"; // Linux; Windows: tf3.dll, macOS: libtf3.dylib
|
||||
|
||||
public enum TF3_ErrorCode
|
||||
{
|
||||
TF3_OK = 0,
|
||||
TF3_ERROR_LOOKUP = 1,
|
||||
TF3_ERROR_CONNECTIVITY = 2,
|
||||
TF3_ERROR_EXTRAPOLATION = 3,
|
||||
TF3_ERROR_INVALID_ARGUMENT = 4,
|
||||
TF3_ERROR_TIMEOUT = 5,
|
||||
TF3_ERROR_UNKNOWN = 99
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential, CharSet = CharSet.Ansi)]
|
||||
public struct TF3_Transform
|
||||
{
|
||||
public long timestamp_sec;
|
||||
public long timestamp_nsec;
|
||||
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 256)]
|
||||
public string frame_id;
|
||||
[MarshalAs(UnmanagedType.ByValTStr, SizeConst = 256)]
|
||||
public string child_frame_id;
|
||||
public double translation_x;
|
||||
public double translation_y;
|
||||
public double translation_z;
|
||||
public double rotation_x;
|
||||
public double rotation_y;
|
||||
public double rotation_z;
|
||||
public double rotation_w;
|
||||
}
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern IntPtr tf3_buffer_create(int cache_time_sec);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void tf3_buffer_destroy(IntPtr buffer);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf3_set_transform(
|
||||
IntPtr buffer,
|
||||
ref TF3_Transform transform,
|
||||
string authority,
|
||||
[MarshalAs(UnmanagedType.I1)] bool is_static);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf3_lookup_transform(
|
||||
IntPtr buffer,
|
||||
string target_frame,
|
||||
string source_frame,
|
||||
long time_sec,
|
||||
long time_nsec,
|
||||
out TF3_Transform transform,
|
||||
out TF3_ErrorCode error_code);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf3_lookup_transform_full(
|
||||
IntPtr buffer,
|
||||
string target_frame,
|
||||
long target_time_sec,
|
||||
long target_time_nsec,
|
||||
string source_frame,
|
||||
long source_time_sec,
|
||||
long source_time_nsec,
|
||||
string fixed_frame,
|
||||
out TF3_Transform transform,
|
||||
out TF3_ErrorCode error_code);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl, CharSet = CharSet.Ansi)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf3_can_transform(
|
||||
IntPtr buffer,
|
||||
string target_frame,
|
||||
string source_frame,
|
||||
long time_sec,
|
||||
long time_nsec,
|
||||
System.Text.StringBuilder error_msg,
|
||||
int error_msg_len);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern int tf3_get_all_frame_names(IntPtr buffer, System.Text.StringBuilder frames, int frames_len);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf3_get_frame_tree(IntPtr buffer, System.Text.StringBuilder output, int output_len);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void tf3_clear(IntPtr buffer);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern void tf3_get_current_time(out long sec, out long nsec);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
[return: MarshalAs(UnmanagedType.I1)]
|
||||
public static extern bool tf3_get_last_error(IntPtr buffer, System.Text.StringBuilder error_msg, int error_msg_len);
|
||||
|
||||
[DllImport(Tf3DllName, CallingConvention = CallingConvention.Cdecl)]
|
||||
public static extern IntPtr tf3_get_version();
|
||||
|
||||
/// <summary>Helper: create TF3_Transform for static transform (identity or given pose).</summary>
|
||||
public static TF3_Transform CreateStaticTransform(string parentFrame, string childFrame,
|
||||
double tx = 0, double ty = 0, double tz = 0,
|
||||
double qx = 0, double qy = 0, double qz = 0, double qw = 1)
|
||||
{
|
||||
var t = new TF3_Transform();
|
||||
t.timestamp_sec = 0;
|
||||
t.timestamp_nsec = 0;
|
||||
t.frame_id = parentFrame ?? "";
|
||||
t.child_frame_id = childFrame ?? "";
|
||||
t.translation_x = tx;
|
||||
t.translation_y = ty;
|
||||
t.translation_z = tz;
|
||||
t.rotation_x = qx;
|
||||
t.rotation_y = qy;
|
||||
t.rotation_z = qz;
|
||||
t.rotation_w = qw;
|
||||
return t;
|
||||
}
|
||||
}
|
||||
}
|
||||
Binary file not shown.
BIN
examples/NavigationExample/maze.png
Normal file
BIN
examples/NavigationExample/maze.png
Normal file
Binary file not shown.
|
After Width: | Height: | Size: 2.5 KiB |
6
examples/NavigationExample/maze.yaml
Normal file
6
examples/NavigationExample/maze.yaml
Normal file
@@ -0,0 +1,6 @@
|
||||
image: maze.png
|
||||
resolution: 0.05
|
||||
origin: [0.0, 0.0, 0.0]
|
||||
negate: 0
|
||||
occupied_thresh: 0.65
|
||||
free_thresh: 0.196
|
||||
274
examples/NavigationExample/msgs/CommonMsgs.cs
Normal file
274
examples/NavigationExample/msgs/CommonMsgs.cs
Normal file
@@ -0,0 +1,274 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
namespace NavigationExample
|
||||
{
|
||||
// ============================================================================
|
||||
// Structures
|
||||
// ============================================================================
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Point
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose2D
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double theta;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Twist2D
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double theta;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Quaternion
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
public double w;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Position
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose
|
||||
{
|
||||
public Point position;
|
||||
public Quaternion orientation;
|
||||
}
|
||||
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Vector3
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Twist
|
||||
{
|
||||
public Vector3 linear;
|
||||
public Vector3 angular;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Header
|
||||
{
|
||||
public uint seq;
|
||||
public uint sec;
|
||||
public uint nsec;
|
||||
public IntPtr frame_id; // char*
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PoseStamped
|
||||
{
|
||||
public Header header;
|
||||
public Pose pose;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Twist2DStamped
|
||||
{
|
||||
public Header header;
|
||||
public Twist2D velocity;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct LaserScan
|
||||
{
|
||||
public Header header;
|
||||
public float angle_min;
|
||||
public float angle_max;
|
||||
public float angle_increment;
|
||||
public float time_increment;
|
||||
public float scan_time;
|
||||
public float range_min;
|
||||
public float range_max;
|
||||
public IntPtr ranges;
|
||||
public UIntPtr ranges_count;
|
||||
public IntPtr intensities;
|
||||
public UIntPtr intensities_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PointCloud
|
||||
{
|
||||
public Header header;
|
||||
public IntPtr points;
|
||||
public UIntPtr points_count;
|
||||
public IntPtr channels;
|
||||
public UIntPtr channels_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PointCloud2
|
||||
{
|
||||
public Header header;
|
||||
public uint height;
|
||||
public uint width;
|
||||
public IntPtr fields;
|
||||
public UIntPtr fields_count;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool is_bigendian;
|
||||
public uint point_step;
|
||||
public uint row_step;
|
||||
public IntPtr data;
|
||||
public UIntPtr data_count;
|
||||
[MarshalAs(UnmanagedType.I1)]
|
||||
public bool is_dense;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PoseWithCovariance
|
||||
{
|
||||
public Pose pose;
|
||||
public IntPtr covariance;
|
||||
public UIntPtr covariance_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct TwistWithCovariance {
|
||||
public Twist twist;
|
||||
public IntPtr covariance;
|
||||
public UIntPtr covariance_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Odometry
|
||||
{
|
||||
public Header header;
|
||||
public IntPtr child_frame_id;
|
||||
public PoseWithCovariance pose;
|
||||
public TwistWithCovariance twist;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct OccupancyGrid
|
||||
{
|
||||
public Header header;
|
||||
public MapMetaData info;
|
||||
public IntPtr data;
|
||||
public UIntPtr data_count;
|
||||
}
|
||||
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct MapMetaData
|
||||
{
|
||||
public Time map_load_time;
|
||||
public float resolution;
|
||||
public uint width;
|
||||
public uint height;
|
||||
public Pose origin;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Time
|
||||
{
|
||||
public uint sec;
|
||||
public uint nsec;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Point32
|
||||
{
|
||||
public float x;
|
||||
public float y;
|
||||
public float z;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Pose2DStamped
|
||||
{
|
||||
public Header header;
|
||||
public Pose2D pose;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Polygon
|
||||
{
|
||||
public IntPtr points;
|
||||
public UIntPtr points_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct PolygonStamped
|
||||
{
|
||||
public Header header;
|
||||
public Polygon polygon;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct OccupancyGridUpdate
|
||||
{
|
||||
public Header header;
|
||||
public int x;
|
||||
public int y;
|
||||
public uint width;
|
||||
public uint height;
|
||||
public IntPtr data;
|
||||
public UIntPtr data_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Path2D
|
||||
{
|
||||
public Header header;
|
||||
public IntPtr poses;
|
||||
public UIntPtr poses_count;
|
||||
}
|
||||
|
||||
/// <summary>Name (char*) + OccupancyGrid for static map list API.</summary>
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NamedOccupancyGrid
|
||||
{
|
||||
public IntPtr name;
|
||||
public OccupancyGrid grid;
|
||||
}
|
||||
|
||||
/// <summary>Name (char*) + LaserScan for laser scan list API.</summary>
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NamedLaserScan
|
||||
{
|
||||
public IntPtr name;
|
||||
public LaserScan scan;
|
||||
}
|
||||
|
||||
/// <summary>Name (char*) + PointCloud for point cloud list API.</summary>
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NamedPointCloud
|
||||
{
|
||||
public IntPtr name;
|
||||
public PointCloud cloud;
|
||||
}
|
||||
|
||||
/// <summary>Name (char*) + PointCloud2 for point cloud2 list API.</summary>
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NamedPointCloud2
|
||||
{
|
||||
public IntPtr name;
|
||||
public PointCloud2 cloud;
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
109
examples/NavigationExample/msgs/ProtocolMsgsTypes.cs
Normal file
109
examples/NavigationExample/msgs/ProtocolMsgsTypes.cs
Normal file
@@ -0,0 +1,109 @@
|
||||
using System;
|
||||
using System.Runtime.InteropServices;
|
||||
|
||||
namespace NavigationExample
|
||||
{
|
||||
/// <summary>
|
||||
/// C# struct layout cho protocol_msgs (robot_protocol_msgs C API).
|
||||
/// Khớp với pnkx_nav_core/src/APIs/c_api/include/protocol_msgs/*.h
|
||||
/// </summary>
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct ControlPoint
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double weight;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct ActionParameter
|
||||
{
|
||||
public IntPtr key; // char*
|
||||
public IntPtr value; // char*
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct NodePosition
|
||||
{
|
||||
public double x;
|
||||
public double y;
|
||||
public double theta;
|
||||
public float allowedDeviationXY;
|
||||
public float allowedDeviationTheta;
|
||||
public IntPtr mapId; // char*
|
||||
public IntPtr mapDescription; // char*
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Trajectory
|
||||
{
|
||||
public uint degree;
|
||||
public IntPtr knotVector; // double*
|
||||
public UIntPtr knotVector_count;
|
||||
public IntPtr controlPoints; // ControlPoint*
|
||||
public UIntPtr controlPoints_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Action
|
||||
{
|
||||
public IntPtr actionType; // char*
|
||||
public IntPtr actionId; // char*
|
||||
public IntPtr actionDescription;// char*
|
||||
public IntPtr blockingType; // char*
|
||||
public IntPtr actionParameters; // ActionParameter*
|
||||
public UIntPtr actionParameters_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Node
|
||||
{
|
||||
public IntPtr nodeId; // char*
|
||||
public int sequenceId;
|
||||
public IntPtr nodeDescription; // char*
|
||||
public byte released;
|
||||
public NodePosition nodePosition;
|
||||
public IntPtr actions; // Action*
|
||||
public UIntPtr actions_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Edge
|
||||
{
|
||||
public IntPtr edgeId; // char*
|
||||
public int sequenceId;
|
||||
public IntPtr edgeDescription; // char*
|
||||
public byte released;
|
||||
public IntPtr startNodeId; // char*
|
||||
public IntPtr endNodeId; // char*
|
||||
public double maxSpeed;
|
||||
public double maxHeight;
|
||||
public double minHeight;
|
||||
public double orientation;
|
||||
public IntPtr orientationType; // char*
|
||||
public IntPtr direction; // char*
|
||||
public byte rotationAllowed;
|
||||
public double maxRotationSpeed;
|
||||
public Trajectory trajectory;
|
||||
public double length;
|
||||
public IntPtr actions; // Action*
|
||||
public UIntPtr actions_count;
|
||||
}
|
||||
|
||||
[StructLayout(LayoutKind.Sequential)]
|
||||
public struct Order
|
||||
{
|
||||
public int headerId;
|
||||
public IntPtr timestamp; // char*
|
||||
public IntPtr version; // char*
|
||||
public IntPtr manufacturer; // char*
|
||||
public IntPtr serialNumber; // char*
|
||||
public IntPtr orderId; // char*
|
||||
public uint orderUpdateId;
|
||||
public IntPtr nodes; // Node*
|
||||
public UIntPtr nodes_count;
|
||||
public IntPtr edges; // Edge*
|
||||
public UIntPtr edges_count;
|
||||
public IntPtr zoneSetId; // char*
|
||||
}
|
||||
}
|
||||
0
examples/NavigationExample/msgs/SensorMsgs.cs
Normal file
0
examples/NavigationExample/msgs/SensorMsgs.cs
Normal file
@@ -27,6 +27,7 @@ echo "Building C API library..."
|
||||
cd "$BUILD_DIR"
|
||||
cmake ..
|
||||
make
|
||||
sudo make install
|
||||
echo "Library built successfully!"
|
||||
|
||||
|
||||
@@ -82,12 +83,10 @@ fi
|
||||
|
||||
# Luôn copy source code mới nhất (cập nhật file nếu đã có)
|
||||
cd "$EXAMPLE_DIR/NavigationExample"
|
||||
echo "Updating Program.cs from CSharpExample.cs..."
|
||||
cp ../CSharpExample.cs Program.cs
|
||||
|
||||
# Bước 3: Copy library
|
||||
echo "Copying library..."
|
||||
cp "$LIB_DIR/libnav_c_api.so" .
|
||||
# # Bước 3: Copy library
|
||||
# echo "Copying library..."
|
||||
# cp "$LIB_DIR/libnav_c_api.so" .
|
||||
|
||||
# Bước 4: Set LD_LIBRARY_PATH để tìm được tất cả dependencies
|
||||
# Main build directory (contains libtf3.so, librobot_cpp.so, etc.)
|
||||
|
||||
29
pnkx_nav_core.sln
Normal file
29
pnkx_nav_core.sln
Normal file
@@ -0,0 +1,29 @@
|
||||
Microsoft Visual Studio Solution File, Format Version 12.00
|
||||
# Visual Studio Version 17
|
||||
VisualStudioVersion = 17.5.2.0
|
||||
MinimumVisualStudioVersion = 10.0.40219.1
|
||||
Project("{2150E333-8FDC-42A3-9474-1A3956D46DE8}") = "examples", "examples", "{B36A84DF-456D-A817-6EDD-3EC3E7F6E11F}"
|
||||
EndProject
|
||||
Project("{FAE04EC0-301F-11D3-BF4B-00C04F79EFBC}") = "NavigationExample", "examples\NavigationExample\NavigationExample.csproj", "{995839D6-1E72-F444-6587-97EF24F93814}"
|
||||
EndProject
|
||||
Global
|
||||
GlobalSection(SolutionConfigurationPlatforms) = preSolution
|
||||
Debug|Any CPU = Debug|Any CPU
|
||||
Release|Any CPU = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(ProjectConfigurationPlatforms) = postSolution
|
||||
{995839D6-1E72-F444-6587-97EF24F93814}.Debug|Any CPU.ActiveCfg = Debug|Any CPU
|
||||
{995839D6-1E72-F444-6587-97EF24F93814}.Debug|Any CPU.Build.0 = Debug|Any CPU
|
||||
{995839D6-1E72-F444-6587-97EF24F93814}.Release|Any CPU.ActiveCfg = Release|Any CPU
|
||||
{995839D6-1E72-F444-6587-97EF24F93814}.Release|Any CPU.Build.0 = Release|Any CPU
|
||||
EndGlobalSection
|
||||
GlobalSection(SolutionProperties) = preSolution
|
||||
HideSolutionNode = FALSE
|
||||
EndGlobalSection
|
||||
GlobalSection(NestedProjects) = preSolution
|
||||
{995839D6-1E72-F444-6587-97EF24F93814} = {B36A84DF-456D-A817-6EDD-3EC3E7F6E11F}
|
||||
EndGlobalSection
|
||||
GlobalSection(ExtensibilityGlobals) = postSolution
|
||||
SolutionGuid = {1A56EED1-5E6A-48A6-9AEE-F39361B34305}
|
||||
EndGlobalSection
|
||||
EndGlobal
|
||||
0
robotapp.db
Normal file
0
robotapp.db
Normal file
@@ -10,17 +10,20 @@ if(NOT CMAKE_BUILD_TYPE)
|
||||
set(CMAKE_BUILD_TYPE Release)
|
||||
endif()
|
||||
|
||||
# Find Boost
|
||||
find_package(Boost REQUIRED)
|
||||
# Find Boost (filesystem needed for plugin path / boost::dll usage)
|
||||
find_package(Boost REQUIRED COMPONENTS filesystem system)
|
||||
|
||||
# Dependencies
|
||||
# Dependencies (robot_nav_2d_utils_conversions provides poseStampedToPose2D used by move_base_core/navigation.h)
|
||||
set(PACKAGES_DIR
|
||||
move_base_core
|
||||
move_base
|
||||
robot_nav_2d_utils
|
||||
tf3
|
||||
robot_time
|
||||
robot_cpp
|
||||
geometry_msgs
|
||||
angles
|
||||
data_convert
|
||||
robot_protocol_msgs
|
||||
)
|
||||
|
||||
# Thư mục include
|
||||
@@ -29,8 +32,28 @@ include_directories(
|
||||
)
|
||||
|
||||
# Tìm tất cả file source
|
||||
file(GLOB SOURCES "src/*.cpp")
|
||||
file(GLOB HEADERS "include/*.h")
|
||||
file(GLOB SOURCES
|
||||
"src/*.cpp"
|
||||
"src/std_msgs/*.cpp"
|
||||
"src/sensor_msgs/*.cpp"
|
||||
"src/geometry_msgs/*.cpp"
|
||||
"src/nav_msgs/*.cpp"
|
||||
"src/nav_2d_msgs/*.cpp"
|
||||
"src/robot_nav_msgs/*.cpp"
|
||||
"src/robot_geometry_msgs/*.cpp"
|
||||
"src/map_msgs/*.cpp"
|
||||
)
|
||||
file(GLOB HEADERS
|
||||
"include/*.h"
|
||||
"include/std_msgs/*.h"
|
||||
"include/sensor_msgs/*.h"
|
||||
"include/geometry_msgs/*.h"
|
||||
"include/nav_msgs/*.h"
|
||||
"include/nav_2d_msgs/*.h"
|
||||
"include/robot_nav_msgs/*.h"
|
||||
"include/robot_geometry_msgs/*.h"
|
||||
"include/map_msgs/*.h"
|
||||
)
|
||||
|
||||
# Tạo thư viện shared (.so)
|
||||
add_library(nav_c_api SHARED ${SOURCES} ${HEADERS})
|
||||
@@ -41,11 +64,15 @@ target_link_libraries(nav_c_api
|
||||
${PACKAGES_DIR}
|
||||
PRIVATE
|
||||
Boost::boost
|
||||
Boost::filesystem
|
||||
Boost::system
|
||||
dl
|
||||
)
|
||||
|
||||
set_target_properties(nav_c_api PROPERTIES
|
||||
LIBRARY_OUTPUT_DIRECTORY ${CMAKE_BINARY_DIR}
|
||||
BUILD_RPATH "${CMAKE_BINARY_DIR}"
|
||||
INSTALL_RPATH "${CMAKE_INSTALL_PREFIX}/lib"
|
||||
)
|
||||
|
||||
# Set include directories
|
||||
|
||||
206
src/APIs/c_api/include/convertor.h
Normal file
206
src/APIs/c_api/include/convertor.h
Normal file
@@ -0,0 +1,206 @@
|
||||
#ifndef C_API_CONVERTOR_H
|
||||
#define C_API_CONVERTOR_H
|
||||
|
||||
// C
|
||||
#include "sensor_msgs/LaserScan.h"
|
||||
#include "sensor_msgs/PointCloud.h"
|
||||
#include "sensor_msgs/PointCloud2.h"
|
||||
#include "nav_msgs/Odometry.h"
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_msgs/OccupancyGrid.h"
|
||||
#include "geometry_msgs/Point.h"
|
||||
#include "geometry_msgs/PoseStamped.h"
|
||||
#include "geometry_msgs/Pose2D.h"
|
||||
#include "nav_2d_msgs/Twist2D.h"
|
||||
#include "nav_2d_msgs/Twist2DStamped.h"
|
||||
#include "nav_2d_msgs/Path2D.h"
|
||||
#include "map_msgs/OccupancyGridUpdate.h"
|
||||
#include "geometry_msgs/PolygonStamped.h"
|
||||
#include "protocol_msgs/Order.h"
|
||||
|
||||
// C++
|
||||
#include <robot_sensor_msgs/LaserScan.h>
|
||||
#include <robot_sensor_msgs/PointCloud.h>
|
||||
#include <robot_sensor_msgs/PointCloud2.h>
|
||||
#include <robot_nav_msgs/Odometry.h>
|
||||
#include <robot_nav_msgs/OccupancyGrid.h>
|
||||
#include <robot_geometry_msgs/PoseStamped.h>
|
||||
#include <robot_geometry_msgs/Pose2D.h>
|
||||
#include <robot_nav_2d_msgs/Twist2D.h>
|
||||
#include <robot_nav_2d_msgs/Twist2DStamped.h>
|
||||
#include <robot_nav_2d_msgs/Path2D.h>
|
||||
#include <robot_map_msgs/OccupancyGridUpdate.h>
|
||||
#include <robot_geometry_msgs/PolygonStamped.h>
|
||||
#include <robot_protocol_msgs/Order.h>
|
||||
|
||||
#include <move_base_core/navigation.h>
|
||||
#include <move_base_core/common.h>
|
||||
|
||||
/**
|
||||
* @brief Convert C LaserScan to C++ LaserScan
|
||||
* @param laser_scan C LaserScan
|
||||
* @return C++ LaserScan
|
||||
*/
|
||||
robot_sensor_msgs::LaserScan convert2CppLaserScan(const LaserScan& laser_scan);
|
||||
|
||||
/**
|
||||
* @brief Convert C OccupancyGrid to C++ OccupancyGrid
|
||||
* @param occupancy_grid C OccupancyGrid
|
||||
* @return C++ OccupancyGrid
|
||||
*/
|
||||
robot_nav_msgs::OccupancyGrid convert2CppOccupancyGrid(const OccupancyGrid& occupancy_grid);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ OccupancyGrid to C OccupancyGrid
|
||||
* @param cpp C++ OccupancyGrid
|
||||
* @param out C OccupancyGrid
|
||||
*/
|
||||
void convert2COccupancyGrid(const robot_nav_msgs::OccupancyGrid& cpp, OccupancyGrid& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ Path2D to C Path2D
|
||||
*/
|
||||
void convert2CPath2D(const robot_nav_2d_msgs::Path2D& cpp, Path2D& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ OccupancyGridUpdate to C OccupancyGridUpdate
|
||||
*/
|
||||
void convert2COccupancyGridUpdate(const robot_map_msgs::OccupancyGridUpdate& cpp, OccupancyGridUpdate& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ PolygonStamped to C PolygonStamped
|
||||
*/
|
||||
void convert2CPolygonStamped(const robot_geometry_msgs::PolygonStamped& cpp, PolygonStamped& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ LaserScan to C LaserScan
|
||||
* @param cpp C++ LaserScan
|
||||
* @param out C LaserScan
|
||||
*/
|
||||
void convert2CLaserScan(const robot_sensor_msgs::LaserScan& cpp, LaserScan& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ PointCloud to C PointCloud
|
||||
* @param cpp C++ PointCloud
|
||||
* @param out C PointCloud
|
||||
*/
|
||||
void convert2CPointCloud(const robot_sensor_msgs::PointCloud& cpp, PointCloud& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ PointCloud2 to C PointCloud2
|
||||
* @param cpp C++ PointCloud2
|
||||
* @param out C PointCloud2
|
||||
*/
|
||||
void convert2CPointCloud2(const robot_sensor_msgs::PointCloud2& cpp, PointCloud2& out);
|
||||
|
||||
/**
|
||||
* @brief Convert C PointCloud to C++ PointCloud
|
||||
* @param c C PointCloud
|
||||
* @return C++ PointCloud
|
||||
*/
|
||||
robot_sensor_msgs::PointCloud convert2CppPointCloud(const PointCloud& c);
|
||||
|
||||
/**
|
||||
* @brief Convert C PointCloud2 to C++ PointCloud2
|
||||
* @param c C PointCloud2
|
||||
* @return C++ PointCloud2
|
||||
*/
|
||||
robot_sensor_msgs::PointCloud2 convert2CppPointCloud2(const PointCloud2& c);
|
||||
|
||||
/**
|
||||
* @brief Convert C Odometry to C++ Odometry
|
||||
* @param odometry C Odometry
|
||||
* @return C++ Odometry
|
||||
*/
|
||||
robot_nav_msgs::Odometry convert2CppOdometry(const Odometry& odometry);
|
||||
|
||||
/**
|
||||
* @brief Convert C PoseStamped to C++ PoseStamped
|
||||
* @param pose_stamped C PoseStamped
|
||||
* @return C++ PoseStamped
|
||||
*/
|
||||
robot_geometry_msgs::PoseStamped convert2CppPoseStamped(const PoseStamped& pose_stamped);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ PoseStamped to C PoseStamped
|
||||
* @param cpp_pose_stamped C++ PoseStamped
|
||||
* @return C PoseStamped
|
||||
*/
|
||||
PoseStamped convert2CPoseStamped(const robot_geometry_msgs::PoseStamped& cpp_pose_stamped);
|
||||
|
||||
|
||||
/**
|
||||
* @brief Convert C Pose2D to C++ Pose2D
|
||||
* @param pose_2d C Pose2D
|
||||
* @return C++ Pose2D
|
||||
*/
|
||||
robot_geometry_msgs::Pose2D convert2CppPose2D(const Pose2D& pose_2d);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ Pose2D to C Pose2D
|
||||
* @param cpp_pose_2d C++ Pose2D
|
||||
* @return C Pose2D
|
||||
*/
|
||||
Pose2D convert2CPose2D(const robot_geometry_msgs::Pose2D& cpp_pose_2d);
|
||||
|
||||
/**
|
||||
* @brief Convert C Twist2D to C++ Twist2D
|
||||
* @param twist_2d C Twist2D
|
||||
* @return C++ Twist2D
|
||||
*/
|
||||
robot_nav_2d_msgs::Twist2D convert2CppTwist2D(const Twist2D& twist_2d);
|
||||
|
||||
|
||||
/**
|
||||
* @brief Convert C++ Twist2D to C Twist2D
|
||||
* @param cpp_twist_2d C++ Twist2D
|
||||
* @return C Twist2D
|
||||
*/
|
||||
Twist2D convert2CTwist2D(const robot_nav_2d_msgs::Twist2D& cpp_twist_2d);
|
||||
|
||||
/**
|
||||
* @brief Convert C Twist2DStamped to C++ Twist2DStamped
|
||||
* @param twist_2d_stamped C Twist2DStamped
|
||||
* @return C++ Twist2DStamped
|
||||
*/
|
||||
robot_nav_2d_msgs::Twist2DStamped convert2CppTwist2DStamped(const Twist2DStamped& twist_2d_stamped);
|
||||
|
||||
|
||||
/**
|
||||
* @brief Convert C++ Twist2DStamped to C Twist2DStamped
|
||||
* @param cpp_twist_2d_stamped C++ Twist2DStamped
|
||||
* @return C Twist2DStamped
|
||||
*/
|
||||
Twist2DStamped convert2CTwist2DStamped(const robot_nav_2d_msgs::Twist2DStamped& cpp_twist_2d_stamped);
|
||||
|
||||
/**
|
||||
* @brief Convert C Order to C++ Order
|
||||
* @param order C Order
|
||||
* @return C++ Order
|
||||
*/
|
||||
robot_protocol_msgs::Order convert2CppOrder(const Order& order);
|
||||
|
||||
/**
|
||||
* @brief Convert C++ Order to C Order
|
||||
* @param cpp_order C++ Order
|
||||
* @return C Order (caller must call order_free when done to release memory)
|
||||
*/
|
||||
Order convert2COrder(const robot_protocol_msgs::Order& cpp_order);
|
||||
|
||||
/**
|
||||
* @brief Check if a quaternion is valid
|
||||
* @param q Quaternion
|
||||
* @return True if valid, false otherwise
|
||||
*/
|
||||
bool isQuaternionValid(const Quaternion& q);
|
||||
|
||||
/**
|
||||
* @brief Free dynamic memory held by an Order returned from convert2COrder
|
||||
* @param order Order to free (pointers and counts are zeroed)
|
||||
*/
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
#endif
|
||||
void order_free(Order* order);
|
||||
|
||||
#endif // C_API_CONVERTOR_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Accel.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Accel.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_ACCEL_H
|
||||
#define C_API_GEOMETRY_MSGS_ACCEL_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Vector3.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Vector3 linear;
|
||||
Vector3 angular;
|
||||
} Accel;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_ACCEL_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/AccelStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/AccelStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_ACCELSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_ACCELSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Accel.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Accel accel;
|
||||
} AccelStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_ACCELSTAMPED_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/AccelWithCovariance.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/AccelWithCovariance.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_ACCELWITHCOVARIANCE_H
|
||||
#define C_API_GEOMETRY_MSGS_ACCELWITHCOVARIANCE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Accel.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Accel accel;
|
||||
double covariance[36];
|
||||
} AccelWithCovariance;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_ACCELWITHCOVARIANCE_H
|
||||
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_ACCELWITHCOVARIANCESTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_ACCELWITHCOVARIANCESTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/AccelWithCovariance.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
AccelWithCovariance accel;
|
||||
} AccelWithCovarianceStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_ACCELWITHCOVARIANCESTAMPED_H
|
||||
28
src/APIs/c_api/include/geometry_msgs/Inertia.h
Normal file
28
src/APIs/c_api/include/geometry_msgs/Inertia.h
Normal file
@@ -0,0 +1,28 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_INERTIA_H
|
||||
#define C_API_GEOMETRY_MSGS_INERTIA_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Vector3.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double m;
|
||||
Vector3 com;
|
||||
double ixx;
|
||||
double ixy;
|
||||
double ixz;
|
||||
double iyy;
|
||||
double iyz;
|
||||
double izz;
|
||||
} Inertia;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_INERTIA_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/InertiaStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/InertiaStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_INERTIASTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_INERTIASTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Inertia.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Inertia inertia;
|
||||
} InertiaStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_INERTIASTAMPED_H
|
||||
21
src/APIs/c_api/include/geometry_msgs/Point.h
Normal file
21
src/APIs/c_api/include/geometry_msgs/Point.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POINT_H
|
||||
#define C_API_GEOMETRY_MSGS_POINT_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
} Point;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
#endif // C_API_GEOMETRY_MSGS_POINT_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Point32.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Point32.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POINT32_H
|
||||
#define C_API_GEOMETRY_MSGS_POINT32_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
float x;
|
||||
float y;
|
||||
float z;
|
||||
} Point32;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POINT32_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/PointStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/PointStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POINTSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_POINTSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Point.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Point point;
|
||||
} PointStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POINTSTAMPED_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Polygon.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Polygon.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POLYGON_H
|
||||
#define C_API_GEOMETRY_MSGS_POLYGON_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Point32.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Point32 *points;
|
||||
size_t points_count;
|
||||
} Polygon;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POLYGON_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/PolygonStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/PolygonStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POLYGONSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_POLYGONSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Polygon.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Polygon polygon;
|
||||
} PolygonStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POLYGONSTAMPED_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/Pose.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/Pose.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POSE_H
|
||||
#define C_API_GEOMETRY_MSGS_POSE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Point.h"
|
||||
#include "geometry_msgs/Quaternion.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Point position;
|
||||
Quaternion orientation;
|
||||
} Pose;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POSE_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Pose2D.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Pose2D.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POSE2D_H
|
||||
#define C_API_GEOMETRY_MSGS_POSE2D_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double x;
|
||||
double y;
|
||||
double theta;
|
||||
} Pose2D;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POSE2D_H
|
||||
24
src/APIs/c_api/include/geometry_msgs/PoseArray.h
Normal file
24
src/APIs/c_api/include/geometry_msgs/PoseArray.h
Normal file
@@ -0,0 +1,24 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POSEARRAY_H
|
||||
#define C_API_GEOMETRY_MSGS_POSEARRAY_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Pose.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Pose *poses;
|
||||
size_t poses_count;
|
||||
} PoseArray;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POSEARRAY_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/PoseStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/PoseStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POSESTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_POSESTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Pose.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Pose pose;
|
||||
} PoseStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POSESTAMPED_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/PoseWithCovariance.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/PoseWithCovariance.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POSEWITHCOVARIANCE_H
|
||||
#define C_API_GEOMETRY_MSGS_POSEWITHCOVARIANCE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Pose.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Pose pose;
|
||||
double *covariance;
|
||||
size_t covariance_count;
|
||||
} PoseWithCovariance;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POSEWITHCOVARIANCE_H
|
||||
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_POSEWITHCOVARIANCESTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_POSEWITHCOVARIANCESTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/PoseWithCovariance.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
PoseWithCovariance pose;
|
||||
} PoseWithCovarianceStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_POSEWITHCOVARIANCESTAMPED_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/Quaternion.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/Quaternion.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_QUATERNION_H
|
||||
#define C_API_GEOMETRY_MSGS_QUATERNION_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
double w;
|
||||
} Quaternion;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_QUATERNION_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/QuaternionStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/QuaternionStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_QUATERNIONSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_QUATERNIONSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Quaternion.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Quaternion quaternion;
|
||||
} QuaternionStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_QUATERNIONSTAMPED_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/Transform.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/Transform.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_TRANSFORM_H
|
||||
#define C_API_GEOMETRY_MSGS_TRANSFORM_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Vector3.h"
|
||||
#include "geometry_msgs/Quaternion.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Vector3 translation;
|
||||
Quaternion rotation;
|
||||
} Transform;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_TRANSFORM_H
|
||||
24
src/APIs/c_api/include/geometry_msgs/TransformStamped.h
Normal file
24
src/APIs/c_api/include/geometry_msgs/TransformStamped.h
Normal file
@@ -0,0 +1,24 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_TRANSFORMSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_TRANSFORMSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Transform.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
char *child_frame_id;
|
||||
Transform transform;
|
||||
} TransformStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_TRANSFORMSTAMPED_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Twist.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Twist.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_TWIST_H
|
||||
#define C_API_GEOMETRY_MSGS_TWIST_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Vector3.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Vector3 linear;
|
||||
Vector3 angular;
|
||||
} Twist;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_TWIST_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/TwistStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/TwistStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_TWISTSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_TWISTSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Twist.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Twist twist;
|
||||
} TwistStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_TWISTSTAMPED_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/TwistWithCovariance.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/TwistWithCovariance.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_TWISTWITHCOVARIANCE_H
|
||||
#define C_API_GEOMETRY_MSGS_TWISTWITHCOVARIANCE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Twist.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Twist twist;
|
||||
double *covariance;
|
||||
size_t covariance_count;
|
||||
} TwistWithCovariance;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_TWISTWITHCOVARIANCE_H
|
||||
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_TWISTWITHCOVARIANCESTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_TWISTWITHCOVARIANCESTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/TwistWithCovariance.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
TwistWithCovariance twist;
|
||||
} TwistWithCovarianceStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_TWISTWITHCOVARIANCESTAMPED_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Vector3.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Vector3.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_VECTOR3_H
|
||||
#define C_API_GEOMETRY_MSGS_VECTOR3_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
} Vector3;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_VECTOR3_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/Vector3Stamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/Vector3Stamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_VECTOR3STAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_VECTOR3STAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Vector3.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Vector3 vector;
|
||||
} Vector3Stamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_VECTOR3STAMPED_H
|
||||
22
src/APIs/c_api/include/geometry_msgs/Wrench.h
Normal file
22
src/APIs/c_api/include/geometry_msgs/Wrench.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_WRENCH_H
|
||||
#define C_API_GEOMETRY_MSGS_WRENCH_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/Vector3.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Vector3 force;
|
||||
Vector3 torque;
|
||||
} Wrench;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_WRENCH_H
|
||||
23
src/APIs/c_api/include/geometry_msgs/WrenchStamped.h
Normal file
23
src/APIs/c_api/include/geometry_msgs/WrenchStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_GEOMETRY_MSGS_WRENCHSTAMPED_H
|
||||
#define C_API_GEOMETRY_MSGS_WRENCHSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Wrench.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Wrench wrench;
|
||||
} WrenchStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_GEOMETRY_MSGS_WRENCHSTAMPED_H
|
||||
33
src/APIs/c_api/include/map_msgs/OccupancyGridUpdate.h
Normal file
33
src/APIs/c_api/include/map_msgs/OccupancyGridUpdate.h
Normal file
@@ -0,0 +1,33 @@
|
||||
#ifndef C_API_ROBOT_MAP_MSGS_OCCUPANCYGRIDUPDATE_C_H
|
||||
#define C_API_ROBOT_MAP_MSGS_OCCUPANCYGRIDUPDATE_C_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
|
||||
/**
|
||||
* C representation of robot_map_msgs::OccupancyGridUpdate.
|
||||
* Note: This header is intentionally named *_c.h to avoid
|
||||
* shadowing the C++ header `robot_map_msgs/OccupancyGridUpdate.h`.
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
int32_t x;
|
||||
int32_t y;
|
||||
uint32_t width;
|
||||
uint32_t height;
|
||||
int8_t *data;
|
||||
size_t data_count;
|
||||
} OccupancyGridUpdate;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_ROBOT_MAP_MSGS_OCCUPANCYGRIDUPDATE_C_H
|
||||
|
||||
23
src/APIs/c_api/include/nav_2d_msgs/ComplexPolygon2D.h
Normal file
23
src/APIs/c_api/include/nav_2d_msgs/ComplexPolygon2D.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_COMPLEXPOLYGON2D_H
|
||||
#define C_API_NAV_2D_MSGS_COMPLEXPOLYGON2D_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_2d_msgs/Polygon2D.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Polygon2D outer;
|
||||
Polygon2D *inner;
|
||||
size_t inner_count;
|
||||
} ComplexPolygon2D;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_COMPLEXPOLYGON2D_H
|
||||
25
src/APIs/c_api/include/nav_2d_msgs/NavGridInfo.h
Normal file
25
src/APIs/c_api/include/nav_2d_msgs/NavGridInfo.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_NAVGRIDINFO_H
|
||||
#define C_API_NAV_2D_MSGS_NAVGRIDINFO_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint32_t width;
|
||||
uint32_t height;
|
||||
double resolution;
|
||||
char *frame_id;
|
||||
double origin_x;
|
||||
double origin_y;
|
||||
} NavGridInfo;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_NAVGRIDINFO_H
|
||||
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfChars.h
Normal file
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfChars.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_NAVGRIDOFCHARS_H
|
||||
#define C_API_NAV_2D_MSGS_NAVGRIDOFCHARS_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Time.h"
|
||||
#include "nav_2d_msgs/NavGridInfo.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Time stamp;
|
||||
NavGridInfo info;
|
||||
uint8_t *data;
|
||||
size_t data_count;
|
||||
} NavGridOfChars;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_NAVGRIDOFCHARS_H
|
||||
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfCharsUpdate.h
Normal file
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfCharsUpdate.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_NAVGRIDOFCHARSUPDATE_H
|
||||
#define C_API_NAV_2D_MSGS_NAVGRIDOFCHARSUPDATE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Time.h"
|
||||
#include "nav_2d_msgs/UIntBounds.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Time stamp;
|
||||
UIntBounds bounds;
|
||||
uint8_t *data;
|
||||
size_t data_count;
|
||||
} NavGridOfCharsUpdate;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_NAVGRIDOFCHARSUPDATE_H
|
||||
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfDoubles.h
Normal file
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfDoubles.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_NAVGRIDOFDOUBLES_H
|
||||
#define C_API_NAV_2D_MSGS_NAVGRIDOFDOUBLES_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Time.h"
|
||||
#include "nav_2d_msgs/NavGridInfo.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Time stamp;
|
||||
NavGridInfo info;
|
||||
double *data;
|
||||
size_t data_count;
|
||||
} NavGridOfDoubles;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_NAVGRIDOFDOUBLES_H
|
||||
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfDoublesUpdate.h
Normal file
25
src/APIs/c_api/include/nav_2d_msgs/NavGridOfDoublesUpdate.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_NAVGRIDOFDOUBLESUPDATE_H
|
||||
#define C_API_NAV_2D_MSGS_NAVGRIDOFDOUBLESUPDATE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Time.h"
|
||||
#include "nav_2d_msgs/UIntBounds.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Time stamp;
|
||||
UIntBounds bounds;
|
||||
double *data;
|
||||
size_t data_count;
|
||||
} NavGridOfDoublesUpdate;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_NAVGRIDOFDOUBLESUPDATE_H
|
||||
24
src/APIs/c_api/include/nav_2d_msgs/Path2D.h
Normal file
24
src/APIs/c_api/include/nav_2d_msgs/Path2D.h
Normal file
@@ -0,0 +1,24 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_PATH2D_H
|
||||
#define C_API_NAV_2D_MSGS_PATH2D_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_2d_msgs/Pose2DStamped.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Pose2DStamped *poses;
|
||||
size_t poses_count;
|
||||
} Path2D;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_PATH2D_H
|
||||
21
src/APIs/c_api/include/nav_2d_msgs/Point2D.h
Normal file
21
src/APIs/c_api/include/nav_2d_msgs/Point2D.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_POINT2D_H
|
||||
#define C_API_NAV_2D_MSGS_POINT2D_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double x;
|
||||
double y;
|
||||
} Point2D;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_POINT2D_H
|
||||
22
src/APIs/c_api/include/nav_2d_msgs/Polygon2D.h
Normal file
22
src/APIs/c_api/include/nav_2d_msgs/Polygon2D.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_POLYGON2D_H
|
||||
#define C_API_NAV_2D_MSGS_POLYGON2D_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_2d_msgs/Point2D.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Point2D *points;
|
||||
size_t points_count;
|
||||
} Polygon2D;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_POLYGON2D_H
|
||||
27
src/APIs/c_api/include/nav_2d_msgs/Polygon2DCollection.h
Normal file
27
src/APIs/c_api/include/nav_2d_msgs/Polygon2DCollection.h
Normal file
@@ -0,0 +1,27 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_POLYGON2DCOLLECTION_H
|
||||
#define C_API_NAV_2D_MSGS_POLYGON2DCOLLECTION_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "std_msgs/ColorRGBA.h"
|
||||
#include "nav_2d_msgs/ComplexPolygon2D.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
ComplexPolygon2D *polygons;
|
||||
size_t polygons_count;
|
||||
ColorRGBA *colors;
|
||||
size_t colors_count;
|
||||
} Polygon2DCollection;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_POLYGON2DCOLLECTION_H
|
||||
23
src/APIs/c_api/include/nav_2d_msgs/Polygon2DStamped.h
Normal file
23
src/APIs/c_api/include/nav_2d_msgs/Polygon2DStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_POLYGON2DSTAMPED_H
|
||||
#define C_API_NAV_2D_MSGS_POLYGON2DSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_2d_msgs/Polygon2D.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Polygon2D polygon;
|
||||
} Polygon2DStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_POLYGON2DSTAMPED_H
|
||||
22
src/APIs/c_api/include/nav_2d_msgs/Pose2D32.h
Normal file
22
src/APIs/c_api/include/nav_2d_msgs/Pose2D32.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_POSE2D32_H
|
||||
#define C_API_NAV_2D_MSGS_POSE2D32_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
float x;
|
||||
float y;
|
||||
float theta;
|
||||
} Pose2D32;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_POSE2D32_H
|
||||
23
src/APIs/c_api/include/nav_2d_msgs/Pose2DStamped.h
Normal file
23
src/APIs/c_api/include/nav_2d_msgs/Pose2DStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_POSE2DSTAMPED_H
|
||||
#define C_API_NAV_2D_MSGS_POSE2DSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Pose2D.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Pose2D pose;
|
||||
} Pose2DStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_POSE2DSTAMPED_H
|
||||
23
src/APIs/c_api/include/nav_2d_msgs/SwitchPlugin.h
Normal file
23
src/APIs/c_api/include/nav_2d_msgs/SwitchPlugin.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_SWITCHPLUGIN_H
|
||||
#define C_API_NAV_2D_MSGS_SWITCHPLUGIN_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_2d_msgs/SwitchPluginRequest.h"
|
||||
#include "nav_2d_msgs/SwitchPluginResponse.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
SwitchPluginRequest request;
|
||||
SwitchPluginResponse response;
|
||||
} SwitchPlugin;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_SWITCHPLUGIN_H
|
||||
20
src/APIs/c_api/include/nav_2d_msgs/SwitchPluginRequest.h
Normal file
20
src/APIs/c_api/include/nav_2d_msgs/SwitchPluginRequest.h
Normal file
@@ -0,0 +1,20 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_SWITCHPLUGINREQUEST_H
|
||||
#define C_API_NAV_2D_MSGS_SWITCHPLUGINREQUEST_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
char *new_plugin;
|
||||
} SwitchPluginRequest;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_SWITCHPLUGINREQUEST_H
|
||||
21
src/APIs/c_api/include/nav_2d_msgs/SwitchPluginResponse.h
Normal file
21
src/APIs/c_api/include/nav_2d_msgs/SwitchPluginResponse.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_SWITCHPLUGINRESPONSE_H
|
||||
#define C_API_NAV_2D_MSGS_SWITCHPLUGINRESPONSE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint8_t success;
|
||||
char *message;
|
||||
} SwitchPluginResponse;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_SWITCHPLUGINRESPONSE_H
|
||||
22
src/APIs/c_api/include/nav_2d_msgs/Twist2D.h
Normal file
22
src/APIs/c_api/include/nav_2d_msgs/Twist2D.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_TWIST2D_H
|
||||
#define C_API_NAV_2D_MSGS_TWIST2D_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
double x;
|
||||
double y;
|
||||
double theta;
|
||||
} Twist2D;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_TWIST2D_H
|
||||
22
src/APIs/c_api/include/nav_2d_msgs/Twist2D32.h
Normal file
22
src/APIs/c_api/include/nav_2d_msgs/Twist2D32.h
Normal file
@@ -0,0 +1,22 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_TWIST2D32_H
|
||||
#define C_API_NAV_2D_MSGS_TWIST2D32_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
float x;
|
||||
float y;
|
||||
float theta;
|
||||
} Twist2D32;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_TWIST2D32_H
|
||||
23
src/APIs/c_api/include/nav_2d_msgs/Twist2DStamped.h
Normal file
23
src/APIs/c_api/include/nav_2d_msgs/Twist2DStamped.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_TWIST2DSTAMPED_H
|
||||
#define C_API_NAV_2D_MSGS_TWIST2DSTAMPED_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_2d_msgs/Twist2D.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
Twist2D velocity;
|
||||
} Twist2DStamped;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_TWIST2DSTAMPED_H
|
||||
23
src/APIs/c_api/include/nav_2d_msgs/UIntBounds.h
Normal file
23
src/APIs/c_api/include/nav_2d_msgs/UIntBounds.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_2D_MSGS_UINTBOUNDS_H
|
||||
#define C_API_NAV_2D_MSGS_UINTBOUNDS_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint32_t min_x;
|
||||
uint32_t min_y;
|
||||
uint32_t max_x;
|
||||
uint32_t max_y;
|
||||
} UIntBounds;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_2D_MSGS_UINTBOUNDS_H
|
||||
@@ -2,372 +2,481 @@
|
||||
#define NAVIGATION_C_API_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
extern "C"
|
||||
{
|
||||
#endif
|
||||
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include <stdbool.h>
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
/* C struct types only - do not include convertor.h here (it pulls C++ code into extern "C") */
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Point.h"
|
||||
#include "geometry_msgs/Pose2D.h"
|
||||
#include "geometry_msgs/PoseStamped.h"
|
||||
#include "nav_msgs/OccupancyGrid.h"
|
||||
#include "nav_msgs/Odometry.h"
|
||||
#include "map_msgs/OccupancyGridUpdate.h"
|
||||
#include "nav_2d_msgs/Twist2D.h"
|
||||
#include "nav_2d_msgs/Twist2DStamped.h"
|
||||
#include "nav_2d_msgs/Path2D.h"
|
||||
#include "sensor_msgs/LaserScan.h"
|
||||
#include "sensor_msgs/PointCloud.h"
|
||||
#include "sensor_msgs/PointCloud2.h"
|
||||
#include "geometry_msgs/PolygonStamped.h"
|
||||
#include "protocol_msgs/Order.h"
|
||||
|
||||
// Forward declarations
|
||||
typedef void* NavigationHandle;
|
||||
typedef void* TFListenerHandle;
|
||||
typedef struct { char *name; OccupancyGrid grid; } NamedOccupancyGrid;
|
||||
typedef struct { char *name; LaserScan scan; } NamedLaserScan;
|
||||
typedef struct { char *name; PointCloud cloud; } NamedPointCloud;
|
||||
typedef struct { char *name; PointCloud2 cloud; } NamedPointCloud2;
|
||||
typedef void* NavigationHandle;
|
||||
typedef void* TFListenerHandle;
|
||||
|
||||
// ============================================================================
|
||||
// Enums
|
||||
// ============================================================================
|
||||
typedef enum
|
||||
{
|
||||
PENDING = 0,
|
||||
ACTIVE = 1,
|
||||
PREEMPTED = 2,
|
||||
SUCCEEDED = 3,
|
||||
ABORTED = 4,
|
||||
REJECTED = 5,
|
||||
PREEMPTING = 6,
|
||||
RECALLING = 7,
|
||||
RECALLED = 8,
|
||||
LOST = 9,
|
||||
PLANNING = 10,
|
||||
CONTROLLING = 11,
|
||||
CLEARING = 12,
|
||||
PAUSED = 13
|
||||
} NavigationState;
|
||||
|
||||
/**
|
||||
* @brief Navigation states, including planning and controller status
|
||||
*/
|
||||
typedef enum {
|
||||
NAV_STATE_PENDING = 0,
|
||||
NAV_STATE_ACTIVE = 1,
|
||||
NAV_STATE_PREEMPTED = 2,
|
||||
NAV_STATE_SUCCEEDED = 3,
|
||||
NAV_STATE_ABORTED = 4,
|
||||
NAV_STATE_REJECTED = 5,
|
||||
NAV_STATE_PREEMPTING = 6,
|
||||
NAV_STATE_RECALLING = 7,
|
||||
NAV_STATE_RECALLED = 8,
|
||||
NAV_STATE_LOST = 9,
|
||||
NAV_STATE_PLANNING = 10,
|
||||
NAV_STATE_CONTROLLING = 11,
|
||||
NAV_STATE_CLEARING = 12,
|
||||
NAV_STATE_PAUSED = 13
|
||||
} NavigationState;
|
||||
|
||||
// ============================================================================
|
||||
// Structures
|
||||
// ============================================================================
|
||||
|
||||
/**
|
||||
* @brief Point structure (x, y, z)
|
||||
*/
|
||||
typedef struct {
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
} Point;
|
||||
|
||||
/**
|
||||
* @brief Pose2D structure (x, y, theta)
|
||||
*/
|
||||
typedef struct {
|
||||
double x;
|
||||
double y;
|
||||
double theta;
|
||||
} Pose2D;
|
||||
|
||||
/**
|
||||
* @brief Quaternion structure
|
||||
*/
|
||||
typedef struct {
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
double w;
|
||||
} Quaternion;
|
||||
|
||||
/**
|
||||
* @brief Position structure
|
||||
*/
|
||||
typedef struct {
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
} Position;
|
||||
|
||||
/**
|
||||
* @brief Pose structure
|
||||
*/
|
||||
typedef struct {
|
||||
Position position;
|
||||
Quaternion orientation;
|
||||
} Pose;
|
||||
|
||||
/**
|
||||
* @brief Header structure
|
||||
*/
|
||||
typedef struct {
|
||||
uint32_t seq;
|
||||
int64_t sec;
|
||||
uint32_t nsec;
|
||||
char* frame_id;
|
||||
} Header;
|
||||
|
||||
/**
|
||||
* @brief PoseStamped structure
|
||||
*/
|
||||
typedef struct {
|
||||
Header header;
|
||||
Pose pose;
|
||||
} PoseStamped;
|
||||
|
||||
/**
|
||||
* @brief Vector3 structure
|
||||
*/
|
||||
typedef struct {
|
||||
double x;
|
||||
double y;
|
||||
double z;
|
||||
} Vector3;
|
||||
|
||||
/**
|
||||
* @brief Navigation feedback structure
|
||||
*/
|
||||
typedef struct {
|
||||
typedef struct
|
||||
{
|
||||
NavigationState navigation_state;
|
||||
char* feed_back_str;
|
||||
char *feed_back_str;
|
||||
Pose2D current_pose;
|
||||
bool goal_checked;
|
||||
bool is_ready;
|
||||
} NavFeedback;
|
||||
} NavFeedback;
|
||||
|
||||
// ============================================================================
|
||||
// String Management
|
||||
// ============================================================================
|
||||
/**
|
||||
* @brief Planner data output structure (C version).
|
||||
* Mirrors robot::move_base_core::PlannerDataOutput in `move_base_core/navigation.h`.
|
||||
*/
|
||||
typedef struct
|
||||
{
|
||||
Path2D plan;
|
||||
OccupancyGrid costmap;
|
||||
OccupancyGridUpdate costmap_update;
|
||||
bool is_costmap_updated;
|
||||
PolygonStamped footprint;
|
||||
} PlannerDataOutput;
|
||||
|
||||
/**
|
||||
* @brief Free a string allocated by the library
|
||||
* @param str String to free
|
||||
*/
|
||||
void nav_c_api_free_string(char* str);
|
||||
/**
|
||||
* @brief Free a string allocated by the API (e.g. feed_back_str, navigation_state_to_string result).
|
||||
* @param str Pointer from strdup; no-op if NULL.
|
||||
*/
|
||||
void nav_c_api_free_string(char *str);
|
||||
|
||||
// ============================================================================
|
||||
// State Conversion
|
||||
// ============================================================================
|
||||
/**
|
||||
* @brief Create a new navigation instance
|
||||
* @return Navigation handle, or NULL on failure
|
||||
*/
|
||||
NavigationHandle navigation_create(void);
|
||||
|
||||
/**
|
||||
* @brief Convert a State enum to its string representation
|
||||
* @param state Enum value of NavigationState
|
||||
* @return String representation (caller must free with nav_c_api_free_string)
|
||||
*/
|
||||
char* navigation_state_to_string(NavigationState state);
|
||||
/**
|
||||
* @brief Destroy a navigation instance
|
||||
* @param handle Navigation handle to destroy
|
||||
*/
|
||||
void navigation_destroy(NavigationHandle handle);
|
||||
|
||||
// ============================================================================
|
||||
// Helper Functions
|
||||
// ============================================================================
|
||||
// ============================================================================
|
||||
// Navigation Interface Methods
|
||||
// ============================================================================
|
||||
|
||||
/**
|
||||
* @brief Creates a target pose by offsetting a given 2D pose along its heading direction
|
||||
* @param pose_x X coordinate of the original pose
|
||||
* @param pose_y Y coordinate of the original pose
|
||||
* @param pose_theta Heading angle in radians
|
||||
* @param frame_id The coordinate frame ID (null-terminated string)
|
||||
* @param offset_distance Distance to offset along heading (positive = forward, negative = backward)
|
||||
* @param out_goal Output parameter for the offset pose
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_offset_goal_2d(double pose_x, double pose_y, double pose_theta,
|
||||
const char* frame_id, double offset_distance,
|
||||
PoseStamped* out_goal);
|
||||
/**
|
||||
* @brief Initialize the navigation system using an existing tf3 buffer (from libtf3 tf3_buffer_create).
|
||||
* Caller retains ownership of the buffer and must call tf3_buffer_destroy when done (after navigation_destroy).
|
||||
* @param handle Navigation handle
|
||||
* @param tf3_buffer Pointer to tf3 BufferCore (TF3_BufferCore from libtf3)
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_initialize(NavigationHandle handle, TFListenerHandle tf3_buffer);
|
||||
|
||||
/**
|
||||
* @brief Creates an offset target pose from a given PoseStamped
|
||||
* @param in_pose Input pose
|
||||
* @param offset_distance Distance to offset along heading direction
|
||||
* @param out_goal Output parameter for the offset pose
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_offset_goal_stamped(const PoseStamped* in_pose, double offset_distance,
|
||||
PoseStamped* out_goal);
|
||||
/**
|
||||
* @brief Set the robot's footprint (outline shape)
|
||||
* @param handle Navigation handle
|
||||
* @param points Array of points representing the footprint polygon
|
||||
* @param point_count Number of points in the array
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_set_robot_footprint(NavigationHandle handle, const Point *points, size_t point_count);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Handle Management
|
||||
// ============================================================================
|
||||
/**
|
||||
* @brief Get the robot's footprint (outline shape)
|
||||
* @param handle Navigation handle
|
||||
* @param out_points Output array of points (allocated by library, free with navigation_free_points)
|
||||
* @param out_count Output number of points in the array
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_get_robot_footprint(NavigationHandle handle, Point *out_points, size_t &out_count);
|
||||
|
||||
/**
|
||||
* @brief Create a new navigation instance
|
||||
* @return Navigation handle, or NULL on failure
|
||||
*/
|
||||
NavigationHandle navigation_create(void);
|
||||
|
||||
/**
|
||||
* @brief Destroy a navigation instance
|
||||
* @param handle Navigation handle to destroy
|
||||
*/
|
||||
void navigation_destroy(NavigationHandle handle);
|
||||
/**
|
||||
* @brief Send a goal for the robot to navigate to
|
||||
* @param handle Navigation handle
|
||||
* @param goal Target pose in the global frame
|
||||
* @return true if goal was accepted and sent successfully
|
||||
*/
|
||||
bool navigation_move_to(NavigationHandle handle, const PoseStamped goal);
|
||||
|
||||
// ============================================================================
|
||||
// TF Listener Management
|
||||
// ============================================================================
|
||||
/**
|
||||
* @brief Send a goal for the robot to navigate to
|
||||
* @param handle Navigation handle
|
||||
* @param order Order message
|
||||
* @param goal Target pose in the global frame
|
||||
* @return true if goal was accepted and sent successfully
|
||||
* @note If order was obtained from convert2COrder(), call order_free(&order) when done
|
||||
*/
|
||||
bool navigation_move_to_order(NavigationHandle handle, const Order order, const PoseStamped goal);
|
||||
|
||||
/**
|
||||
* @brief Create a TF listener instance
|
||||
* @return TF listener handle, or NULL on failure
|
||||
*/
|
||||
TFListenerHandle tf_listener_create(void);
|
||||
/**
|
||||
* @brief Send a goal for the robot to navigate to
|
||||
* @param handle Navigation handle
|
||||
* @param nodes Nodes array
|
||||
* @param node_count Number of nodes in the array
|
||||
* @param edges Edges array
|
||||
* @param edge_count Number of edges in the array
|
||||
* @param goal Target pose in the global frame
|
||||
* @return true if goal was accepted and sent successfully
|
||||
*/
|
||||
bool navigation_move_to_nodes_edges(NavigationHandle handle, const Node *nodes, size_t node_count, const Edge *edges, size_t edge_count, const PoseStamped goal);
|
||||
|
||||
/**
|
||||
* @brief Destroy a TF listener instance
|
||||
* @param handle TF listener handle to destroy
|
||||
*/
|
||||
void tf_listener_destroy(TFListenerHandle handle);
|
||||
/**
|
||||
* @brief Send a docking goal to a predefined marker
|
||||
* @param handle Navigation handle
|
||||
* @param marker Marker name or ID (null-terminated string)
|
||||
* @param goal Target pose for docking
|
||||
* @return true if docking command succeeded
|
||||
*/
|
||||
bool navigation_dock_to(NavigationHandle handle, const char *marker, const PoseStamped goal);
|
||||
|
||||
/**
|
||||
* @brief Inject a static transform into the TF buffer.
|
||||
*
|
||||
* This is a convenience for standalone usage where no external TF publisher exists yet.
|
||||
* It will create/ensure the frames exist and become transformable.
|
||||
*
|
||||
* @param tf_handle TF listener handle
|
||||
* @param parent_frame Parent frame id (e.g. "map")
|
||||
* @param child_frame Child frame id (e.g. "base_link")
|
||||
* @param x Translation x (meters)
|
||||
* @param y Translation y (meters)
|
||||
* @param z Translation z (meters)
|
||||
* @param qx Rotation quaternion x
|
||||
* @param qy Rotation quaternion y
|
||||
* @param qz Rotation quaternion z
|
||||
* @param qw Rotation quaternion w
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool tf_listener_set_static_transform(TFListenerHandle tf_handle,
|
||||
const char* parent_frame,
|
||||
const char* child_frame,
|
||||
double x, double y, double z,
|
||||
double qx, double qy, double qz, double qw);
|
||||
/**
|
||||
* @brief Send a docking goal to a predefined marker
|
||||
* @param handle Navigation handle
|
||||
* @param order Order message
|
||||
* @param goal Target pose for docking
|
||||
* @return true if docking command succeeded
|
||||
*/
|
||||
bool navigation_dock_to_order(NavigationHandle handle, const Order order, const char *marker, const PoseStamped goal);
|
||||
|
||||
// ============================================================================
|
||||
// Navigation Interface Methods
|
||||
// ============================================================================
|
||||
/**
|
||||
* @brief Send a goal for the robot to navigate to
|
||||
* @param handle Navigation handle
|
||||
* @param marker Marker name or ID (null-terminated string)
|
||||
* @param nodes Nodes array
|
||||
* @param node_count Number of nodes in the array
|
||||
* @param edges Edges array
|
||||
* @param edge_count Number of edges in the array
|
||||
* @param goal Target pose in the global frame
|
||||
* @return true if goal was accepted and sent successfully
|
||||
*/
|
||||
bool navigation_dock_to_nodes_edges(NavigationHandle handle, const char *marker, const Node *nodes, size_t node_count, const Edge *edges, size_t edge_count, const PoseStamped goal);
|
||||
|
||||
/**
|
||||
* @brief Initialize the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param tf_handle TF listener handle
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_initialize(NavigationHandle handle, TFListenerHandle tf_handle);
|
||||
|
||||
/**
|
||||
* @brief Set the robot's footprint (outline shape)
|
||||
* @param handle Navigation handle
|
||||
* @param points Array of points representing the footprint polygon
|
||||
* @param point_count Number of points in the array
|
||||
* @return true on success, false on failure
|
||||
*/
|
||||
bool navigation_set_robot_footprint(NavigationHandle handle, const Point* points, size_t point_count);
|
||||
/**
|
||||
* @brief Move straight toward the target position
|
||||
* @param handle Navigation handle
|
||||
* @param distance Distance to move (meters)
|
||||
* @return true if command issued successfully
|
||||
*/
|
||||
bool navigation_move_straight_to(NavigationHandle handle, const double distance);
|
||||
|
||||
/**
|
||||
* @brief Send a goal for the robot to navigate to
|
||||
* @param handle Navigation handle
|
||||
* @param goal Target pose in the global frame
|
||||
* @param xy_goal_tolerance Acceptable error in X/Y (meters)
|
||||
* @param yaw_goal_tolerance Acceptable angular error (radians)
|
||||
* @return true if goal was accepted and sent successfully
|
||||
*/
|
||||
bool navigation_move_to(NavigationHandle handle, const PoseStamped* goal,
|
||||
double xy_goal_tolerance, double yaw_goal_tolerance);
|
||||
/**
|
||||
* @brief Rotate in place to align with target orientation
|
||||
* @param handle Navigation handle
|
||||
* @param goal_yaw Desired heading (radians)
|
||||
* @return true if rotation command was sent successfully
|
||||
*/
|
||||
bool navigation_rotate_to(NavigationHandle handle, const PoseStamped goal);
|
||||
|
||||
/**
|
||||
* @brief Send a docking goal to a predefined marker
|
||||
* @param handle Navigation handle
|
||||
* @param marker Marker name or ID (null-terminated string)
|
||||
* @param goal Target pose for docking
|
||||
* @param xy_goal_tolerance Acceptable XY error (meters)
|
||||
* @param yaw_goal_tolerance Acceptable heading error (radians)
|
||||
* @return true if docking command succeeded
|
||||
*/
|
||||
bool navigation_dock_to(NavigationHandle handle, const char* marker,
|
||||
const PoseStamped* goal,
|
||||
double xy_goal_tolerance, double yaw_goal_tolerance);
|
||||
/**
|
||||
* @brief Pause the robot's movement
|
||||
* @param handle Navigation handle
|
||||
*/
|
||||
void navigation_pause(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Move straight toward the target position
|
||||
* @param handle Navigation handle
|
||||
* @param goal Target pose
|
||||
* @param xy_goal_tolerance Acceptable positional error (meters)
|
||||
* @return true if command issued successfully
|
||||
*/
|
||||
bool navigation_move_straight_to(NavigationHandle handle, const PoseStamped* goal,
|
||||
double xy_goal_tolerance);
|
||||
/**
|
||||
* @brief Resume motion after a pause
|
||||
* @param handle Navigation handle
|
||||
*/
|
||||
void navigation_resume(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Rotate in place to align with target orientation
|
||||
* @param handle Navigation handle
|
||||
* @param goal Pose containing desired heading (only Z-axis used)
|
||||
* @param yaw_goal_tolerance Acceptable angular error (radians)
|
||||
* @return true if rotation command was sent successfully
|
||||
*/
|
||||
bool navigation_rotate_to(NavigationHandle handle, const PoseStamped* goal,
|
||||
double yaw_goal_tolerance);
|
||||
/**
|
||||
* @brief Cancel the current goal and stop the robot
|
||||
* @param handle Navigation handle
|
||||
*/
|
||||
void navigation_cancel(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Pause the robot's movement
|
||||
* @param handle Navigation handle
|
||||
*/
|
||||
void navigation_pause(NavigationHandle handle);
|
||||
/**
|
||||
* @brief Send limited linear velocity command
|
||||
* @param handle Navigation handle
|
||||
* @param linear_x Linear velocity in X direction
|
||||
* @param linear_y Linear velocity in Y direction
|
||||
* @param linear_z Linear velocity in Z direction
|
||||
* @return true if the command was accepted
|
||||
*/
|
||||
bool navigation_set_twist_linear(NavigationHandle handle,
|
||||
double linear_x, double linear_y, double linear_z);
|
||||
|
||||
/**
|
||||
* @brief Resume motion after a pause
|
||||
* @param handle Navigation handle
|
||||
*/
|
||||
void navigation_resume(NavigationHandle handle);
|
||||
/**
|
||||
* @brief Send limited angular velocity command
|
||||
* @param handle Navigation handle
|
||||
* @param angular_x Angular velocity around X axis
|
||||
* @param angular_y Angular velocity around Y axis
|
||||
* @param angular_z Angular velocity around Z axis
|
||||
* @return true if the command was accepted
|
||||
*/
|
||||
bool navigation_set_twist_angular(NavigationHandle handle,
|
||||
double angular_x, double angular_y, double angular_z);
|
||||
|
||||
/**
|
||||
* @brief Cancel the current goal and stop the robot
|
||||
* @param handle Navigation handle
|
||||
*/
|
||||
void navigation_cancel(NavigationHandle handle);
|
||||
/**
|
||||
* @brief Get the robot's pose as a PoseStamped
|
||||
* @param handle Navigation handle
|
||||
* @param out_pose Output parameter with the robot's current pose
|
||||
* @return true if pose was successfully retrieved
|
||||
*/
|
||||
bool navigation_get_robot_pose_stamped(NavigationHandle handle, PoseStamped &out_pose);
|
||||
|
||||
/**
|
||||
* @brief Send limited linear velocity command
|
||||
* @param handle Navigation handle
|
||||
* @param linear_x Linear velocity in X direction
|
||||
* @param linear_y Linear velocity in Y direction
|
||||
* @param linear_z Linear velocity in Z direction
|
||||
* @return true if the command was accepted
|
||||
*/
|
||||
bool navigation_set_twist_linear(NavigationHandle handle,
|
||||
double linear_x, double linear_y, double linear_z);
|
||||
/**
|
||||
* @brief Get the robot's pose as a 2D pose
|
||||
* @param handle Navigation handle
|
||||
* @param out_pose Output parameter with the robot's current 2D pose
|
||||
* @return true if pose was successfully retrieved
|
||||
*/
|
||||
bool navigation_get_robot_pose_2d(NavigationHandle handle, Pose2D &out_pose);
|
||||
|
||||
/**
|
||||
* @brief Send limited angular velocity command
|
||||
* @param handle Navigation handle
|
||||
* @param angular_x Angular velocity around X axis
|
||||
* @param angular_y Angular velocity around Y axis
|
||||
* @param angular_z Angular velocity around Z axis
|
||||
* @return true if the command was accepted
|
||||
*/
|
||||
bool navigation_set_twist_angular(NavigationHandle handle,
|
||||
double angular_x, double angular_y, double angular_z);
|
||||
/**
|
||||
* @brief Get the robot's current twist
|
||||
* @param handle Navigation handle
|
||||
* @param out_twist Output parameter with the robot's current twist
|
||||
* @return true if twist was successfully retrieved
|
||||
* @note out_twist->header.frame_id must be freed using nav_c_api_free_string
|
||||
*/
|
||||
bool navigation_get_twist(NavigationHandle handle, Twist2DStamped &out_twist);
|
||||
|
||||
/**
|
||||
* @brief Get the robot's pose as a PoseStamped
|
||||
* @param handle Navigation handle
|
||||
* @param out_pose Output parameter with the robot's current pose
|
||||
* @return true if pose was successfully retrieved
|
||||
*/
|
||||
bool navigation_get_robot_pose_stamped(NavigationHandle handle, PoseStamped* out_pose);
|
||||
/**
|
||||
* @brief Get navigation feedback
|
||||
* @param handle Navigation handle
|
||||
* @param out_feedback Output parameter with navigation feedback
|
||||
* @return true if feedback was successfully retrieved
|
||||
* @note The feed_back_str field must be freed using nav_c_api_free_string
|
||||
*/
|
||||
bool navigation_get_feedback(NavigationHandle handle, NavFeedback &out_feedback);
|
||||
|
||||
/**
|
||||
* @brief Get the robot's pose as a 2D pose
|
||||
* @param handle Navigation handle
|
||||
* @param out_pose Output parameter with the robot's current 2D pose
|
||||
* @return true if pose was successfully retrieved
|
||||
*/
|
||||
bool navigation_get_robot_pose_2d(NavigationHandle handle, Pose2D* out_pose);
|
||||
/**
|
||||
* @brief Add a static map to the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param map_name Name of the map
|
||||
* @param map Occupancy grid handle
|
||||
* @return true if the map was added successfully
|
||||
*/
|
||||
bool navigation_add_static_map(NavigationHandle handle, const char *map_name, const OccupancyGrid occupancy_grid);
|
||||
|
||||
/**
|
||||
* @brief Get navigation feedback
|
||||
* @param handle Navigation handle
|
||||
* @param out_feedback Output parameter with navigation feedback
|
||||
* @return true if feedback was successfully retrieved
|
||||
* @note The feed_back_str field must be freed using nav_c_api_free_string
|
||||
*/
|
||||
bool navigation_get_feedback(NavigationHandle handle, NavFeedback* out_feedback);
|
||||
/**
|
||||
* @brief Add a laser scan to the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param laser_scan_name Name of the laser scan
|
||||
* @param laser_scan Laser scan handle
|
||||
* @return true if the laser scan was added successfully
|
||||
*/
|
||||
bool navigation_add_laser_scan(NavigationHandle handle, const char *laser_scan_name, const LaserScan laser_scan);
|
||||
|
||||
/**
|
||||
* @brief Free navigation feedback structure
|
||||
* @param feedback Feedback structure to free
|
||||
*/
|
||||
void navigation_free_feedback(NavFeedback* feedback);
|
||||
/**
|
||||
* @brief Add a point cloud to the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param point_cloud_name Name of the point cloud
|
||||
* @param point_cloud Point cloud handle
|
||||
* @return true if the point cloud was added successfully
|
||||
*/
|
||||
bool navigation_add_point_cloud(NavigationHandle handle, const char *point_cloud_name, const PointCloud point_cloud);
|
||||
|
||||
/**
|
||||
* @brief Add a point cloud2 to the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param point_cloud2_name Name of the point cloud2
|
||||
* @param point_cloud2 Point cloud2 handle
|
||||
* @return true if the point cloud2 was added successfully
|
||||
*/
|
||||
bool navigation_add_point_cloud2(NavigationHandle handle, const char *point_cloud2_name, const PointCloud2 point_cloud2);
|
||||
|
||||
/**
|
||||
* @brief Add an odometry to the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param odometry_name Name of the odometry
|
||||
* @param odometry Odometry handle
|
||||
* @return true if the odometry was added successfully
|
||||
*/
|
||||
bool navigation_add_odometry(NavigationHandle handle, const char *odometry_name, const Odometry odometry);
|
||||
|
||||
/**
|
||||
* @brief Get a static map from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param map_name Name of the map
|
||||
* @param out_map Output parameter for the map handle
|
||||
* @return true if the map was retrieved successfully
|
||||
*/
|
||||
bool navigation_get_static_map(NavigationHandle handle, const char *map_name, OccupancyGrid &out_map);
|
||||
|
||||
/**
|
||||
* @brief Get a laser scan from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param laser_scan_name Name of the laser scan
|
||||
* @param out_scan Output parameter for the laser scan handle
|
||||
* @return true if the laser scan was retrieved successfully
|
||||
*/
|
||||
bool navigation_get_laser_scan(NavigationHandle handle, const char *laser_scan_name, LaserScan &out_scan);
|
||||
|
||||
/**
|
||||
* @brief Get a point cloud from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param point_cloud_name Name of the point cloud
|
||||
* @param out_cloud Output parameter for the point cloud handle
|
||||
* @return true if the point cloud was retrieved successfully
|
||||
*/
|
||||
bool navigation_get_point_cloud(NavigationHandle handle, const char *point_cloud_name, PointCloud &out_cloud);
|
||||
|
||||
/**
|
||||
* @brief Get a point cloud2 from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param point_cloud2_name Name of the point cloud2
|
||||
* @param out_cloud Output parameter for the point cloud2 handle
|
||||
* @return true if the point cloud2 was retrieved successfully
|
||||
*/
|
||||
bool navigation_get_point_cloud2(NavigationHandle handle, const char *point_cloud2_name, PointCloud2 &out_cloud);
|
||||
|
||||
/**
|
||||
* @brief Get all static maps from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param out_maps Output parameter for the maps array
|
||||
* @param out_count Output parameter for the number of maps
|
||||
* @return true if the maps were retrieved successfully
|
||||
*/
|
||||
bool navigation_get_all_static_maps(NavigationHandle handle, NamedOccupancyGrid *out_maps, size_t &out_count);
|
||||
|
||||
/**
|
||||
* @brief Get all laser scans from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param out_scans Output parameter for the scans array
|
||||
* @param out_count Output parameter for the number of scans
|
||||
* @return true if the scans were retrieved successfully
|
||||
*/
|
||||
bool navigation_get_all_laser_scans(NavigationHandle handle, NamedLaserScan *out_scans, size_t &out_count);
|
||||
|
||||
/**
|
||||
* @brief Get all point clouds from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param out_clouds Output parameter for the clouds array
|
||||
* @param out_count Output parameter for the number of clouds
|
||||
* @return true if the clouds were retrieved successfully
|
||||
*/
|
||||
bool navigation_get_all_point_clouds(NavigationHandle handle, NamedPointCloud *out_clouds, size_t &out_count);
|
||||
|
||||
/**
|
||||
* @brief Get all point cloud2s from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param out_clouds Output parameter for the clouds array
|
||||
* @param out_count Output parameter for the number of clouds
|
||||
* @return true if the clouds were retrieved successfully
|
||||
*/
|
||||
bool navigation_get_all_point_cloud2s(NavigationHandle handle, NamedPointCloud2 *out_clouds, size_t &out_count);
|
||||
|
||||
/**
|
||||
* @brief Remove a static map from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param map_name Name of the map
|
||||
* @return true if the map was removed successfully
|
||||
*/
|
||||
bool navigation_remove_static_map(NavigationHandle handle, const char *map_name);
|
||||
|
||||
/**
|
||||
* @brief Remove a laser scan from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param laser_scan_name Name of the laser scan
|
||||
* @return true if the laser scan was removed successfully
|
||||
*/
|
||||
bool navigation_remove_laser_scan(NavigationHandle handle, const char *laser_scan_name);
|
||||
|
||||
/**
|
||||
* @brief Remove a point cloud from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param point_cloud_name Name of the point cloud
|
||||
* @return true if the point cloud was removed successfully
|
||||
*/
|
||||
bool navigation_remove_point_cloud(NavigationHandle handle, const char *point_cloud_name);
|
||||
|
||||
/**
|
||||
* @brief Remove a point cloud2 from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param point_cloud2_name Name of the point cloud2
|
||||
* @return true if the point cloud2 was removed successfully
|
||||
*/
|
||||
bool navigation_remove_point_cloud2(NavigationHandle handle, const char *point_cloud2_name);
|
||||
|
||||
/**
|
||||
* @brief Remove all static maps from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @return true if the maps were removed successfully
|
||||
*/
|
||||
bool navigation_remove_all_static_maps(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Remove all laser scans from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @return true if the scans were removed successfully
|
||||
*/
|
||||
bool navigation_remove_all_laser_scans(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Remove all point clouds from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @return true if the clouds were removed successfully
|
||||
*/
|
||||
bool navigation_remove_all_point_clouds(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Remove all point cloud2s from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @return true if the cloud2s were removed successfully
|
||||
*/
|
||||
bool navigation_remove_all_point_cloud2s(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Remove all data from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @return true if the data was removed successfully
|
||||
*/
|
||||
bool navigation_remove_all_data(NavigationHandle handle);
|
||||
|
||||
/**
|
||||
* @brief Get the global data from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param out_data Output parameter for the data
|
||||
* @return true if the data was retrieved successfully
|
||||
*/
|
||||
bool navigation_get_global_data(NavigationHandle handle, PlannerDataOutput *out_data);
|
||||
|
||||
/**
|
||||
* @brief Get the local data from the navigation system
|
||||
* @param handle Navigation handle
|
||||
* @param out_data Output parameter for the data
|
||||
* @return true if the data was retrieved successfully
|
||||
*/
|
||||
bool navigation_get_local_data(NavigationHandle handle, PlannerDataOutput *out_data);
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // NAVIGATION_C_API_H
|
||||
|
||||
|
||||
29
src/APIs/c_api/include/nav_msgs/ActionTypes.h
Normal file
29
src/APIs/c_api/include/nav_msgs/ActionTypes.h
Normal file
@@ -0,0 +1,29 @@
|
||||
#ifndef C_API_NAV_MSGS_ACTIONTYPES_H
|
||||
#define C_API_NAV_MSGS_ACTIONTYPES_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Time.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Time stamp;
|
||||
char *id;
|
||||
} GoalID;
|
||||
|
||||
typedef struct
|
||||
{
|
||||
GoalID goal_id;
|
||||
uint8_t status;
|
||||
char *text;
|
||||
} GoalStatus;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_ACTIONTYPES_H
|
||||
23
src/APIs/c_api/include/nav_msgs/GetMap.h
Normal file
23
src/APIs/c_api/include/nav_msgs/GetMap.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAP_H
|
||||
#define C_API_NAV_MSGS_GETMAP_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/GetMapRequest.h"
|
||||
#include "nav_msgs/GetMapResponse.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
GetMapRequest request;
|
||||
GetMapResponse response;
|
||||
} GetMap;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAP_H
|
||||
25
src/APIs/c_api/include/nav_msgs/GetMapAction.h
Normal file
25
src/APIs/c_api/include/nav_msgs/GetMapAction.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPACTION_H
|
||||
#define C_API_NAV_MSGS_GETMAPACTION_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/GetMapActionGoal.h"
|
||||
#include "nav_msgs/GetMapActionResult.h"
|
||||
#include "nav_msgs/GetMapActionFeedback.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
GetMapActionGoal action_goal;
|
||||
GetMapActionResult action_result;
|
||||
GetMapActionFeedback action_feedback;
|
||||
} GetMapAction;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPACTION_H
|
||||
25
src/APIs/c_api/include/nav_msgs/GetMapActionFeedback.h
Normal file
25
src/APIs/c_api/include/nav_msgs/GetMapActionFeedback.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPACTIONFEEDBACK_H
|
||||
#define C_API_NAV_MSGS_GETMAPACTIONFEEDBACK_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_msgs/ActionTypes.h"
|
||||
#include "nav_msgs/GetMapFeedback.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
GoalStatus status;
|
||||
GetMapFeedback feedback;
|
||||
} GetMapActionFeedback;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPACTIONFEEDBACK_H
|
||||
25
src/APIs/c_api/include/nav_msgs/GetMapActionGoal.h
Normal file
25
src/APIs/c_api/include/nav_msgs/GetMapActionGoal.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPACTIONGOAL_H
|
||||
#define C_API_NAV_MSGS_GETMAPACTIONGOAL_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_msgs/ActionTypes.h"
|
||||
#include "nav_msgs/GetMapGoal.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
GoalID goal_id;
|
||||
GetMapGoal goal;
|
||||
} GetMapActionGoal;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPACTIONGOAL_H
|
||||
25
src/APIs/c_api/include/nav_msgs/GetMapActionResult.h
Normal file
25
src/APIs/c_api/include/nav_msgs/GetMapActionResult.h
Normal file
@@ -0,0 +1,25 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPACTIONRESULT_H
|
||||
#define C_API_NAV_MSGS_GETMAPACTIONRESULT_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "nav_msgs/ActionTypes.h"
|
||||
#include "nav_msgs/GetMapResult.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
GoalStatus status;
|
||||
GetMapResult result;
|
||||
} GetMapActionResult;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPACTIONRESULT_H
|
||||
20
src/APIs/c_api/include/nav_msgs/GetMapFeedback.h
Normal file
20
src/APIs/c_api/include/nav_msgs/GetMapFeedback.h
Normal file
@@ -0,0 +1,20 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPFEEDBACK_H
|
||||
#define C_API_NAV_MSGS_GETMAPFEEDBACK_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint8_t _dummy;
|
||||
} GetMapFeedback;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPFEEDBACK_H
|
||||
20
src/APIs/c_api/include/nav_msgs/GetMapGoal.h
Normal file
20
src/APIs/c_api/include/nav_msgs/GetMapGoal.h
Normal file
@@ -0,0 +1,20 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPGOAL_H
|
||||
#define C_API_NAV_MSGS_GETMAPGOAL_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint8_t _dummy;
|
||||
} GetMapGoal;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPGOAL_H
|
||||
20
src/APIs/c_api/include/nav_msgs/GetMapRequest.h
Normal file
20
src/APIs/c_api/include/nav_msgs/GetMapRequest.h
Normal file
@@ -0,0 +1,20 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPREQUEST_H
|
||||
#define C_API_NAV_MSGS_GETMAPREQUEST_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
|
||||
typedef struct
|
||||
{
|
||||
uint8_t _dummy;
|
||||
} GetMapRequest;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPREQUEST_H
|
||||
21
src/APIs/c_api/include/nav_msgs/GetMapResponse.h
Normal file
21
src/APIs/c_api/include/nav_msgs/GetMapResponse.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPRESPONSE_H
|
||||
#define C_API_NAV_MSGS_GETMAPRESPONSE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/OccupancyGrid.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
OccupancyGrid map;
|
||||
} GetMapResponse;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPRESPONSE_H
|
||||
21
src/APIs/c_api/include/nav_msgs/GetMapResult.h
Normal file
21
src/APIs/c_api/include/nav_msgs/GetMapResult.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef C_API_NAV_MSGS_GETMAPRESULT_H
|
||||
#define C_API_NAV_MSGS_GETMAPRESULT_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/OccupancyGrid.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
OccupancyGrid map;
|
||||
} GetMapResult;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETMAPRESULT_H
|
||||
23
src/APIs/c_api/include/nav_msgs/GetPlan.h
Normal file
23
src/APIs/c_api/include/nav_msgs/GetPlan.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_MSGS_GETPLAN_H
|
||||
#define C_API_NAV_MSGS_GETPLAN_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/GetPlanRequest.h"
|
||||
#include "nav_msgs/GetPlanResponse.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
GetPlanRequest request;
|
||||
GetPlanResponse response;
|
||||
} GetPlan;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETPLAN_H
|
||||
23
src/APIs/c_api/include/nav_msgs/GetPlanRequest.h
Normal file
23
src/APIs/c_api/include/nav_msgs/GetPlanRequest.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_MSGS_GETPLANREQUEST_H
|
||||
#define C_API_NAV_MSGS_GETPLANREQUEST_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "geometry_msgs/PoseStamped.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
PoseStamped start;
|
||||
PoseStamped goal;
|
||||
float tolerance;
|
||||
} GetPlanRequest;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETPLANREQUEST_H
|
||||
21
src/APIs/c_api/include/nav_msgs/GetPlanResponse.h
Normal file
21
src/APIs/c_api/include/nav_msgs/GetPlanResponse.h
Normal file
@@ -0,0 +1,21 @@
|
||||
#ifndef C_API_NAV_MSGS_GETPLANRESPONSE_H
|
||||
#define C_API_NAV_MSGS_GETPLANRESPONSE_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/Path.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Path plan;
|
||||
} GetPlanResponse;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GETPLANRESPONSE_H
|
||||
26
src/APIs/c_api/include/nav_msgs/GridCells.h
Normal file
26
src/APIs/c_api/include/nav_msgs/GridCells.h
Normal file
@@ -0,0 +1,26 @@
|
||||
#ifndef C_API_NAV_MSGS_GRIDCELLS_H
|
||||
#define C_API_NAV_MSGS_GRIDCELLS_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "std_msgs/Header.h"
|
||||
#include "geometry_msgs/Point.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
Header header;
|
||||
float cell_width;
|
||||
float cell_height;
|
||||
Point *cells;
|
||||
size_t cells_count;
|
||||
} GridCells;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_GRIDCELLS_H
|
||||
23
src/APIs/c_api/include/nav_msgs/LoadMap.h
Normal file
23
src/APIs/c_api/include/nav_msgs/LoadMap.h
Normal file
@@ -0,0 +1,23 @@
|
||||
#ifndef C_API_NAV_MSGS_LOADMAP_H
|
||||
#define C_API_NAV_MSGS_LOADMAP_H
|
||||
|
||||
#ifdef __cplusplus
|
||||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <stdint.h>
|
||||
#include <stddef.h>
|
||||
#include "nav_msgs/LoadMapRequest.h"
|
||||
#include "nav_msgs/LoadMapResponse.h"
|
||||
|
||||
typedef struct
|
||||
{
|
||||
LoadMapRequest request;
|
||||
LoadMapResponse response;
|
||||
} LoadMap;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
#endif
|
||||
|
||||
#endif // C_API_NAV_MSGS_LOADMAP_H
|
||||
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user