VTK  9.1.0
vtkImageResample.h
Go to the documentation of this file.
1/*=========================================================================
2
3 Program: Visualization Toolkit
4 Module: vtkImageResample.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=========================================================================*/
34#ifndef vtkImageResample_h
35#define vtkImageResample_h
36
37#include "vtkImageReslice.h"
38#include "vtkImagingCoreModule.h" // For export macro
39
40class VTKIMAGINGCORE_EXPORT vtkImageResample : public vtkImageReslice
41{
42public:
45 void PrintSelf(ostream& os, vtkIndent indent) override;
46
48
52 void SetOutputSpacing(double sx, double sy, double sz) override;
53 void SetOutputSpacing(const double spacing[3]) override
54 {
55 this->SetOutputSpacing(spacing[0], spacing[1], spacing[2]);
56 }
57 void SetAxisOutputSpacing(int axis, double spacing);
59
61
65 void SetMagnificationFactors(double fx, double fy, double fz);
66 void SetMagnificationFactors(const double f[3])
67 {
68 this->SetMagnificationFactors(f[0], f[1], f[2]);
69 }
70 vtkGetVector3Macro(MagnificationFactors, double);
71 void SetAxisMagnificationFactor(int axis, double factor);
73
78 double GetAxisMagnificationFactor(int axis, vtkInformation* inInfo = nullptr);
79
81
87 vtkSetMacro(Dimensionality, int);
88 vtkGetMacro(Dimensionality, int);
90
91protected:
93 ~vtkImageResample() override = default;
94
95 double MagnificationFactors[3];
97
99
100private:
101 vtkImageResample(const vtkImageResample&) = delete;
102 void operator=(const vtkImageResample&) = delete;
103};
104
105#endif
Resamples an image to be larger or smaller.
void SetAxisMagnificationFactor(int axis, double factor)
Set/Get Magnification factors.
void SetMagnificationFactors(double fx, double fy, double fz)
Set/Get Magnification factors.
void SetMagnificationFactors(const double f[3])
Set/Get Magnification factors.
~vtkImageResample() override=default
void SetOutputSpacing(const double spacing[3]) override
Set desired spacing.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
double GetAxisMagnificationFactor(int axis, vtkInformation *inInfo=nullptr)
Get the computed magnification factor for a specific axis.
static vtkImageResample * New()
void SetAxisOutputSpacing(int axis, double spacing)
Set desired spacing.
void SetOutputSpacing(double sx, double sy, double sz) override
Set desired spacing.
int RequestInformation(vtkInformation *, vtkInformationVector **, vtkInformationVector *) override
Subclasses can reimplement this method to collect information from their inputs and set information f...
Reslices a volume along a new set of axes.
virtual void SetOutputSpacing(double x, double y, double z)
Set the voxel spacing for the output data.
a simple class to control print indentation
Definition: vtkIndent.h:43
Store zero or more vtkInformation instances.
Store vtkAlgorithm input/output information.
@ spacing
Definition: vtkX3D.h:487