You cannot select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
nmWTAI-Platform/3rd/VTK7.1/include/vtkExtractGeometry.h

116 lines
3.5 KiB
C

/*=========================================================================
Program: Visualization Toolkit
Module: vtkExtractGeometry.h
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
All rights reserved.
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
This software is distributed WITHOUT ANY WARRANTY; without even
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
PURPOSE. See the above copyright notice for more information.
=========================================================================*/
/**
* @class vtkExtractGeometry
* @brief extract cells that lie either entirely inside or outside of a specified implicit function
*
*
* vtkExtractGeometry extracts from its input dataset all cells that are either
* completely inside or outside of a specified implicit function. Any type of
* dataset can be input to this filter. On output the filter generates an
* unstructured grid.
*
* To use this filter you must specify an implicit function. You must also
* specify whethter to extract cells laying inside or outside of the implicit
* function. (The inside of an implicit function is the negative values
* region.) An option exists to extract cells that are neither inside or
* outside (i.e., boundary).
*
* A more efficient version of this filter is available for vtkPolyData input.
* See vtkExtractPolyDataGeometry.
*
* @sa
* vtkExtractPolyDataGeometry vtkGeometryFilter vtkExtractVOI
*/
#ifndef vtkExtractGeometry_h
#define vtkExtractGeometry_h
#include "vtkFiltersExtractionModule.h" // For export macro
#include "vtkUnstructuredGridAlgorithm.h"
class vtkImplicitFunction;
class VTKFILTERSEXTRACTION_EXPORT vtkExtractGeometry : public vtkUnstructuredGridAlgorithm
{
public:
vtkTypeMacro(vtkExtractGeometry,vtkUnstructuredGridAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
/**
* Construct object with ExtractInside turned on.
*/
static vtkExtractGeometry *New();
/**
* Return the MTime taking into account changes to the implicit function
*/
vtkMTimeType GetMTime();
//@{
/**
* Specify the implicit function for inside/outside checks.
*/
virtual void SetImplicitFunction(vtkImplicitFunction*);
vtkGetObjectMacro(ImplicitFunction,vtkImplicitFunction);
//@}
//@{
/**
* Boolean controls whether to extract cells that are inside of implicit
* function (ExtractInside == 1) or outside of implicit function
* (ExtractInside == 0).
*/
vtkSetMacro(ExtractInside,int);
vtkGetMacro(ExtractInside,int);
vtkBooleanMacro(ExtractInside,int);
//@}
//@{
/**
* Boolean controls whether to extract cells that are partially inside.
* By default, ExtractBoundaryCells is off.
*/
vtkSetMacro(ExtractBoundaryCells,int);
vtkGetMacro(ExtractBoundaryCells,int);
vtkBooleanMacro(ExtractBoundaryCells,int);
vtkSetMacro(ExtractOnlyBoundaryCells,int);
vtkGetMacro(ExtractOnlyBoundaryCells,int);
vtkBooleanMacro(ExtractOnlyBoundaryCells,int);
//@}
protected:
vtkExtractGeometry(vtkImplicitFunction *f=NULL);
~vtkExtractGeometry();
// Usual data generation method
virtual int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
virtual int FillInputPortInformation(int port, vtkInformation *info);
vtkImplicitFunction *ImplicitFunction;
int ExtractInside;
int ExtractBoundaryCells;
int ExtractOnlyBoundaryCells;
private:
vtkExtractGeometry(const vtkExtractGeometry&) VTK_DELETE_FUNCTION;
void operator=(const vtkExtractGeometry&) VTK_DELETE_FUNCTION;
};
#endif