Slicer  5.0
Slicer is a multi-platform, free and open source software package for visualization and medical image computing
vtkFractionalLabelmapToClosedSurfaceConversionRule.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 Kyle Sunderland, 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 __vtkFractionalLabelmapToClosedSurfaceConversionRule_h
22 #define __vtkFractionalLabelmapToClosedSurfaceConversionRule_h
23 
24 // SegmentationCore includes
27 #include "vtkSegmentationCoreConfigure.h"
28 
36 {
37 public:
39  static const std::string GetFractionalLabelMapOversamplingFactorParameterName() { return "Fractional labelmap oversampling factor"; };
40  static const std::string GetThresholdFractionParameterName() { return "Threshold fraction"; };
41 
42 public:
46 
50  vtkDataObject* ConstructRepresentationObjectByRepresentation(std::string representationName) override;
51 
55  vtkDataObject* ConstructRepresentationObjectByClass(std::string className) override;
56 
58  bool Convert(vtkSegment* segment) override;
59 
61  unsigned int GetConversionCost(vtkDataObject* sourceRepresentation=nullptr, vtkDataObject* targetRepresentation=nullptr) override;
62 
64  const char* GetName() override { return "Fractional labelmap to closed surface"; };
65 
68 
71 
72 protected:
73 
77  void PadLabelmap(vtkOrientedImageData* fractionalLabelMap, double paddingConstant);
78 
79 protected:
82 
83 private:
85  void operator=(const vtkFractionalLabelmapToClosedSurfaceConversionRule&) = delete;
86 };
87 
88 #endif // __vtkFractionalLabelmapToClosedSurfaceConversionRule_h
Convert binary labelmap representation (vtkOrientedImageData type) to closed surface representation (...
This class encapsulates a segment that is part of a segmentation.
Definition: vtkSegment.h:45
Convert Fractional labelmap representation (vtkOrientedImageData type) to closed surface representati...
static vtkBinaryLabelmapToClosedSurfaceConversionRule * New()
const char * GetSourceRepresentationName() override
Human-readable name of the source representation.
const char * GetName() override
Human-readable name of the converter rule.
Abstract converter rule class. Subclasses perform conversions between specific representation types...
Image data containing orientation information.
vtkDataObject * ConstructRepresentationObjectByRepresentation(std::string representationName) override
static const char * GetSegmentationClosedSurfaceRepresentationName()
bool Convert(vtkSegment *segment) override
Update the target representation based on the source representation.
unsigned int GetConversionCost(vtkDataObject *sourceRepresentation=nullptr, vtkDataObject *targetRepresentation=nullptr) override
Get the cost of the conversion.
static const char * GetSegmentationFractionalLabelmapRepresentationName()
static const std::string GetFractionalLabelMapOversamplingFactorParameterName()
Conversion parameter: magnification factor.
vtkDataObject * ConstructRepresentationObjectByClass(std::string className) override
vtkSegmentationConverterRule * CreateRuleInstance() override
const char * GetTargetRepresentationName() override
Human-readable name of the target representation.