VTK
|
00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: vtkCubeSource.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 =========================================================================*/ 00029 #ifndef __vtkCubeSource_h 00030 #define __vtkCubeSource_h 00031 00032 #include "vtkPolyDataAlgorithm.h" 00033 00034 class VTK_GRAPHICS_EXPORT vtkCubeSource : public vtkPolyDataAlgorithm 00035 { 00036 public: 00037 static vtkCubeSource *New(); 00038 vtkTypeMacro(vtkCubeSource,vtkPolyDataAlgorithm); 00039 void PrintSelf(ostream& os, vtkIndent indent); 00040 00042 00043 vtkSetClampMacro(XLength,double,0.0,VTK_DOUBLE_MAX); 00044 vtkGetMacro(XLength,double); 00046 00048 00049 vtkSetClampMacro(YLength,double,0.0,VTK_DOUBLE_MAX); 00050 vtkGetMacro(YLength,double); 00052 00054 00055 vtkSetClampMacro(ZLength,double,0.0,VTK_DOUBLE_MAX); 00056 vtkGetMacro(ZLength,double); 00058 00060 00061 vtkSetVector3Macro(Center,double); 00062 vtkGetVectorMacro(Center,double,3); 00064 00066 00068 void SetBounds(double xMin, double xMax, 00069 double yMin, double yMax, 00070 double zMin, double zMax); 00071 void SetBounds(double bounds[6]); 00073 00074 protected: 00075 vtkCubeSource(double xL=1.0, double yL=1.0, double zL=1.0); 00076 ~vtkCubeSource() {}; 00077 00078 int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *); 00079 double XLength; 00080 double YLength; 00081 double ZLength; 00082 double Center[3]; 00083 private: 00084 vtkCubeSource(const vtkCubeSource&); // Not implemented. 00085 void operator=(const vtkCubeSource&); // Not implemented. 00086 }; 00087 00088 #endif