From 77ce83ee7ffb95ec011053cb8d0bd2418f3d2234 Mon Sep 17 00:00:00 2001 From: Michael Ferguson Date: Wed, 17 Jan 2024 21:16:19 -0500 Subject: [PATCH 1/3] properly remap compressed topics --- image_publisher/src/image_publisher.cpp | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/image_publisher/src/image_publisher.cpp b/image_publisher/src/image_publisher.cpp index 4859ed02b..f42aba575 100644 --- a/image_publisher/src/image_publisher.cpp +++ b/image_publisher/src/image_publisher.cpp @@ -52,7 +52,11 @@ using namespace std::chrono_literals; ImagePublisher::ImagePublisher(const rclcpp::NodeOptions & options) : rclcpp::Node("ImagePublisher", options) { - pub_ = image_transport::create_camera_publisher(this, "image_raw"); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string topic_name = node_base->resolve_topic_or_service_name("image_raw", false); + pub_ = image_transport::create_camera_publisher(this, topic_name); flip_horizontal_ = this->declare_parameter("flip_horizontal", false); flip_vertical_ = this->declare_parameter("flip_vertical", false); From 90823d68ca0e983712400e49d4e7196e740c2f76 Mon Sep 17 00:00:00 2001 From: Michael Ferguson Date: Wed, 17 Jan 2024 21:33:30 -0500 Subject: [PATCH 2/3] apply same treatment to image_view --- image_view/src/image_view_node.cpp | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/image_view/src/image_view_node.cpp b/image_view/src/image_view_node.cpp index 2ebc5a599..9999ec0ad 100644 --- a/image_view/src/image_view_node.cpp +++ b/image_view/src/image_view_node.cpp @@ -107,8 +107,10 @@ ImageViewNode::ImageViewNode(const rclcpp::NodeOptions & options) auto transport = this->declare_parameter("image_transport", "raw"); RCLCPP_INFO(this->get_logger(), "Using transport \"%s\"", transport.c_str()); - std::string topic = rclcpp::expand_topic_or_service_name( - "image", this->get_name(), this->get_namespace()); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string topic = node_base->resolve_topic_or_service_name("image", false); image_transport::TransportHints hints(this, transport); pub_ = this->create_publisher("output", 1); @@ -118,7 +120,7 @@ ImageViewNode::ImageViewNode(const rclcpp::NodeOptions & options) auto topics = this->get_topic_names_and_types(); - if (topics.find(topic) != topics.end()) { + if (topics.find(topic) == topics.end()) { RCLCPP_WARN( this->get_logger(), "Topic 'image' has not been remapped! " "Typical command-line usage:\n" From 257d4114801901877c531667f8aeb44d31077174 Mon Sep 17 00:00:00 2001 From: Michael Ferguson Date: Wed, 17 Jan 2024 21:45:01 -0500 Subject: [PATCH 3/3] same treatment, more nodes --- image_view/src/disparity_view_node.cpp | 10 +++++++--- image_view/src/extract_images_node.cpp | 8 +++++--- image_view/src/image_saver_node.cpp | 6 ++++-- image_view/src/stereo_view_node.cpp | 7 ++++--- image_view/src/video_recorder_node.cpp | 7 +++++-- 5 files changed, 25 insertions(+), 13 deletions(-) diff --git a/image_view/src/disparity_view_node.cpp b/image_view/src/disparity_view_node.cpp index 4bc04aaa9..be0805676 100644 --- a/image_view/src/disparity_view_node.cpp +++ b/image_view/src/disparity_view_node.cpp @@ -65,10 +65,14 @@ namespace image_view DisparityViewNode::DisparityViewNode(const rclcpp::NodeOptions & options) : rclcpp::Node("disparity_view_node", options) { - std::string topic = - rclcpp::expand_topic_or_service_name("image", this->get_name(), this->get_namespace()); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string topic = node_base->resolve_topic_or_service_name("image", false); - if (topic == "image") { + auto topics = this->get_topic_names_and_types(); + + if (topics.find(topic) == topics.end()) { RCLCPP_WARN( this->get_logger(), "Topic 'image' has not been remapped! Typical command-line usage:\n" "\t$ ros2 run image_view disparity_view --ros-args -r image:="); diff --git a/image_view/src/extract_images_node.cpp b/image_view/src/extract_images_node.cpp index f27f342d6..bf6513a97 100644 --- a/image_view/src/extract_images_node.cpp +++ b/image_view/src/extract_images_node.cpp @@ -70,8 +70,10 @@ ExtractImagesNode::ExtractImagesNode(const rclcpp::NodeOptions & options) : rclcpp::Node("extract_images_node", options), filename_format_(""), count_(0), _time(this->now()) { - auto topic = rclcpp::expand_topic_or_service_name( - "image", this->get_name(), this->get_namespace()); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string topic = node_base->resolve_topic_or_service_name("image", false); this->declare_parameter("transport", std::string("raw")); std::string transport = this->get_parameter("transport").as_string(); @@ -83,7 +85,7 @@ ExtractImagesNode::ExtractImagesNode(const rclcpp::NodeOptions & options) auto topics = this->get_topic_names_and_types(); - if (topics.find(topic) != topics.end()) { + if (topics.find(topic) == topics.end()) { RCLCPP_WARN( this->get_logger(), "extract_images: image has not been remapped! " "Typical command-line usage:\n\t$ ros2 run image_view extract_images " diff --git a/image_view/src/image_saver_node.cpp b/image_view/src/image_saver_node.cpp index 302651880..5760b1488 100644 --- a/image_view/src/image_saver_node.cpp +++ b/image_view/src/image_saver_node.cpp @@ -70,8 +70,10 @@ namespace image_view ImageSaverNode::ImageSaverNode(const rclcpp::NodeOptions & options) : rclcpp::Node("image_saver_node", options) { - auto topic = rclcpp::expand_topic_or_service_name( - "image", this->get_name(), this->get_namespace()); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string topic = node_base->resolve_topic_or_service_name("image", false); // Useful when CameraInfo is being published cam_sub_ = image_transport::create_camera_subscription( diff --git a/image_view/src/stereo_view_node.cpp b/image_view/src/stereo_view_node.cpp index a9d21d018..04c015e62 100644 --- a/image_view/src/stereo_view_node.cpp +++ b/image_view/src/stereo_view_node.cpp @@ -109,9 +109,10 @@ StereoViewNode::StereoViewNode(const rclcpp::NodeOptions & options) cv::setMouseCallback("right", &StereoViewNode::mouseCb, this); cv::setMouseCallback("disparity", &StereoViewNode::mouseCb, this); - // Resolve topic names - std::string stereo_ns = rclcpp::expand_topic_or_service_name( - "stereo", this->get_name(), this->get_namespace()); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string stereo_ns = node_base->resolve_topic_or_service_name("stereo", false); std::string left_topic = rclcpp::expand_topic_or_service_name( stereo_ns + "/left" + rclcpp::expand_topic_or_service_name( diff --git a/image_view/src/video_recorder_node.cpp b/image_view/src/video_recorder_node.cpp index bed3ced59..3438d58a4 100644 --- a/image_view/src/video_recorder_node.cpp +++ b/image_view/src/video_recorder_node.cpp @@ -66,8 +66,11 @@ VideoRecorderNode::VideoRecorderNode(const rclcpp::NodeOptions & options) rclcpp::shutdown(); } - auto topic = rclcpp::expand_topic_or_service_name( - "image", this->get_name(), this->get_namespace()); + // For compressed topics to remap appropriately, we need to pass a + // fully expanded and remapped topic name to image_transport + auto node_base = this->get_node_base_interface(); + std::string topic = node_base->resolve_topic_or_service_name("image", false); + sub_image = image_transport::create_subscription( this, topic, std::bind(&VideoRecorderNode::callback, this, std::placeholders::_1), "raw");