OTB  9.0.0
Orfeo Toolbox
otbWatershedSegmentationFilter.hxx
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2005-2022 Centre National d'Etudes Spatiales (CNES)
3  *
4  * This file is part of Orfeo Toolbox
5  *
6  * https://www.orfeo-toolbox.org/
7  *
8  * Licensed under the Apache License, Version 2.0 (the "License");
9  * you may not use this file except in compliance with the License.
10  * You may obtain a copy of the License at
11  *
12  * http://www.apache.org/licenses/LICENSE-2.0
13  *
14  * Unless required by applicable law or agreed to in writing, software
15  * distributed under the License is distributed on an "AS IS" BASIS,
16  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
17  * See the License for the specific language governing permissions and
18  * limitations under the License.
19  */
20 
21 #ifndef otbWatershedSegmentationFilter_hxx
22 #define otbWatershedSegmentationFilter_hxx
23 
25 
26 namespace otb
27 {
28 
29 template <class TInputImage, class TOutputLabelImage>
31 {
32  m_WatershedFilter = WatershedFilterType::New();
33  m_CastFilter = CastImageFilterType::New();
34  m_CastFilter->SetInput(m_WatershedFilter->GetOutput());
35  this->SetNthOutput(0, TOutputLabelImage::New());
36 }
37 
38 template <class TInputImage, class TOutputLabelImage>
40 {
41 }
42 
43 
44 template <class TInputImage, class TOutputLabelImage>
46 {
47  this->m_WatershedFilter->SetInput(this->GetInput());
48  m_CastFilter->GraftOutput(this->GetOutput());
49  m_CastFilter->Update();
50  this->GraftOutput(m_CastFilter->GetOutput());
51 
52  // Since WatershedFilterType outputs an itk::Image,
53  // we loose the additional metadata of OTB like ProjectionRef.
54  // Import them before exiting
55  this->GetOutput()->CopyInformation(this->GetInput());
56 }
57 
58 } // end namespace otb
59 #endif
otb::WatershedSegmentationFilter::WatershedSegmentationFilter
WatershedSegmentationFilter()
Definition: otbWatershedSegmentationFilter.hxx:30
otb
The "otb" namespace contains all Orfeo Toolbox (OTB) classes.
Definition: otbJoinContainer.h:32
otb::WatershedSegmentationFilter::GenerateData
void GenerateData() override
Definition: otbWatershedSegmentationFilter.hxx:45
otbWatershedSegmentationFilter.h
otb::WatershedSegmentationFilter::~WatershedSegmentationFilter
~WatershedSegmentationFilter() override
Definition: otbWatershedSegmentationFilter.hxx:39