Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Dashing: Image_proc with old PR comments fixed #426

Merged
merged 10 commits into from
Jul 16, 2019
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 3 additions & 3 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
@@ -1,8 +1,8 @@
version: 2
jobs:
crystal:
dashing:
docker:
- image: ros:crystal-ros-base
- image: ros:dashing-ros-base
steps:
- checkout
- run:
Expand All @@ -29,4 +29,4 @@ workflows:
version: 2
ros_build:
jobs:
- crystal
- dashing
20 changes: 11 additions & 9 deletions depth_image_proc/CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ endif()

find_package(ament_cmake REQUIRED)
find_package(rclcpp REQUIRED)
find_package(rclcpp_components REQUIRED)
find_package(cv_bridge REQUIRED)
find_package(tf2_eigen REQUIRED)
find_package(image_geometry REQUIRED)
Expand Down Expand Up @@ -49,22 +50,23 @@ ament_target_dependencies(${PROJECT_NAME}
"class_loader"
"message_filters"
"rclcpp"
"rclcpp_components"
"tf2_ros"
"tf2"
"tf2_eigen"
"stereo_msgs"
"sensor_msgs"
)

rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::ConvertMetricNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::CropForemostNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::DisparityNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyzNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyzRadialNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyziNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyziRadialNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyzrgbNode")
rclcpp_register_node_plugins(${PROJECT_NAME} "${PROJECT_NAME}::RegisterNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::ConvertMetricNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::CropForemostNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::DisparityNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyzNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyzRadialNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyziNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyziRadialNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::PointCloudXyzrgbNode")
rclcpp_components_register_nodes(${PROJECT_NAME} "${PROJECT_NAME}::RegisterNode")

target_link_libraries(${PROJECT_NAME} ${ament_LIBRARIES} ${OpenCV_LIBRARIES})

Expand Down
135 changes: 82 additions & 53 deletions image_proc/CMakeLists.txt
Original file line number Diff line number Diff line change
@@ -1,68 +1,97 @@
cmake_minimum_required(VERSION 2.8)
cmake_minimum_required(VERSION 3.5)

project(image_proc)

find_package(catkin REQUIRED)
# ROS2 Flags
if(NOT CMAKE_CXX_STANDARD)
set(CMAKE_CXX_STANDARD 14)
endif()

if(CMAKE_COMPILER_IS_GNUCXX OR CMAKE_CXX_COMPILER_ID MATCHES "Clang")
add_compile_options(-Wall -Wextra -Wpedantic)
endif()

find_package(catkin REQUIRED cv_bridge dynamic_reconfigure image_geometry image_transport nodelet nodelet_topic_tools roscpp sensor_msgs)
find_package(ament_cmake REQUIRED)
find_package(rclcpp REQUIRED)
find_package(rclcpp_components REQUIRED)
find_package(cv_bridge REQUIRED)
find_package(image_transport REQUIRED)
find_package(sensor_msgs REQUIRED)
find_package(OpenCV REQUIRED)
find_package(Boost REQUIRED COMPONENTS thread)
find_package(image_geometry REQUIRED)

if(cv_bridge_VERSION VERSION_GREATER "1.12.0")
add_compile_options(-std=c++11)
endif()
include_directories(include)

# Dynamic reconfigure support
generate_dynamic_reconfigure_options(cfg/CropDecimate.cfg cfg/Debayer.cfg cfg/Rectify.cfg cfg/Resize.cfg)
add_library(rectify SHARED
src/rectify.cpp)
target_compile_definitions(rectify
PRIVATE "COMPOSITION_BUILDING_DLL")

catkin_package(
CATKIN_DEPENDS image_geometry roscpp sensor_msgs
DEPENDS OpenCV
INCLUDE_DIRS include
LIBRARIES ${PROJECT_NAME}
)
ament_target_dependencies(rectify
"image_geometry"
"sensor_msgs"
"cv_bridge"
"class_loader"
"image_transport"
"rclcpp"
"rclcpp_components"
)

rclcpp_components_register_nodes(rectify "image_proc::RectifyNode")
set(node_plugins "${node_plugins}image_proc::RectifyNode;$<TARGET_FILE:rectify>\n")

include_directories(include ${catkin_INCLUDE_DIRS} ${OpenCV_INCLUDE_DIRS})

# Temporary fix for DataType deprecation in OpenCV 3.3.1. We continue to use the deprecated form for now because
# the new one is not available in OpenCV 2.4 (on Trusty).
add_definitions(-DOPENCV_TRAITS_ENABLE_DEPRECATED)

# Nodelet library
add_library(${PROJECT_NAME} src/libimage_proc/processor.cpp
src/nodelets/debayer.cpp
src/nodelets/rectify.cpp
src/nodelets/resize.cpp
src/nodelets/crop_decimate.cpp
src/libimage_proc/advertisement_checker.cpp
src/nodelets/edge_aware.cpp
src/nodelets/crop_non_zero.cpp
)
add_dependencies(${PROJECT_NAME} ${PROJECT_NAME}_gencfg)
target_link_libraries(${PROJECT_NAME} ${catkin_LIBRARIES} ${Boost_LIBRARIES} ${OpenCV_LIBRARIES})
add_library(debayer SHARED
src/debayer.cpp
src/edge_aware.cpp
)

install(TARGETS ${PROJECT_NAME}
DESTINATION ${CATKIN_PACKAGE_LIB_DESTINATION}
)
install(DIRECTORY include/${PROJECT_NAME}/
DESTINATION ${CATKIN_PACKAGE_INCLUDE_DESTINATION}
)
install(FILES nodelet_plugins.xml
DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}
target_compile_definitions(debayer
PRIVATE "COMPOSITION_BUILDING_DLL")

ament_target_dependencies(debayer
"sensor_msgs"
"cv_bridge"
"class_loader"
"image_transport"
"rclcpp"
"rclcpp_components"
)

rclcpp_components_register_nodes(debayer "image_proc::DebayerNode")
set(node_plugins "${node_plugins}image_proc::DebayerNode;$<TARGET_FILE:debayer>\n")

add_executable(image_proc
src/image_proc.cpp
)
target_link_libraries(image_proc
debayer
rectify
ament_index_cpp::ament_index_cpp)

# Standalone node
add_executable(image_proc_exe src/nodes/image_proc.cpp)
target_link_libraries(image_proc_exe ${PROJECT_NAME} ${Boost_LIBRARIES} ${OpenCV_LIBRARIES})
SET_TARGET_PROPERTIES(image_proc_exe PROPERTIES OUTPUT_NAME image_proc)
install(TARGETS image_proc_exe
DESTINATION ${CATKIN_PACKAGE_BIN_DESTINATION}
if(CMAKE_CXX_COMPILER_ID STREQUAL "GNU")
target_link_libraries(image_proc "stdc++fs")
endif()

ament_target_dependencies(image_proc
"image_geometry"
"sensor_msgs"
"cv_bridge"
"class_loader"
"image_transport"
"rclcpp"
"rclcpp_components"
"rcutils"
)

# install the launch file
install(DIRECTORY launch
DESTINATION ${CATKIN_PACKAGE_SHARE_DESTINATION}/
install(TARGETS
debayer
rectify
ARCHIVE DESTINATION lib
RUNTIME DESTINATION bin
LIBRARY DESTINATION lib
)

if(CATKIN_ENABLE_TESTING)
add_subdirectory(test)
endif()
install(TARGETS
image_proc
DESTINATION lib/${PROJECT_NAME})
ament_package()
Empty file removed image_proc/COLCON_IGNORE
Empty file.
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/*********************************************************************
* Software License Agreement (BSD License)
*
* Copyright (c) 2008, Willow Garage, Inc.
* Copyright (c) 2008, 2019, Willow Garage, Inc., Andreas Klintberg.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
Expand Down Expand Up @@ -31,31 +31,47 @@
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*********************************************************************/
#ifndef IMAGE_PROC_ADVERTISEMENT_CHECKER_H
#define IMAGE_PROC_ADVERTISEMENT_CHECKER_H

#include <ros/ros.h>
#include <cstring>
#include <memory>
#include <sstream>
#include <string>
#include <vector>
#include <thread>
#include <rclcpp/rclcpp.hpp>
#include <image_transport/image_transport.h>

namespace image_proc {
#include <ament_index_cpp/get_resource.hpp>
#include "rclcpp/rclcpp.hpp"
#ifndef IMAGE_PROC_DEBAYER_HPP
#define IMAGE_PROC_DEBAYER_HPP

class AdvertisementChecker

namespace image_proc
{
class DebayerNode : public rclcpp::Node
{
ros::NodeHandle nh_;
std::string name_;
ros::WallTimer timer_;
ros::V_string topics_;
// ROS communication
public:
DebayerNode(const rclcpp::NodeOptions&);
private:
image_transport::Subscriber sub_raw_;

void timerCb();
std::string camera_namespace_;
int debayer_;

public:
AdvertisementChecker(const ros::NodeHandle& nh = ros::NodeHandle(),
const std::string& name = std::string());

void start(const ros::V_string& topics, double duration);
int debayer_bilinear_ = 0;
int debayer_edgeaware_ = 1;
int debayer_edgeaware_weighted_ = 2;
int debayer_vng_ = 3;

void stop();
};
std::mutex connect_mutex_;

} // namespace image_proc
image_transport::Publisher pub_mono_;
image_transport::Publisher pub_color_;

#endif
void connectCb();
void imageCb(const sensor_msgs::msg::Image::ConstSharedPtr & raw_msg);
};
} // namespace image_proc
#endif
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/*********************************************************************
* Software License Agreement (BSD License)
*
* Copyright (c) 2008, Willow Garage, Inc.
* Copyright (c) 2008, 2019, Willow Garage, Inc., Andreas Klintberg.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
Expand Down Expand Up @@ -31,6 +31,7 @@
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*********************************************************************/

#ifndef IMAGE_PROC_EDGE_AWARE
#define IMAGE_PROC_EDGE_AWARE

Expand All @@ -45,5 +46,4 @@ void debayerEdgeAware(const cv::Mat& bayer, cv::Mat& color);
void debayerEdgeAwareWeighted(const cv::Mat& bayer, cv::Mat& color);

} // namespace image_proc

#endif
7 changes: 4 additions & 3 deletions image_proc/include/image_proc/processor.h
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
/*********************************************************************
* Software License Agreement (BSD License)
*
* Copyright (c) 2008, Willow Garage, Inc.
* Copyright (c) 2008, 2019, Willow Garage, Inc., Andreas Klintberg.
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
Expand Down Expand Up @@ -31,12 +31,13 @@
* ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
* POSSIBILITY OF SUCH DAMAGE.
*********************************************************************/

#ifndef IMAGE_PROC_PROCESSOR_H
#define IMAGE_PROC_PROCESSOR_H

#include <opencv2/core/core.hpp>
#include <image_geometry/pinhole_camera_model.h>
#include <sensor_msgs/Image.h>
#include "sensor_msgs/msg/image.hpp"

namespace image_proc {

Expand Down Expand Up @@ -67,7 +68,7 @@ class Processor
ALL = MONO | RECT | COLOR | RECT_COLOR
};

bool process(const sensor_msgs::ImageConstPtr& raw_image,
bool process(const sensor_msgs::msg::Image::SharedConstPtr& raw_image,
const image_geometry::PinholeCameraModel& model,
ImageSet& output, int flags = ALL) const;
};
Expand Down
Loading