OTB  9.0.0
Orfeo Toolbox
otbPointSetToPointSetFilter.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 otbPointSetToPointSetFilter_hxx
22 #define otbPointSetToPointSetFilter_hxx
23 
25 
26 namespace otb
27 {
28 
32 template <class TInputPointSet, class TOutputPointSet>
34 {
35  this->SetNumberOfRequiredInputs(1);
36 }
37 
41 template <class TInputPointSet, class TOutputPointSet>
43 {
44  // process object is not const-correct, the const_cast
45  // is required here.
46  this->ProcessObjectType::SetNthInput(idx, const_cast<InputPointSetType*>(input));
47  this->GetInput()->ReleaseDataFlagOff();
48 }
50 
54 template <class TInputPointSet, class TOutputPointSet>
56 {
57  // process object is not const-correct, the const_cast
58  // is required here.
59  this->ProcessObjectType::SetNthInput(0, const_cast<InputPointSetType*>(input));
60  this->GetInput()->ReleaseDataFlagOff();
61 }
63 
67 template <class TInputPointSet, class TOutputPointSet>
70 {
71 
72  return static_cast<InputPointSetType*>(this->ProcessObjectType::GetInput(idx));
73 }
74 
78 template <class TInputPointSet, class TOutputPointSet>
80 {
81  if (this->GetNumberOfInputs() < 1)
82  return nullptr;
83 
84  return static_cast<InputPointSetType*>(this->ProcessObjectType::GetInput(0));
85 }
86 
90 template <class TInputPointSet, class TOutputPointSet>
91 void PointSetToPointSetFilter<TInputPointSet, TOutputPointSet>::PrintSelf(std::ostream& os, itk::Indent indent) const
92 {
93  Superclass::PrintSelf(os, indent);
94 }
95 
96 } // end namespace otb
97 
98 #endif
otb::PointSetToPointSetFilter::PointSetToPointSetFilter
PointSetToPointSetFilter()
Definition: otbPointSetToPointSetFilter.hxx:33
otb
The "otb" namespace contains all Orfeo Toolbox (OTB) classes.
Definition: otbJoinContainer.h:32
otb::PointSetToPointSetFilter::GetInput
InputPointSetType * GetInput()
Definition: otbPointSetToPointSetFilter.hxx:79
otb::PointSetToPointSetFilter::PrintSelf
void PrintSelf(std::ostream &os, itk::Indent indent) const override
Definition: otbPointSetToPointSetFilter.hxx:91
otbPointSetToPointSetFilter.h
otb::PointSetToPointSetFilter::SetInput
void SetInput(unsigned int idx, const InputPointSetType *input)
Definition: otbPointSetToPointSetFilter.hxx:42
otb::PointSetToPointSetFilter::InputPointSetType
TInputPointSet InputPointSetType
Definition: otbPointSetToPointSetFilter.h:52