From 4735a4779ef321b0e45c2dc0462b9e2ff511808f Mon Sep 17 00:00:00 2001 From: Mateusz Lichota Date: Fri, 23 Dec 2022 06:12:41 +0100 Subject: [PATCH] Make camera frame configurable in ros_bridge_camera --- .../src/fsds_ros_bridge_camera.cpp | 11 ++++++++--- .../src/fsds_ros2_bridge_camera.cpp | 15 ++++++++++----- 2 files changed, 18 insertions(+), 8 deletions(-) diff --git a/ros/src/fsds_ros_bridge/src/fsds_ros_bridge_camera.cpp b/ros/src/fsds_ros_bridge/src/fsds_ros_bridge_camera.cpp index d98eb0fe..bb78f587 100644 --- a/ros/src/fsds_ros_bridge/src/fsds_ros_bridge_camera.cpp +++ b/ros/src/fsds_ros_bridge/src/fsds_ros_bridge_camera.cpp @@ -26,6 +26,8 @@ ros_bridge::Statistics fps_statistic; // settings std::string camera_name = ""; +std::string camera_frame_prefix = ""; +std::string camera_frame_id = ""; double framerate = 0.0; std::string host_ip = "localhost"; bool depthcamera = false; @@ -75,7 +77,7 @@ void doImageUpdate(const ros::TimerEvent&) img_msg->encoding = "bgr8"; img_msg->is_bigendian = 0; img_msg->header.stamp = make_ts(img_response.time_stamp); - img_msg->header.frame_id = "/fsds/camera/"+camera_name; + img_msg->header.frame_id = camera_frame_id; image_pub.publish(img_msg); fps_statistic.addCount(); @@ -129,7 +131,7 @@ void doDepthImageUpdate(const ros::TimerEvent&) { cv::Mat depth_img = noisify_depthimage(manual_decode_depth(img_response)); sensor_msgs::ImagePtr img_msg = cv_bridge::CvImage(std_msgs::Header(), "32FC1", depth_img).toImageMsg(); img_msg->header.stamp = make_ts(img_response.time_stamp); - img_msg->header.frame_id = "/fsds/camera/"+camera_name; + img_msg->header.frame_id = camera_frame_id; image_pub.publish(img_msg); fps_statistic.addCount(); @@ -142,6 +144,9 @@ int main(int argc, char ** argv) // load settings nh.param("camera_name", camera_name, ""); + nh.param("camera_frame_prefix", camera_frame_prefix, ""); + camera_frame_id = camera_frame_prefix + camera_name; + nh.param("framerate", framerate, 0.0); nh.param("host_ip", host_ip, "localhost"); nh.param("depthcamera", depthcamera, false); @@ -176,7 +181,7 @@ int main(int argc, char ** argv) } // ready topic - image_pub = nh.advertise("/fsds/camera/" + camera_name, 1); + image_pub = nh.advertise(camera_frame_id, 1); // start the loop ros::Timer imageTimer = nh.createTimer(ros::Duration(1/framerate), depthcamera ? doDepthImageUpdate : doImageUpdate); diff --git a/ros2/src/fsds_ros2_bridge/src/fsds_ros2_bridge_camera.cpp b/ros2/src/fsds_ros2_bridge/src/fsds_ros2_bridge_camera.cpp index 5cb24ab9..20181b10 100644 --- a/ros2/src/fsds_ros2_bridge/src/fsds_ros2_bridge_camera.cpp +++ b/ros2/src/fsds_ros2_bridge/src/fsds_ros2_bridge_camera.cpp @@ -26,6 +26,8 @@ ros_bridge::Statistics fps_statistic; // settings std::string camera_name = ""; +std::string camera_frame_prefix = ""; +std::string camera_frame_id = ""; double framerate = 0.0; std::string host_ip = "localhost"; bool depthcamera = false; @@ -76,13 +78,13 @@ void doImageUpdate() img_msg->encoding = "bgr8"; img_msg->is_bigendian = 0; img_msg->header.stamp = make_ts(img_response.time_stamp); - img_msg->header.frame_id = "/fsds/" + camera_name; + img_msg->header.frame_id = camera_frame_id; image_pub->publish(*img_msg); sensor_msgs::msg::CameraInfo::SharedPtr info_msg = std::make_shared(); info_msg->header.stamp = make_ts(img_response.time_stamp); - info_msg->header.frame_id = "/fsds/" + camera_name; + info_msg->header.frame_id = camera_frame_id; info_msg->width = img_response.width; info_msg->height = img_response.height; info_msg->distortion_model = "plumb_bob"; @@ -155,7 +157,7 @@ void doDepthImageUpdate() cv::Mat depth_img = noisify_depthimage(manual_decode_depth(img_response)); sensor_msgs::msg::Image::SharedPtr img_msg = cv_bridge::CvImage(std_msgs::msg::Header(), "32FC1", depth_img).toImageMsg(); img_msg->header.stamp = make_ts(img_response.time_stamp); - img_msg->header.frame_id = "/fsds/" + camera_name; + img_msg->header.frame_id = camera_frame_id; image_pub->publish(*img_msg); fps_statistic.addCount(); @@ -168,6 +170,9 @@ int main(int argc, char ** argv) // load settings camera_name = nh->declare_parameter("camera_name", ""); + camera_frame_prefix = nh->declare_parameter("camera_frame_prefix", "/fsds/"); + camera_frame_id = camera_frame_prefix + camera_name; + framerate = nh->declare_parameter("framerate", 0.0); host_ip = nh->declare_parameter("host_ip", "localhost"); depthcamera = nh->declare_parameter("depthcamera", false); @@ -201,8 +206,8 @@ int main(int argc, char ** argv) } // ready topic - image_pub = nh->create_publisher("/fsds/" + camera_name + "/image_color", 1); - info_pub = nh->create_publisher("/fsds/" + camera_name + "/camera_info", 1); + image_pub = nh->create_publisher(camera_frame_id + "/image_color", 1); + info_pub = nh->create_publisher(camera_frame_id + "/camera_info", 1); // start the loop rclcpp::TimerBase::SharedPtr imageTimer = nh->create_wall_timer(dseconds { 1/framerate }, depthcamera ? &doDepthImageUpdate : &doImageUpdate);