Slicer  5.0
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
vtkClosedSurfaceToBinaryLabelmapConversionRule.h
Go to the documentation of this file.
1 /*==============================================================================
2 
3  Copyright (c) Laboratory for Percutaneous Surgery (PerkLab)
4  Queen's University, Kingston, ON, Canada. All Rights Reserved.
5 
6  See COPYRIGHT.txt
7  or http://www.slicer.org/copyright/copyright.txt for details.
8 
9  Unless required by applicable law or agreed to in writing, software
10  distributed under the License is distributed on an "AS IS" BASIS,
11  WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12  See the License for the specific language governing permissions and
13  limitations under the License.
14 
15  This file was originally developed by Csaba Pinter, PerkLab, Queen's University
16  and was supported through the Applied Cancer Research Unit program of Cancer Care
17  Ontario with funds provided by the Ontario Ministry of Health and Long-Term Care
18 
19 ==============================================================================*/
20 
21 #ifndef __vtkClosedSurfaceToBinaryLabelmapConversionRule_h
22 #define __vtkClosedSurfaceToBinaryLabelmapConversionRule_h
23 
24 // SegmentationCore includes
27 
28 #include "vtkSegmentationCoreConfigure.h"
29 
30 class vtkPolyData;
31 
36 class vtkSegmentationCore_EXPORT vtkClosedSurfaceToBinaryLabelmapConversionRule
38 {
39 public:
44  static const std::string GetOversamplingFactorParameterName() { return "Oversampling factor"; };
45  static const std::string GetCropToReferenceImageGeometryParameterName() { return "Crop to reference image geometry"; };
48  static const std::string GetCollapseLabelmapsParameterName() { return "Collapse labelmaps"; };
49 
50 public:
54 
58  vtkDataObject* ConstructRepresentationObjectByRepresentation(std::string representationName) override;
59 
63  vtkDataObject* ConstructRepresentationObjectByClass(std::string className) override;
64 
66  bool Convert(vtkSegment* segment) override;
67 
70  bool PostConvert(vtkSegmentation* segmentation) override;
71 
73  unsigned int GetConversionCost(vtkDataObject* sourceRepresentation=nullptr, vtkDataObject* targetRepresentation=nullptr) override;
74 
76  const char* GetName() override { return "Closed surface to binary labelmap (simple image stencil)"; };
77 
80 
83 
84  vtkSetMacro(UseOutputImageDataGeometry, bool);
85 
86 protected:
92  bool CalculateOutputGeometry(vtkPolyData* closedSurfacePolyData, vtkOrientedImageData* geometryImageData);
93 
99  std::string GetDefaultImageGeometryStringForPolyData(vtkPolyData* polyData);
100 
101 protected:
107  bool UseOutputImageDataGeometry{false};
108 
109 protected:
112 
113 private:
116 };
117 
118 #endif // __vtkClosedSurfaceToBinaryLabelmapConversionRule_h
This class encapsulates a segment that is part of a segmentation.
Definition: vtkSegment.h:45
virtual vtkDataObject * ConstructRepresentationObjectByRepresentation(std::string representationName)=0
virtual bool PostConvert(vtkSegmentation *vtkNotUsed(segmentation))
void operator=(const vtkSegmentationConverterRule &)
static const char * GetSegmentationBinaryLabelmapRepresentationName()
Abstract converter rule class. Subclasses perform conversions between specific representation types...
virtual vtkDataObject * ConstructRepresentationObjectByClass(std::string className)=0
const char * GetSourceRepresentationName() override
Human-readable name of the source representation.
Image data containing orientation information.
Convert closed surface representation (vtkPolyData type) to binary labelmap representation (vtkOrient...
virtual unsigned int GetConversionCost(vtkDataObject *sourceRepresentation=nullptr, vtkDataObject *targetRepresentation=nullptr)
static const char * GetSegmentationClosedSurfaceRepresentationName()
const char * GetName() override
Human-readable name of the converter rule.
This class encapsulates a segmentation that can contain multiple segments and multiple representation...
virtual vtkSegmentationConverterRule * CreateRuleInstance()=0
virtual bool Convert(vtkSegment *segment)=0
const char * GetTargetRepresentationName() override
Human-readable name of the target representation.