contrast_stretch_nodelet.cpp
Go to the documentation of this file.
1 // *****************************************************************************
2 //
3 // Copyright (c) 2014, Southwest Research Institute® (SwRI®)
4 // All rights reserved.
5 //
6 // Redistribution and use in source and binary forms, with or without
7 // modification, are permitted provided that the following conditions are met:
8 // * Redistributions of source code must retain the above copyright
9 // notice, this list of conditions and the following disclaimer.
10 // * Redistributions in binary form must reproduce the above copyright
11 // notice, this list of conditions and the following disclaimer in the
12 // documentation and/or other materials provided with the distribution.
13 // * Neither the name of Southwest Research Institute® (SwRI®) nor the
14 // names of its contributors may be used to endorse or promote products
15 // derived from this software without specific prior written permission.
16 //
17 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
18 // AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
19 // IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
20 // ARE DISCLAIMED. IN NO EVENT SHALL <COPYRIGHT HOLDER> BE LIABLE FOR ANY
21 // DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
22 // (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
23 // LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
24 // ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
26 // SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
27 //
28 // *****************************************************************************
29 
30 #include <string>
31 
32 #include <opencv2/core/core.hpp>
33 #include <opencv2/highgui/highgui.hpp>
34 #include <opencv2/imgproc/imgproc.hpp>
35 
36 #include <ros/ros.h>
37 #include <nodelet/nodelet.h>
40 #include <sensor_msgs/Image.h>
41 #include <cv_bridge/cv_bridge.h>
43 
45 
46 namespace swri_image_util
47 {
49  {
50  public:
52  bins_(8),
53  max_min_(0.0),
54  min_max_(0.0),
57  {
58  }
59 
61  {
62  }
63 
64  void onInit()
65  {
68 
69  priv.param("bins", bins_, bins_);
70  priv.param("max_min", max_min_, max_min_);
71  priv.param("min_max", min_max_, min_max_);
72  priv.param("over_exposure_threshold", over_exposure_threshold_, over_exposure_threshold_);
73  priv.param("over_exposure_dilation", over_exposure_dilation_, over_exposure_dilation_);
74 
75  std::string mask;
76  priv.param("mask", mask, std::string(""));
77  if (!mask.empty())
78  {
79  mask_ = cv::imread(mask, 0);
80  }
81 
83  image_pub_ = it.advertise("normalized_image", 1);
85  }
86 
87  void ImageCallback(const sensor_msgs::ImageConstPtr& image)
88  {
90 
91  if (mask_.empty())
92  {
93  mask_ = cv::Mat::ones(cv_image->image.size(), CV_8U);
94  }
95  else if (mask_.rows != cv_image->image.rows || mask_.cols != cv_image->image.cols)
96  {
97  cv::resize(mask_, mask_, cv_image->image.size(), 1.0, 1.0, cv::INTER_NEAREST);
98  }
99 
100  cv::Mat mask;
101 
102  if (over_exposure_threshold_ < 255 && over_exposure_threshold_ > 0)
103  {
104  cv::Mat over_exposed = cv_image->image > over_exposure_threshold_;
105  cv::Mat element = cv::getStructuringElement(
106  cv::MORPH_ELLIPSE,
107  cv::Size(2 * over_exposure_dilation_ + 1, 2 * over_exposure_dilation_ + 1 ),
109  cv::dilate(over_exposed, over_exposed, element);
110 
111  mask = mask_.clone();
112  mask.setTo(0, over_exposed);
113  }
114  else
115  {
116  mask = mask_;
117  }
118 
119  swri_image_util::ContrastStretch(bins_, cv_image->image, cv_image->image, mask, max_min_, min_max_);
120 
121  image_pub_.publish(cv_image->toImageMsg());
122  }
123 
124  private:
125  int32_t bins_;
126  double max_min_;
127  double min_max_;
130 
131  cv::Mat mask_;
132 
135 
136  };
137 }
138 
139 // Register nodelet plugin
141 SWRI_NODELET_EXPORT_CLASS(swri_image_util, ContrastStretchNodelet)
nodelet::Nodelet::getNodeHandle
ros::NodeHandle & getNodeHandle() const
image_encodings.h
swri_image_util::ContrastStretchNodelet::ImageCallback
void ImageCallback(const sensor_msgs::ImageConstPtr &image)
Definition: contrast_stretch_nodelet.cpp:87
SWRI_NODELET_EXPORT_CLASS
SWRI_NODELET_EXPORT_CLASS(swri_image_util, DrawPolygonNodelet)
image_transport::ImageTransport
boost::shared_ptr
ros.h
swri_image_util::ContrastStretchNodelet::bins_
int32_t bins_
Definition: contrast_stretch_nodelet.cpp:125
swri_image_util::ContrastStretch
void ContrastStretch(int32_t grid_size, const cv::Mat &source_image, cv::Mat &dest_image, const cv::Mat &mask=cv::Mat(), double max_min=0.0, double min_max=0.0)
Definition: image_normalization.cpp:135
swri_image_util
Definition: draw_util.h:37
nodelet::Nodelet::getPrivateNodeHandle
ros::NodeHandle & getPrivateNodeHandle() const
swri_image_util::ContrastStretchNodelet::ContrastStretchNodelet
ContrastStretchNodelet()
Definition: contrast_stretch_nodelet.cpp:51
image_transport::ImageTransport::advertise
Publisher advertise(const std::string &base_topic, uint32_t queue_size, bool latch=false)
image_transport::Subscriber
class_list_macros.h
cv_bridge::toCvCopy
CvImagePtr toCvCopy(const sensor_msgs::CompressedImage &source, const std::string &encoding=std::string())
image_transport::ImageTransport::subscribe
Subscriber subscribe(const std::string &base_topic, uint32_t queue_size, const boost::function< void(const sensor_msgs::ImageConstPtr &)> &callback, const ros::VoidPtr &tracked_object=ros::VoidPtr(), const TransportHints &transport_hints=TransportHints())
swri_image_util::ContrastStretchNodelet::mask_
cv::Mat mask_
Definition: contrast_stretch_nodelet.cpp:131
swri_image_util::ContrastStretchNodelet::onInit
void onInit()
Definition: contrast_stretch_nodelet.cpp:64
swri_image_util::ContrastStretchNodelet::~ContrastStretchNodelet
~ContrastStretchNodelet()
Definition: contrast_stretch_nodelet.cpp:60
swri_image_util::ContrastStretchNodelet::min_max_
double min_max_
Definition: contrast_stretch_nodelet.cpp:127
swri_image_util::ContrastStretchNodelet
Definition: contrast_stretch_nodelet.cpp:48
image_transport::Publisher::publish
void publish(const sensor_msgs::Image &message) const
image_normalization.h
swri_image_util::ContrastStretchNodelet::image_sub_
image_transport::Subscriber image_sub_
Definition: contrast_stretch_nodelet.cpp:133
math_util.h
image_transport.h
nodelet::Nodelet
swri_image_util::ContrastStretchNodelet::image_pub_
image_transport::Publisher image_pub_
Definition: contrast_stretch_nodelet.cpp:134
swri_image_util::ContrastStretchNodelet::max_min_
double max_min_
Definition: contrast_stretch_nodelet.cpp:126
nodelet.h
image_transport::Publisher
cv_bridge.h
ros::NodeHandle::param
T param(const std::string &param_name, const T &default_val) const
swri_image_util::ContrastStretchNodelet::over_exposure_threshold_
double over_exposure_threshold_
Definition: contrast_stretch_nodelet.cpp:128
swri_image_util::ContrastStretchNodelet::over_exposure_dilation_
int32_t over_exposure_dilation_
Definition: contrast_stretch_nodelet.cpp:129
ros::NodeHandle


swri_image_util
Author(s): Kris Kozak
autogenerated on Thu Jun 6 2024 02:33:12