VTK  9.1.0
vtkVoxelModeller.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkVoxelModeller.h
5
6 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7 All rights reserved.
8 See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9
10 This software is distributed WITHOUT ANY WARRANTY; without even
11 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12 PURPOSE. See the above copyright notice for more information.
13
14=========================================================================*/
50#ifndef vtkVoxelModeller_h
51#define vtkVoxelModeller_h
52
53#include "vtkImageAlgorithm.h"
54#include "vtkImagingHybridModule.h" // For export macro
55
56class VTKIMAGINGHYBRID_EXPORT vtkVoxelModeller : public vtkImageAlgorithm
57{
58public:
60 void PrintSelf(ostream& os, vtkIndent indent) override;
61
70
74 double ComputeModelBounds(double origin[3], double spacing[3]);
75
77
81 void SetSampleDimensions(int i, int j, int k);
82 void SetSampleDimensions(int dim[3]);
83 vtkGetVectorMacro(SampleDimensions, int, 3);
85
87
91 vtkSetClampMacro(MaximumDistance, double, 0.0, 1.0);
92 vtkGetMacro(MaximumDistance, double);
94
96
100 void SetModelBounds(const double bounds[6]);
101 void SetModelBounds(double xmin, double xmax, double ymin, double ymax, double zmin, double zmax);
102 vtkGetVectorMacro(ModelBounds, double, 6);
104
106
112 vtkSetMacro(ScalarType, int);
113 void SetScalarTypeToFloat() { this->SetScalarType(VTK_FLOAT); }
114 void SetScalarTypeToDouble() { this->SetScalarType(VTK_DOUBLE); }
115 void SetScalarTypeToInt() { this->SetScalarType(VTK_INT); }
116 void SetScalarTypeToUnsignedInt() { this->SetScalarType(VTK_UNSIGNED_INT); }
117 void SetScalarTypeToLong() { this->SetScalarType(VTK_LONG); }
118 void SetScalarTypeToUnsignedLong() { this->SetScalarType(VTK_UNSIGNED_LONG); }
119 void SetScalarTypeToShort() { this->SetScalarType(VTK_SHORT); }
120 void SetScalarTypeToUnsignedShort() { this->SetScalarType(VTK_UNSIGNED_SHORT); }
121 void SetScalarTypeToUnsignedChar() { this->SetScalarType(VTK_UNSIGNED_CHAR); }
122 void SetScalarTypeToChar() { this->SetScalarType(VTK_CHAR); }
123 void SetScalarTypeToBit() { this->SetScalarType(VTK_BIT); }
124 vtkGetMacro(ScalarType, int);
126
128
135 vtkSetMacro(ForegroundValue, double);
136 vtkGetMacro(ForegroundValue, double);
137 vtkSetMacro(BackgroundValue, double);
138 vtkGetMacro(BackgroundValue, double);
140
141protected:
143 ~vtkVoxelModeller() override = default;
144
146
147 // see vtkAlgorithm for details
149 vtkInformationVector* outputVector) override;
150
151 // see algorithm for more info
152 int FillInputPortInformation(int port, vtkInformation* info) override;
153
154 int SampleDimensions[3];
156 double ModelBounds[6];
160
161private:
162 vtkVoxelModeller(const vtkVoxelModeller&) = delete;
163 void operator=(const vtkVoxelModeller&) = delete;
164};
165
166#endif
Generic algorithm superclass for image algs.
a simple class to control print indentation
Definition: vtkIndent.h:113
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
convert an arbitrary dataset to a voxel representation
void SetModelBounds(const double bounds[6])
Specify the position in space to perform the voxelization.
void SetScalarTypeToBit()
Control the scalar type of the output image.
void SetSampleDimensions(int i, int j, int k)
Set the i-j-k dimensions on which to sample the distance function.
void SetScalarTypeToUnsignedShort()
Control the scalar type of the output image.
int RequestData(vtkInformation *request, vtkInformationVector **inputVector, vtkInformationVector *outputVector) override
This is called in response to a REQUEST_DATA request from the executive.
void SetScalarTypeToInt()
Control the scalar type of the output image.
void SetScalarTypeToDouble()
Control the scalar type of the output image.
void SetSampleDimensions(int dim[3])
Set the i-j-k dimensions on which to sample the distance function.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
~vtkVoxelModeller() override=default
void SetScalarTypeToShort()
Control the scalar type of the output image.
void SetScalarTypeToChar()
Control the scalar type of the output image.
void SetScalarTypeToUnsignedInt()
Control the scalar type of the output image.
void SetScalarTypeToUnsignedChar()
Control the scalar type of the output image.
int RequestInformation(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
Subclasses can reimplement this method to collect information from their inputs and set information f...
double ComputeModelBounds(double origin[3], double spacing[3])
Compute the ModelBounds based on the input geometry.
int FillInputPortInformation(int port, vtkInformation *info) override
These method should be reimplemented by subclasses that have more than a single input or single outpu...
void SetModelBounds(double xmin, double xmax, double ymin, double ymax, double zmin, double zmax)
Specify the position in space to perform the voxelization.
static vtkVoxelModeller * New()
Construct an instance of vtkVoxelModeller with its sample dimensions set to (50,50,...
void SetScalarTypeToFloat()
Control the scalar type of the output image.
void SetScalarTypeToUnsignedLong()
Control the scalar type of the output image.
void SetScalarTypeToLong()
Control the scalar type of the output image.
#define VTK_SHORT
Definition: vtkType.h:48
#define VTK_UNSIGNED_INT
Definition: vtkType.h:51
#define VTK_DOUBLE
Definition: vtkType.h:55
#define VTK_UNSIGNED_CHAR
Definition: vtkType.h:47
#define VTK_UNSIGNED_SHORT
Definition: vtkType.h:49
#define VTK_INT
Definition: vtkType.h:50
#define VTK_FLOAT
Definition: vtkType.h:54
#define VTK_CHAR
Definition: vtkType.h:45
#define VTK_UNSIGNED_LONG
Definition: vtkType.h:53
#define VTK_BIT
Definition: vtkType.h:44
#define VTK_LONG
Definition: vtkType.h:52