00001 /*========================================================================= 00002 00003 Program: Visualization Toolkit 00004 Module: $RCSfile: vtkImageMedian3D.h,v $ 00005 Language: C++ 00006 00007 Copyright (c) 1993-2002 Ken Martin, Will Schroeder, Bill Lorensen 00008 All rights reserved. 00009 See Copyright.txt or http://www.kitware.com/Copyright.htm for details. 00010 00011 This software is distributed WITHOUT ANY WARRANTY; without even 00012 the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR 00013 PURPOSE. See the above copyright notice for more information. 00014 00015 =========================================================================*/ 00032 #ifndef __vtkImageMedian3D_h 00033 #define __vtkImageMedian3D_h 00034 00035 00036 #include "vtkImageSpatialFilter.h" 00037 00038 class VTK_IMAGING_EXPORT vtkImageMedian3D : public vtkImageSpatialFilter 00039 { 00040 public: 00041 static vtkImageMedian3D *New(); 00042 vtkTypeRevisionMacro(vtkImageMedian3D,vtkImageSpatialFilter); 00043 void PrintSelf(ostream& os, vtkIndent indent); 00044 00047 void SetKernelSize(int size0, int size1, int size2); 00048 00050 00051 vtkGetMacro(NumberOfElements,int); 00053 00054 protected: 00055 vtkImageMedian3D(); 00056 ~vtkImageMedian3D(); 00057 00058 int NumberOfElements; 00059 00060 void ThreadedExecute(vtkImageData *inData, vtkImageData *outData, 00061 int extent[6], int id); 00062 00063 void ExecuteInformation(vtkImageData *inData, vtkImageData *outData); 00064 // Called by the superclass 00065 void ExecuteInformation() { this->Superclass::ExecuteInformation(); } 00066 00067 void ExecuteData(vtkDataObject *out); 00068 00069 private: 00070 vtkImageMedian3D(const vtkImageMedian3D&); // Not implemented. 00071 void operator=(const vtkImageMedian3D&); // Not implemented. 00072 }; 00073 00074 #endif 00075 00076 00077