From 0afdb2143b10251c78080b6c48739e707d716ce4 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Alejandro=20Hern=C3=A1ndez=20Cordero?= Date: Fri, 19 Jan 2024 17:24:04 +0100 Subject: [PATCH] [backport humble] ROS 2: Add option to prepend timestamp to image filename in image_saver node (#870) (#885) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit backport #870 Signed-off-by: Alejandro Hernández Cordero --- .../include/image_view/image_saver_node.hpp | 1 + image_view/src/image_saver_node.cpp | 16 ++++++++++++++-- 2 files changed, 15 insertions(+), 2 deletions(-) diff --git a/image_view/include/image_view/image_saver_node.hpp b/image_view/include/image_view/image_saver_node.hpp index 217ea71d2..af3b0434c 100644 --- a/image_view/include/image_view/image_saver_node.hpp +++ b/image_view/include/image_view/image_saver_node.hpp @@ -70,6 +70,7 @@ class ImageSaverNode private: boost::format g_format; + bool stamped_filename_; bool save_all_image_{false}; bool save_image_service_{false}; std::string encoding_; diff --git a/image_view/src/image_saver_node.cpp b/image_view/src/image_saver_node.cpp index 8c7007ca7..5dcf20fe5 100644 --- a/image_view/src/image_saver_node.cpp +++ b/image_view/src/image_saver_node.cpp @@ -48,6 +48,7 @@ #include #include +#include #include #include "cv_bridge/cv_bridge.h" @@ -89,6 +90,7 @@ ImageSaverNode::ImageSaverNode(const rclcpp::NodeOptions & options) format_string = this->declare_parameter("filename_format", std::string("left%04i.%s")); encoding_ = this->declare_parameter("encoding", std::string("bgr8")); save_all_image_ = this->declare_parameter("save_all_image", true); + stamped_filename_ = this->declare_parameter("stamped_filename", false); request_start_end_ = this->declare_parameter("request_start_end", false); g_format.parse(format_string); @@ -142,8 +144,18 @@ bool ImageSaverNode::saveImage( } if (save_all_image_ || save_image_service_) { - cv::imwrite(filename, image); - RCLCPP_INFO(this->get_logger(), "Saved image %s", filename.c_str()); + if (stamped_filename_) { + std::stringstream ss; + ss << this->now().nanoseconds(); + std::string timestamp_str = ss.str(); + filename.insert(0, timestamp_str); + } + + if (cv::imwrite(filename, image)) { + RCLCPP_INFO(this->get_logger(), "Saved image %s", filename.c_str()); + } else { + RCLCPP_ERROR(this->get_logger(), "Failed to save image to path %s", filename.c_str()); + } save_image_service_ = false; } else {