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.

115 lines
3.7 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 whether 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) override;
/**
* Construct object with ExtractInside turned on.
*/
static vtkExtractGeometry* New();
/**
* Return the MTime taking into account changes to the implicit function
*/
vtkMTimeType GetMTime() override;
//@{
/**
* 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, vtkTypeBool);
vtkGetMacro(ExtractInside, vtkTypeBool);
vtkBooleanMacro(ExtractInside, vtkTypeBool);
//@}
//@{
/**
* Boolean controls whether to extract cells that are partially inside.
* By default, ExtractBoundaryCells is off.
*/
vtkSetMacro(ExtractBoundaryCells, vtkTypeBool);
vtkGetMacro(ExtractBoundaryCells, vtkTypeBool);
vtkBooleanMacro(ExtractBoundaryCells, vtkTypeBool);
vtkSetMacro(ExtractOnlyBoundaryCells, vtkTypeBool);
vtkGetMacro(ExtractOnlyBoundaryCells, vtkTypeBool);
vtkBooleanMacro(ExtractOnlyBoundaryCells, vtkTypeBool);
//@}
protected:
vtkExtractGeometry(vtkImplicitFunction* f = nullptr);
~vtkExtractGeometry() override;
// Usual data generation method
int RequestData(vtkInformation*, vtkInformationVector**, vtkInformationVector*) override;
int FillInputPortInformation(int port, vtkInformation* info) override;
vtkImplicitFunction* ImplicitFunction;
vtkTypeBool ExtractInside;
vtkTypeBool ExtractBoundaryCells;
vtkTypeBool ExtractOnlyBoundaryCells;
private:
vtkExtractGeometry(const vtkExtractGeometry&) = delete;
void operator=(const vtkExtractGeometry&) = delete;
};
#endif