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/vtkCellDistanceSelector.h

152 lines
4.5 KiB
C

/*=========================================================================
Program: Visualization Toolkit
Module: vtkCellDistanceSelector
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 vtkCellDistanceSelector
* @brief select neighbor cells up to a distance
*
*
* This filter grows an input selection by iteratively selecting neighbor
* cells (a neighbor cell is a cell that shares a vertex/edge/face), up to
* a given topological distance to the selected neighborhood (number of times
* we add neighbor cells).
* This filter takes a vtkSelection and a vtkCompositeDataSet as inputs.
* It outputs a vtkSelection identifying all the selected cells.
*
* @par Thanks:
* This file has been initially developed in the frame of CEA's Love visualization software development <br>
* CEA/DIF - Commissariat a l'Energie Atomique, Centre DAM Ile-De-France <br>
* BP12, F-91297 Arpajon, France. <br>
* Modified and integrated into VTK, Kitware SAS 2012
* Implementation by Thierry Carrard and Philippe Pebay
*/
#ifndef vtkCellDistanceSelector_h
#define vtkCellDistanceSelector_h
#include "vtkFiltersSelectionModule.h" // For export macro
#include "vtkSelectionAlgorithm.h"
#include "vtkSmartPointer.h" // For smart pointers
class vtkDataSet;
class vtkSelection;
class vtkAlgorithmOutput;
class vtkDataArray;
//@{
/**
* Grows a selection, selecting neighbor cells, up to a user defined topological distance
*/
class VTKFILTERSSELECTION_EXPORT vtkCellDistanceSelector : public vtkSelectionAlgorithm
{
public:
vtkTypeMacro(vtkCellDistanceSelector,vtkSelectionAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent) VTK_OVERRIDE;
//@}
static vtkCellDistanceSelector* New();
/**
* enumeration values to specify input port types
*/
enum InputPorts
{
INPUT_MESH = 0, //!< Port 0 is for input mesh
INPUT_SELECTION = 1 //!< Port 1 is for input selection
};
/**
* A convenience method to set the data object input connection to the producer output
*/
void SetInputMeshConnection( vtkAlgorithmOutput* in )
{ this->SetInputConnection( INPUT_MESH, in ); }
/**
* A convenience method to set the input data object
*/
void SetInputMesh( vtkDataObject* obj )
{ this->SetInputData( INPUT_MESH, obj ); }
/**
* A convenience method to set the selection input connection to the producer output
*/
void SetInputSelectionConnection( vtkAlgorithmOutput* in )
{ this->SetInputConnection( INPUT_SELECTION, in ); }
/**
* A convenience method to set the input selection
*/
void SetInputSelection( vtkSelection* obj )
{ this->SetInputData( INPUT_SELECTION, obj ); }
//@{
/**
* Tells how far (in term of topological distance) away from seed cells to expand the selection
*/
vtkSetMacro(Distance,int);
vtkGetMacro(Distance,int);
//@}
//@{
/**
* If set, seed cells passed with SetSeedCells will be included in the final selection
*/
vtkSetMacro(IncludeSeed,int);
vtkGetMacro(IncludeSeed,int);
vtkBooleanMacro(IncludeSeed,int);
//@}
//@{
/**
* If set, intermediate cells (between seed cells and the selection boundary) will be included in the final selection
*/
vtkSetMacro(AddIntermediate,int);
vtkGetMacro(AddIntermediate,int);
vtkBooleanMacro(AddIntermediate,int);
//@}
protected:
vtkCellDistanceSelector ();
virtual ~vtkCellDistanceSelector ();
void AddSelectionNode(vtkSelection* output, vtkSmartPointer<vtkDataArray> outIndices, int partNumber, int d);
virtual int FillInputPortInformation(int port, vtkInformation *info);
virtual int RequestData(vtkInformation*,vtkInformationVector**,vtkInformationVector*);
/**
* Tological radius from seed cells to be used to select cells
* Default: 1
*/
int Distance;
/**
* Decide whether seed cells are included in selection
* Default: 1
*/
int IncludeSeed;
/**
* Decide whether at distance between 1 and Distance-1 are included in selection
* Default: 1
*/
int AddIntermediate;
private:
vtkCellDistanceSelector(const vtkCellDistanceSelector &) VTK_DELETE_FUNCTION;
void operator= (const vtkCellDistanceSelector &) VTK_DELETE_FUNCTION;
};
#endif /* vtkCellDistanceSelector_h */