VTK
vtkVoxelContoursToSurfaceFilter.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkVoxelContoursToSurfaceFilter.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 =========================================================================*/
43 #ifndef vtkVoxelContoursToSurfaceFilter_h
44 #define vtkVoxelContoursToSurfaceFilter_h
45 
46 #include "vtkFiltersGeneralModule.h" // For export macro
47 #include "vtkPolyDataAlgorithm.h"
48 
49 class VTKFILTERSGENERAL_EXPORT vtkVoxelContoursToSurfaceFilter : public vtkPolyDataAlgorithm
50 {
51 public:
54  void PrintSelf(ostream& os, vtkIndent indent) VTK_OVERRIDE;
55 
57 
63  vtkSetMacro( MemoryLimitInBytes, int );
64  vtkGetMacro( MemoryLimitInBytes, int );
66 
67  vtkSetVector3Macro( Spacing, double );
68  vtkGetVectorMacro( Spacing, double, 3 );
69 
70 protected:
72  ~vtkVoxelContoursToSurfaceFilter() VTK_OVERRIDE;
73 
74  int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *) VTK_OVERRIDE;
75 
76  int MemoryLimitInBytes;
77 
78  double Spacing[3];
79 
80  double *LineList;
81  int LineListLength;
82  int LineListSize;
83 
84  double *SortedXList;
85  double *SortedYList;
86  int SortedListSize;
87 
88  int *WorkingList;
89  int WorkingListLength;
90 
91  double *IntersectionList;
92  int IntersectionListLength;
93 
94  void AddLineToLineList( double x1, double y1, double x2, double y2 );
95  void SortLineList();
96 
97  void CastLines( float *slice, double gridOrigin[3],
98  int gridSize[3], int type );
99 
100  void PushDistances( float *ptr, int gridSize[3], int chunkSize );
101 private:
103  void operator=(const vtkVoxelContoursToSurfaceFilter&) VTK_DELETE_FUNCTION;
104 };
105 
106 #endif
Store vtkAlgorithm input/output information.
static vtkPolyDataAlgorithm * New()
Superclass for algorithms that produce only polydata as output.
a simple class to control print indentation
Definition: vtkIndent.h:33
vtkSetMacro(IgnoreDriverBugs, bool)
When set known driver bugs are ignored during driver feature detection.
Store zero or more vtkInformation instances.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.