From 761a82600cc42801f50da6bbd5aa45857f0fb718 Mon Sep 17 00:00:00 2001 From: sskorol Date: Sun, 22 Oct 2023 23:26:52 +0300 Subject: [PATCH] GH-42: added RAE logo restoring on container shutdown. --- .dockerignore | 3 +++ Dockerfile | 23 +++++++++++++++++- assets/rae-logo-white.jpg | Bin 0 -> 4140 bytes rae_hw/include/rae_hw/peripherals/lcd.hpp | 4 ++++ rae_hw/launch/peripherals.launch.py | 4 ++++ rae_hw/src/peripherals/lcd.cpp | 27 ++++++++++++++++++---- 6 files changed, 55 insertions(+), 6 deletions(-) create mode 100644 .dockerignore create mode 100644 assets/rae-logo-white.jpg diff --git a/.dockerignore b/.dockerignore new file mode 100644 index 0000000..ed34f38 --- /dev/null +++ b/.dockerignore @@ -0,0 +1,3 @@ +.git +.github +.devcontainer \ No newline at end of file diff --git a/Dockerfile b/Dockerfile index 5994dcc..38923ef 100644 --- a/Dockerfile +++ b/Dockerfile @@ -6,12 +6,33 @@ ARG BUILD_TYPE="RelWithDebInfo" ENV DEBIAN_FRONTEND=noninteractive RUN apt-get update \ - && apt-get -y install --no-install-recommends software-properties-common git libusb-1.0-0-dev wget zsh python3-colcon-common-extensions python3-rosdep build-essential neovim tmux htop net-tools iputils-ping gpiod gstreamer1.0-plugins-bad gstreamer1.0-alsa libasound2-dev busybox + && apt-get -y install --no-install-recommends \ + software-properties-common \ + git \ + nano \ + libusb-1.0-0-dev \ + wget \ + zsh \ + python3-colcon-common-extensions \ + python3-rosdep \ + build-essential \ + neovim \ + tmux \ + htop \ + net-tools \ + iputils-ping \ + gpiod \ + gstreamer1.0-plugins-bad \ + gstreamer1.0-alsa \ + libasound2-dev \ + busybox ENV WS=/ws RUN mkdir -p $WS/src COPY ./ .$WS/src/rae-ros +RUN cp -R .$WS/src/rae-ros/assets/. /usr/share +RUN rm -rf .$WS/src/rae-ros/assets RUN rm -rf .$WS/src/rae-ros/rae_gazebo RUN cd .$WS/ && apt update && rosdep update && rosdep install --from-paths src --ignore-src -y --skip-keys depthai --skip-keys depthai_bridge --skip-keys depthai_ros_driver --skip-keys audio_msgs --skip-keys laserscan_kinect --skip-keys ira_laser_tools diff --git a/assets/rae-logo-white.jpg b/assets/rae-logo-white.jpg new file mode 100644 index 0000000000000000000000000000000000000000..079e8f978363e7383a7d357467ac75932a3183c1 GIT binary patch literal 4140 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 literal 0 HcmV?d00001 diff --git a/rae_hw/include/rae_hw/peripherals/lcd.hpp b/rae_hw/include/rae_hw/peripherals/lcd.hpp index 08d230f..44ef2fa 100644 --- a/rae_hw/include/rae_hw/peripherals/lcd.hpp +++ b/rae_hw/include/rae_hw/peripherals/lcd.hpp @@ -2,11 +2,13 @@ #include #include #include +#include #include "rclcpp/rclcpp.hpp" #include "sensor_msgs/msg/image.hpp" #include "cv_bridge/cv_bridge.h" #include "opencv2/opencv.hpp" + namespace rae_hw { class LCDNode : public rclcpp::Node @@ -16,6 +18,7 @@ namespace rae_hw ~LCDNode(); void image_callback(const sensor_msgs::msg::Image::SharedPtr msg); + void display_image(const cv::Mat& img); private: rclcpp::Subscription::SharedPtr subscription_; @@ -24,5 +27,6 @@ namespace rae_hw struct fb_var_screeninfo vinfo; struct fb_fix_screeninfo finfo; long screensize; + std::string default_logo_path; }; } \ No newline at end of file diff --git a/rae_hw/launch/peripherals.launch.py b/rae_hw/launch/peripherals.launch.py index a0b9bee..aa5010e 100644 --- a/rae_hw/launch/peripherals.launch.py +++ b/rae_hw/launch/peripherals.launch.py @@ -34,6 +34,9 @@ def launch_setup(context, *args, **kwargs): name='lcd_node', package='rae_hw', plugin='rae_hw::LCDNode', + parameters=[{ + 'default_logo_path': LaunchConfiguration('default_logo_path') + }], ), ComposableNode( name='led_node', @@ -62,6 +65,7 @@ def generate_launch_description(): DeclareLaunchArgument('name', default_value='rae'), DeclareLaunchArgument('run_container', default_value='true'), DeclareLaunchArgument('enable_battery_status', default_value='true'), + DeclareLaunchArgument('default_logo_path', default_value='/usr/share/rae-logo-white.jpg'), ] return LaunchDescription( diff --git a/rae_hw/src/peripherals/lcd.cpp b/rae_hw/src/peripherals/lcd.cpp index 2a74386..27f9e07 100644 --- a/rae_hw/src/peripherals/lcd.cpp +++ b/rae_hw/src/peripherals/lcd.cpp @@ -15,6 +15,10 @@ namespace rae_hw LCDNode::LCDNode(const rclcpp::NodeOptions &options) : Node("lcd_node", options) { + std::string logo_key = "default_logo_path"; + declare_parameter(logo_key); + default_logo_path = get_parameter(logo_key).as_string(); + // Open the framebuffer device fbfd = open("/dev/fb0", O_RDWR); if (fbfd == -1) @@ -52,16 +56,22 @@ namespace rae_hw "lcd", 10, std::bind(&LCDNode::image_callback, this, std::placeholders::_1)); RCLCPP_INFO(this->get_logger(), "LCD node running!"); } + LCDNode::~LCDNode() { + // Load default image + cv::Mat default_img = cv::imread(default_logo_path); + if (!default_img.empty()) + { + display_image(default_img); + } + munmap(fbp, screensize); close(fbfd); } - void LCDNode::image_callback(const sensor_msgs::msg::Image::SharedPtr msg) + void LCDNode::display_image(const cv::Mat& img) { - // Convert ROS image message to OpenCV image - cv::Mat img = cv_bridge::toCvCopy(msg, "bgr8")->image; // Resize to match the screen dimensions cv::resize(img, img, cv::Size(vinfo.xres, vinfo.yres)); // Iterate over the image pixels @@ -77,8 +87,15 @@ namespace rae_hw *((cv::Vec3b *)(fbp + location)) = pixel; } } - }; + } + void LCDNode::image_callback(const sensor_msgs::msg::Image::SharedPtr msg) + { + // Convert ROS image message to OpenCV image + cv::Mat img = cv_bridge::toCvCopy(msg, "bgr8")->image; + display_image(img); + }; } + #include "rclcpp_components/register_node_macro.hpp" -RCLCPP_COMPONENTS_REGISTER_NODE(rae_hw::LCDNode); \ No newline at end of file +RCLCPP_COMPONENTS_REGISTER_NODE(rae_hw::LCDNode);