morphological_operator.h
Go to the documentation of this file.
1 // -*- mode: c++ -*-
2 /*********************************************************************
3  * Software License Agreement (BSD License)
4  *
5  * Copyright (c) 2015, 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 
37 #ifndef JSK_PERCEPTION_MORPHOLOGICAL_OPERATOR_H_
38 #define JSK_PERCEPTION_MORPHOLOGICAL_OPERATOR_H_
39 
40 #include <jsk_topic_tools/diagnostic_nodelet.h>
41 #include <sensor_msgs/Image.h>
42 #include <dynamic_reconfigure/server.h>
43 #include <jsk_perception/MorphologicalMaskImageOperatorConfig.h>
44 #include <opencv2/opencv.hpp>
45 
46 namespace jsk_perception
47 {
48 
49  class MorphologicalImageOperatorNodelet:
50  public jsk_topic_tools::DiagnosticNodelet
51  {
52  public:
53  typedef jsk_perception::MorphologicalMaskImageOperatorConfig Config;
54  MorphologicalImageOperatorNodelet(const std::string& name):
55  DiagnosticNodelet(name) {}
56  protected:
57  virtual void onInit();
58  virtual void subscribe();
59  virtual void unsubscribe();
60  virtual void configCallback(Config &config, uint32_t level);
61  virtual void imageCallback(const sensor_msgs::Image::ConstPtr& image_msg);
62  virtual void apply(const cv::Mat& input, cv::Mat& output, const cv::Mat& element) = 0;
63 
64  boost::mutex mutex_;
68  int method_;
69  int size_;
70  int iterations_;
71  private:
72 
73  };
74 
75  class MorphologicalImageOperator: public MorphologicalImageOperatorNodelet
76  {
77  public:
78  MorphologicalImageOperator(const std::string& name, const int& operation):
80  protected:
81  virtual void apply(
82  const cv::Mat& input, cv::Mat& output, const cv::Mat& element);
83  int operation_;
84  };
85 
86  class Erode: public MorphologicalImageOperator
87  {
88  public:
89  Erode(): MorphologicalImageOperator("Erode", cv::MORPH_ERODE) {}
90  };
91 
92  class Dilate: public MorphologicalImageOperator
93  {
94  public:
95  Dilate(): MorphologicalImageOperator("Dilate", cv::MORPH_DILATE) {}
96  };
97 
98  class Opening: public MorphologicalImageOperator
99  {
100  public:
101  Opening(): MorphologicalImageOperator("Opening", cv::MORPH_OPEN) {}
102  };
103 
104  class Closing: public MorphologicalImageOperator
105  {
106  public:
107  Closing(): MorphologicalImageOperator("Closing", cv::MORPH_CLOSE) {}
108  };
109 
111  {
112  public:
114  MorphologicalImageOperator("MorphologicalGradient", cv::MORPH_GRADIENT) {}
115  };
116 
118  {
119  public:
120  TopHat(): MorphologicalImageOperator("TopHat", cv::MORPH_TOPHAT) {}
121  };
122 
124  {
125  public:
126  BlackHat(): MorphologicalImageOperator("BlackHat", cv::MORPH_BLACKHAT) {}
127  };
128 }
129 
130 #endif
jsk_perception::Erode
Definition: morphological_operator.h:118
jsk_perception::MorphologicalImageOperatorNodelet::iterations_
int iterations_
Definition: morphological_operator.h:134
jsk_perception::MorphologicalImageOperatorNodelet::apply
virtual void apply(const cv::Mat &input, cv::Mat &output, const cv::Mat &element)=0
ros::Publisher
boost::shared_ptr
jsk_perception::MorphologicalImageOperatorNodelet::sub_
ros::Subscriber sub_
Definition: morphological_operator.h:129
jsk_perception::Closing::Closing
Closing()
Definition: morphological_operator.h:139
jsk_perception::MorphologicalImageOperator::operation_
int operation_
Definition: morphological_operator.h:115
jsk_perception::MorphologicalImageOperatorNodelet::method_
int method_
Definition: morphological_operator.h:132
jsk_perception::MorphologicalImageOperatorNodelet::unsubscribe
virtual void unsubscribe()
Definition: morphological_operator.cpp:100
jsk_perception::MorphologicalGradient
Definition: morphological_operator.h:142
jsk_perception::MorphologicalImageOperatorNodelet::MorphologicalImageOperatorNodelet
MorphologicalImageOperatorNodelet(const std::string &name)
Definition: morphological_operator.h:118
jsk_perception::MorphologicalImageOperator
Definition: morphological_operator.h:107
jsk_perception::TopHat::TopHat
TopHat()
Definition: morphological_operator.h:152
jsk_perception::Erode::Erode
Erode()
Definition: morphological_operator.h:121
jsk_perception::MorphologicalImageOperatorNodelet::mutex_
boost::mutex mutex_
Definition: morphological_operator.h:128
jsk_perception::MorphologicalGradient::MorphologicalGradient
MorphologicalGradient()
Definition: morphological_operator.h:145
jsk_perception::MorphologicalImageOperatorNodelet::Config
jsk_perception::MorphologicalMaskImageOperatorConfig Config
Definition: morphological_operator.h:117
jsk_perception
Definition: add_mask_image.h:48
jsk_perception::MorphologicalImageOperatorNodelet::subscribe
virtual void subscribe()
Definition: morphological_operator.cpp:92
jsk_perception::Opening::Opening
Opening()
Definition: morphological_operator.h:133
jsk_perception::MorphologicalImageOperatorNodelet::size_
int size_
Definition: morphological_operator.h:133
jsk_perception::MorphologicalImageOperatorNodelet::srv_
boost::shared_ptr< dynamic_reconfigure::Server< Config > > srv_
Definition: morphological_operator.h:131
jsk_perception::MorphologicalImageOperatorNodelet::configCallback
virtual void configCallback(Config &config, uint32_t level)
Definition: morphological_operator.cpp:105
jsk_perception::BlackHat::BlackHat
BlackHat()
Definition: morphological_operator.h:158
jsk_perception::Dilate::Dilate
Dilate()
Definition: morphological_operator.h:127
jsk_perception::MorphologicalImageOperatorNodelet::imageCallback
virtual void imageCallback(const sensor_msgs::Image::ConstPtr &image_msg)
Definition: morphological_operator.cpp:114
jsk_perception::MorphologicalImageOperator::MorphologicalImageOperator
MorphologicalImageOperator(const std::string &name, const int &operation)
Definition: morphological_operator.h:110
cv
node_scripts.craft.craft.output
output
Definition: craft.py:107
jsk_perception::MorphologicalImageOperator::apply
virtual void apply(const cv::Mat &input, cv::Mat &output, const cv::Mat &element)
Definition: morphological_operator.cpp:142
jsk_perception::MorphologicalImageOperatorNodelet::pub_
ros::Publisher pub_
Definition: morphological_operator.h:130
jsk_perception::TopHat
Definition: morphological_operator.h:149
jsk_perception::MorphologicalImageOperatorNodelet::onInit
virtual void onInit()
Definition: morphological_operator.cpp:79
ros::Subscriber
jsk_perception::BlackHat
Definition: morphological_operator.h:155


jsk_perception
Author(s): Manabu Saito, Ryohei Ueda
autogenerated on Fri May 16 2025 03:11:17