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/o2r 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 
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 
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_;
71  private:
72 
73  };
74 
76  {
77  public:
78  MorphologicalImageOperator(const std::string& name, const int& operation):
79  MorphologicalImageOperatorNodelet(name), operation_(operation) {}
80  protected:
81  virtual void apply(
82  const cv::Mat& input, cv::Mat& output, const cv::Mat& element);
84  };
85 
87  {
88  public:
89  Erode(): MorphologicalImageOperator("Erode", cv::MORPH_ERODE) {}
90  };
91 
93  {
94  public:
95  Dilate(): MorphologicalImageOperator("Dilate", cv::MORPH_DILATE) {}
96  };
97 
99  {
100  public:
101  Opening(): MorphologicalImageOperator("Opening", cv::MORPH_OPEN) {}
102  };
103 
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
virtual void imageCallback(const sensor_msgs::Image::ConstPtr &image_msg)
virtual void apply(const cv::Mat &input, cv::Mat &output, const cv::Mat &element)=0
config
input
DiagnosticNodelet(const std::string &name)
jsk_perception::MorphologicalMaskImageOperatorConfig Config
void output(int index, double value)
boost::shared_ptr< dynamic_reconfigure::Server< Config > > srv_
MorphologicalImageOperator(const std::string &name, const int &operation)
virtual void configCallback(Config &config, uint32_t level)


jsk_perception
Author(s): Manabu Saito, Ryohei Ueda
autogenerated on Mon May 3 2021 03:03:27