ITK  6.0.0
Insight Toolkit
itkMeshSource.h
Go to the documentation of this file.
1/*=========================================================================
2 *
3 * Copyright NumFOCUS
4 *
5 * Licensed under the Apache License, Version 2.0 (the "License");
6 * you may not use this file except in compliance with the License.
7 * You may obtain a copy of the License at
8 *
9 * https://www.apache.org/licenses/LICENSE-2.0.txt
10 *
11 * Unless required by applicable law or agreed to in writing, software
12 * distributed under the License is distributed on an "AS IS" BASIS,
13 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14 * See the License for the specific language governing permissions and
15 * limitations under the License.
16 *
17 *=========================================================================*/
18/*=========================================================================
19 *
20 * Portions of this file are subject to the VTK Toolkit Version 3 copyright.
21 *
22 * Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
23 *
24 * For complete copyright, license and disclaimer of warranty information
25 * please refer to the NOTICE file at the top of the ITK source tree.
26 *
27 *=========================================================================*/
28#ifndef itkMeshSource_h
29#define itkMeshSource_h
30
31
32#include "itkProcessObject.h"
33
34namespace itk
35{
48template <typename TOutputMesh>
49class ITK_TEMPLATE_EXPORT MeshSource : public ProcessObject
50{
51public:
52 ITK_DISALLOW_COPY_AND_MOVE(MeshSource);
53
59
61 itkNewMacro(Self);
62
64 itkOverrideGetNameOfClassMacro(MeshSource);
65
68 using OutputMeshType = TOutputMesh;
70
71 using DataObjectIdentifierType = Superclass::DataObjectIdentifierType;
72
76
78 GetOutput(unsigned int idx);
79
83 using Superclass::SetOutput;
84 void
85 SetOutput(TOutputMesh * output);
122 virtual void
124
130 virtual void
132
133 virtual void
134 GraftNthOutput(unsigned int idx, DataObject * graft);
135
150 using Superclass::MakeOutput;
155protected:
157 ~MeshSource() override = default;
158 void
159 PrintSelf(std::ostream & os, Indent indent) const override;
160
164 void
166
167private:
170 int m_GenerateDataRegion{};
171 int m_GenerateDataNumberOfRegions{};
172};
173} // end namespace itk
174
175#ifndef ITK_MANUAL_INSTANTIATION
176# include "itkMeshSource.hxx"
177#endif
178
179#endif
Base class for all data objects in ITK.
SmartPointer< Self > Pointer
Control indentation during Print() invocation.
Definition: itkIndent.h:50
Light weight base class for most itk classes.
Base class for all process objects that output mesh data.
Definition: itkMeshSource.h:50
void SetOutput(TOutputMesh *output)
virtual void GraftNthOutput(unsigned int idx, DataObject *graft)
typename OutputMeshType::Pointer OutputMeshPointer
Definition: itkMeshSource.h:69
virtual void GraftOutput(const DataObjectIdentifierType &key, DataObject *graft)
void GenerateInputRequestedRegion() override
OutputMeshType * GetOutput(unsigned int idx)
~MeshSource() override=default
OutputMeshType * GetOutput()
virtual void GraftOutput(DataObject *graft)
void PrintSelf(std::ostream &os, Indent indent) const override
DataObjectPointer MakeOutput(DataObjectPointerArraySizeType idx) override
TOutputMesh OutputMeshType
Definition: itkMeshSource.h:68
The base class for all process objects (source, filters, mappers) in the Insight data processing pipe...
DataObjectPointerArray::size_type DataObjectPointerArraySizeType
DataObject::DataObjectIdentifierType DataObjectIdentifierType
SmartPointer< Self > Pointer
The "itk" namespace contains all Insight Segmentation and Registration Toolkit (ITK) classes....
class ITK_FORWARD_EXPORT ProcessObject
Definition: itkDataObject.h:41