VTK
|
00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: vtkRecursiveDividingCubes.h 00005 00006 Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen 00007 All rights reserved. 00008 See Copyright.txt or http://www.kitware.com/Copyright.htm for details. 00009 00010 This software is distributed WITHOUT ANY WARRANTY; without even 00011 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 00012 PURPOSE. See the above copyright notice for more information. 00013 00014 =========================================================================*/ 00039 #ifndef __vtkRecursiveDividingCubes_h 00040 #define __vtkRecursiveDividingCubes_h 00041 00042 #include "vtkFiltersGeneralModule.h" // For export macro 00043 #include "vtkPolyDataAlgorithm.h" 00044 00045 class vtkVoxel; 00046 00047 class VTKFILTERSGENERAL_EXPORT vtkRecursiveDividingCubes : public vtkPolyDataAlgorithm 00048 { 00049 public: 00050 static vtkRecursiveDividingCubes *New(); 00051 vtkTypeMacro(vtkRecursiveDividingCubes,vtkPolyDataAlgorithm); 00052 void PrintSelf(ostream& os, vtkIndent indent); 00053 00055 00056 vtkSetMacro(Value,double); 00057 vtkGetMacro(Value,double); 00059 00061 00062 vtkSetClampMacro(Distance,double,1.0e-06,VTK_DOUBLE_MAX); 00063 vtkGetMacro(Distance,double); 00065 00067 00070 vtkSetClampMacro(Increment,int,1,VTK_INT_MAX); 00071 vtkGetMacro(Increment,int); 00073 00074 protected: 00075 vtkRecursiveDividingCubes(); 00076 ~vtkRecursiveDividingCubes(); 00077 00078 virtual int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *); 00079 virtual int FillInputPortInformation(int port, vtkInformation *info); 00080 void SubDivide(double origin[3], double h[3], double values[8]); 00081 00082 double Value; 00083 double Distance; 00084 int Increment; 00085 00086 // working variable 00087 int Count; 00088 00089 // to replace a static 00090 vtkVoxel *Voxel; 00091 private: 00092 vtkRecursiveDividingCubes(const vtkRecursiveDividingCubes&); // Not implemented. 00093 void operator=(const vtkRecursiveDividingCubes&); // Not implemented. 00094 }; 00095 00096 #endif