threshold_nodelet.cpp
Go to the documentation of this file.
1 // -*- mode: c++ -*-
2 /*********************************************************************
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2016, JSK Lab
6  * All rights reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * * Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  * * Redistributions in binary form must reproduce the above
15  * copyright notice, this list of conditions and the following
16  * disclaimer in the documentation and/or other materials provided
17  * with the distribution.
18  * * Neither the name of the JSK Lab nor the names of its
19  * contributors may be used to endorse or promote products derived
20  * from this software without specific prior written permission.
21  *
22  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
23  * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
24  * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
25  * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
26  * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
27  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
28  * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
29  * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
30  * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
31  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN
32  * ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
33  * POSSIBILITY OF SUCH DAMAGE.
34  *********************************************************************/
35 
36 // https://github.com/opencv/opencv/blob/2.4/samples/cpp/tutorial_code/ImgProc/Threshold.cpp
43 #include <cv_bridge/cv_bridge.h>
45 
46 #include <opencv2/highgui/highgui.hpp>
47 #include "opencv2/imgproc/imgproc.hpp"
48 
49 #include "opencv_apps/nodelet.h"
50 #include "opencv_apps/ThresholdConfig.h"
51 
52 #include <dynamic_reconfigure/server.h>
53 
54 namespace opencv_apps
55 {
56 class ThresholdNodelet : public opencv_apps::Nodelet
57 {
59  // Dynamic Reconfigure
61  typedef opencv_apps::ThresholdConfig Config;
62  typedef dynamic_reconfigure::Server<Config> ReconfigureServer;
65 
66  int queue_size_;
67  bool debug_view_;
68 
69  std::string window_name_;
70 
74 
76 
77  boost::mutex mutex_;
78  int threshold_type_;
80  int threshold_value_;
81  bool apply_otsu_;
82 
83  void imageCallbackWithInfo(const sensor_msgs::ImageConstPtr& msg, const sensor_msgs::CameraInfoConstPtr& cam_info)
84  {
85  doWork(msg, cam_info->header.frame_id);
86  }
87 
88  void imageCallback(const sensor_msgs::ImageConstPtr& msg)
89  {
90  doWork(msg, msg->header.frame_id);
91  }
92 
93  void subscribe() // NOLINT(modernize-use-override)
94  {
95  NODELET_DEBUG("Subscribing to image topic.");
96  if (config_.use_camera_info)
97  cam_sub_ = it_->subscribeCamera("image", queue_size_, &ThresholdNodelet::imageCallbackWithInfo, this);
98  else
99  img_sub_ = it_->subscribe("image", queue_size_, &ThresholdNodelet::imageCallback, this);
100  }
101 
102  void unsubscribe() // NOLINT(modernize-use-override)
103  {
104  NODELET_DEBUG("Unsubscribing from image topic.");
105  img_sub_.shutdown();
106  cam_sub_.shutdown();
107  }
108 
109  void reconfigureCallback(Config& config, uint32_t level)
110  {
111  boost::mutex::scoped_lock lock(mutex_);
112  config_ = config;
113  threshold_value_ = config.threshold;
114  threshold_type_ = config.threshold_type;
115  max_binary_value_ = config.max_binary;
116  apply_otsu_ = config.apply_otsu;
117  }
118 
119  void doWork(const sensor_msgs::Image::ConstPtr& image_msg, const std::string& input_frame_from_msg)
120  {
121  try
122  {
123  cv::Mat src_image = cv_bridge::toCvShare(image_msg, sensor_msgs::image_encodings::BGR8)->image;
124  cv::Mat gray_image;
125  cv::cvtColor(src_image, gray_image, cv::COLOR_BGR2GRAY);
126  cv::Mat result_image;
127 
129  {
130  threshold_type_ |= CV_THRESH_OTSU;
131  }
132  cv::threshold(gray_image, result_image, threshold_value_, max_binary_value_, threshold_type_);
133  //-- Show what you got
134  if (debug_view_)
135  {
136  cv::namedWindow(window_name_, cv::WINDOW_AUTOSIZE);
137  cv::imshow(window_name_, result_image);
138  int c = cv::waitKey(1);
139  }
142  }
143  catch (cv::Exception& e)
144  {
145  NODELET_ERROR("Image processing error: %s %s %s %i", e.err.c_str(), e.func.c_str(), e.file.c_str(), e.line);
146  }
147  }
148 
149 public:
150  virtual void onInit() // NOLINT(modernize-use-override)
151  {
154 
155  pnh_->param("queue_size", queue_size_, 3);
156  pnh_->param("debug_view", debug_view_, false);
158  {
159  always_subscribe_ = true;
160  }
162  // Dynamic Reconfigure
164  reconfigure_server_ = boost::make_shared<dynamic_reconfigure::Server<Config> >(*pnh_);
165  dynamic_reconfigure::Server<Config>::CallbackType f =
167  reconfigure_server_->setCallback(f);
168 
169  img_pub_ = advertiseImage(*pnh_, "image", 1);
171  }
172 };
173 } // namespace opencv_apps
174 
175 namespace threshold
176 {
178 {
179 public:
180  virtual void onInit() // NOLINT(modernize-use-override)
181  {
182  ROS_WARN("DeprecationWarning: Nodelet threshold/threshold is deprecated, "
183  "and renamed to opencv_apps/threshold.");
185  }
186 };
187 } // namespace threshold
188 
189 #ifdef USE_PLUGINLIB_CLASS_LIST_MACROS_H
191 #else
193 #endif
nodelet.h
threshold::ThresholdNodelet
Definition: threshold_nodelet.cpp:177
NODELET_ERROR
#define NODELET_ERROR(...)
opencv_apps::Nodelet::onInitPostProcess
virtual void onInitPostProcess()
Post processing of initialization of nodelet. You need to call this method in order to use always_sub...
Definition: nodelet.cpp:77
image_encodings.h
image_transport::ImageTransport
boost::shared_ptr< ReconfigureServer >
cv_bridge::CvImage::toImageMsg
sensor_msgs::ImagePtr toImageMsg() const
opencv_apps::ThresholdNodelet::cam_sub_
image_transport::CameraSubscriber cam_sub_
Definition: threshold_nodelet.cpp:137
opencv_apps::ThresholdNodelet::subscribe
void subscribe()
This method is called when publisher is subscribed by other nodes. Set up subscribers in this method.
Definition: threshold_nodelet.cpp:157
opencv_apps::ThresholdNodelet::Config
opencv_apps::ThresholdConfig Config
Definition: threshold_nodelet.cpp:125
boost::placeholders::_1
boost::arg< 1 > _1
Definition: nodelet.cpp:44
opencv_apps::Nodelet
Nodelet to automatically subscribe/unsubscribe topics according to subscription of advertised topics.
Definition: nodelet.h:90
opencv_apps::ThresholdNodelet::ReconfigureServer
dynamic_reconfigure::Server< Config > ReconfigureServer
Definition: threshold_nodelet.cpp:126
opencv_apps::ThresholdNodelet::threshold_value_
int threshold_value_
Definition: threshold_nodelet.cpp:144
threshold::ThresholdNodelet::onInit
virtual void onInit()
Initialize nodehandles nh_ and pnh_. Subclass should call this method in its onInit method.
Definition: threshold_nodelet.cpp:180
opencv_apps::ThresholdNodelet::onInit
virtual void onInit()
Initialize nodehandles nh_ and pnh_. Subclass should call this method in its onInit method.
Definition: threshold_nodelet.cpp:214
opencv_apps::ThresholdNodelet::img_pub_
image_transport::Publisher img_pub_
Definition: threshold_nodelet.cpp:135
f
f
opencv_apps::ThresholdNodelet::doWork
void doWork(const sensor_msgs::Image::ConstPtr &image_msg, const std::string &input_frame_from_msg)
Definition: threshold_nodelet.cpp:183
image_transport::Subscriber
opencv_apps::ThresholdNodelet::img_sub_
image_transport::Subscriber img_sub_
Definition: threshold_nodelet.cpp:136
opencv_apps::Nodelet::advertiseImage
image_transport::Publisher advertiseImage(ros::NodeHandle &nh, const std::string &topic, int queue_size)
Advertise an image topic and watch the publisher. Publishers which are created by this method....
Definition: nodelet.h:201
class_list_macros.h
opencv_apps::ThresholdNodelet::window_name_
std::string window_name_
Definition: threshold_nodelet.cpp:133
opencv_apps::ThresholdNodelet::max_binary_value_
int max_binary_value_
Definition: threshold_nodelet.cpp:143
image_transport::CameraSubscriber
image_transport::CameraSubscriber::shutdown
void shutdown()
boost::placeholders::_2
boost::arg< 2 > _2
Definition: nodelet.cpp:45
opencv_apps::Nodelet::always_subscribe_
bool always_subscribe_
A flag to disable watching mechanism and always subscribe input topics. It can be specified via ~alwa...
Definition: nodelet.h:300
ROS_WARN
#define ROS_WARN(...)
opencv_apps::ThresholdNodelet::mutex_
boost::mutex mutex_
Definition: threshold_nodelet.cpp:141
image_transport::Publisher::publish
void publish(const sensor_msgs::Image &message) const
opencv_apps
Demo code to calculate moments.
Definition: nodelet.h:68
opencv_apps::ThresholdNodelet::config_
Config config_
Definition: threshold_nodelet.cpp:127
image_transport.h
threshold
Definition: threshold_nodelet.cpp:175
opencv_apps::ThresholdNodelet::queue_size_
int queue_size_
Definition: threshold_nodelet.cpp:130
nodelet::Nodelet
opencv_apps::ThresholdNodelet::debug_view_
bool debug_view_
Definition: threshold_nodelet.cpp:131
PLUGINLIB_EXPORT_CLASS
PLUGINLIB_EXPORT_CLASS(opencv_apps::ThresholdNodelet, nodelet::Nodelet)
opencv_apps::ThresholdNodelet::imageCallback
void imageCallback(const sensor_msgs::ImageConstPtr &msg)
Definition: threshold_nodelet.cpp:152
image_transport::Publisher
sensor_msgs::image_encodings::MONO8
const std::string MONO8
cv_bridge.h
opencv_apps::ThresholdNodelet::reconfigureCallback
void reconfigureCallback(Config &config, uint32_t level)
Definition: threshold_nodelet.cpp:173
cv_bridge::CvImage
class_list_macros.hpp
opencv_apps::ThresholdNodelet::imageCallbackWithInfo
void imageCallbackWithInfo(const sensor_msgs::ImageConstPtr &msg, const sensor_msgs::CameraInfoConstPtr &cam_info)
Definition: threshold_nodelet.cpp:147
opencv_apps::ThresholdNodelet::unsubscribe
void unsubscribe()
This method is called when publisher is unsubscribed by other nodes. Shut down subscribers in this me...
Definition: threshold_nodelet.cpp:166
sensor_msgs::image_encodings::BGR8
const std::string BGR8
opencv_apps::ThresholdNodelet
Definition: threshold_nodelet.cpp:88
cv_bridge::toCvShare
CvImageConstPtr toCvShare(const sensor_msgs::Image &source, const boost::shared_ptr< void const > &tracked_object, const std::string &encoding=std::string())
opencv_apps::ThresholdNodelet::it_
boost::shared_ptr< image_transport::ImageTransport > it_
Definition: threshold_nodelet.cpp:139
opencv_apps::Nodelet::nh_
boost::shared_ptr< ros::NodeHandle > nh_
Shared pointer to nodehandle.
Definition: nodelet.h:272
opencv_apps::ThresholdNodelet::apply_otsu_
bool apply_otsu_
Definition: threshold_nodelet.cpp:145
opencv_apps::ThresholdNodelet::threshold_type_
int threshold_type_
Definition: threshold_nodelet.cpp:142
opencv_apps::Nodelet::onInit
virtual void onInit()
Initialize nodehandles nh_ and pnh_. Subclass should call this method in its onInit method.
Definition: nodelet.cpp:60
opencv_apps::Nodelet::pnh_
boost::shared_ptr< ros::NodeHandle > pnh_
Shared pointer to private nodehandle.
Definition: nodelet.h:277
NODELET_DEBUG
#define NODELET_DEBUG(...)
image_transport::Subscriber::shutdown
void shutdown()
opencv_apps::ThresholdNodelet::reconfigure_server_
boost::shared_ptr< ReconfigureServer > reconfigure_server_
Definition: threshold_nodelet.cpp:128


opencv_apps
Author(s): Kei Okada
autogenerated on Fri May 23 2025 02:49:49