00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: $RCSfile: vtkExtractGeometry.h,v $ 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 =========================================================================*/ 00043 #ifndef __vtkExtractGeometry_h 00044 #define __vtkExtractGeometry_h 00045 00046 #include "vtkDataSetToUnstructuredGridFilter.h" 00047 00048 class vtkImplicitFunction; 00049 00050 class VTK_GRAPHICS_EXPORT vtkExtractGeometry : public vtkDataSetToUnstructuredGridFilter 00051 { 00052 public: 00053 vtkTypeRevisionMacro(vtkExtractGeometry,vtkDataSetToUnstructuredGridFilter); 00054 void PrintSelf(ostream& os, vtkIndent indent); 00055 00057 static vtkExtractGeometry *New(); 00058 00060 unsigned long GetMTime(); 00061 00063 00064 virtual void SetImplicitFunction(vtkImplicitFunction*); 00065 vtkGetObjectMacro(ImplicitFunction,vtkImplicitFunction); 00067 00069 00072 vtkSetMacro(ExtractInside,int); 00073 vtkGetMacro(ExtractInside,int); 00074 vtkBooleanMacro(ExtractInside,int); 00076 00078 00080 vtkSetMacro(ExtractBoundaryCells,int); 00081 vtkGetMacro(ExtractBoundaryCells,int); 00082 vtkBooleanMacro(ExtractBoundaryCells,int); 00084 00085 protected: 00086 vtkExtractGeometry(vtkImplicitFunction *f=NULL); 00087 ~vtkExtractGeometry(); 00088 00089 // Usual data generation method 00090 void Execute(); 00091 00092 vtkImplicitFunction *ImplicitFunction; 00093 int ExtractInside; 00094 int ExtractBoundaryCells; 00095 00096 private: 00097 vtkExtractGeometry(const vtkExtractGeometry&); // Not implemented. 00098 void operator=(const vtkExtractGeometry&); // Not implemented. 00099 }; 00100 00101 #endif 00102 00103