VTK
Public Types | Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes
vtkCleanPolyData Class Reference

merge duplicate points, and/or remove unused points and/or remove degenerate cells More...

#include <vtkCleanPolyData.h>

Inheritance diagram for vtkCleanPolyData:
Inheritance graph
[legend]
Collaboration diagram for vtkCleanPolyData:
Collaboration graph
[legend]

List of all members.

Public Types

typedef vtkPolyDataAlgorithm Superclass

Public Member Functions

void PrintSelf (ostream &os, vtkIndent indent)
virtual int IsA (const char *type)
vtkCleanPolyDataNewInstance () const
void CreateDefaultLocator (vtkPolyData *input=0)
void ReleaseLocator ()
unsigned long int GetMTime ()
virtual void OperateOnPoint (double in[3], double out[3])
virtual void OperateOnBounds (double in[6], double out[6])
virtual void SetPieceInvariant (int)
virtual int GetPieceInvariant ()
virtual void PieceInvariantOn ()
virtual void PieceInvariantOff ()
virtual void SetToleranceIsAbsolute (int)
virtual void ToleranceIsAbsoluteOn ()
virtual void ToleranceIsAbsoluteOff ()
virtual int GetToleranceIsAbsolute ()
virtual void SetTolerance (double)
virtual double GetTolerance ()
virtual void SetAbsoluteTolerance (double)
virtual double GetAbsoluteTolerance ()
virtual void SetConvertLinesToPoints (int)
virtual void ConvertLinesToPointsOn ()
virtual void ConvertLinesToPointsOff ()
virtual int GetConvertLinesToPoints ()
virtual void SetConvertPolysToLines (int)
virtual void ConvertPolysToLinesOn ()
virtual void ConvertPolysToLinesOff ()
virtual int GetConvertPolysToLines ()
virtual void SetConvertStripsToPolys (int)
virtual void ConvertStripsToPolysOn ()
virtual void ConvertStripsToPolysOff ()
virtual int GetConvertStripsToPolys ()
virtual void SetPointMerging (int)
virtual int GetPointMerging ()
virtual void PointMergingOn ()
virtual void PointMergingOff ()
virtual void SetLocator (vtkIncrementalPointLocator *locator)
virtual
vtkIncrementalPointLocator
GetLocator ()

Static Public Member Functions

static vtkCleanPolyDataNew ()
static int IsTypeOf (const char *type)
static vtkCleanPolyDataSafeDownCast (vtkObjectBase *o)

Protected Member Functions

virtual vtkObjectBaseNewInstanceInternal () const
 vtkCleanPolyData ()
 ~vtkCleanPolyData ()
virtual int RequestData (vtkInformation *, vtkInformationVector **, vtkInformationVector *)
virtual int RequestInformation (vtkInformation *, vtkInformationVector **, vtkInformationVector *)
virtual int RequestUpdateExtent (vtkInformation *, vtkInformationVector **, vtkInformationVector *)

Protected Attributes

int PointMerging
double Tolerance
double AbsoluteTolerance
int ConvertLinesToPoints
int ConvertPolysToLines
int ConvertStripsToPolys
int ToleranceIsAbsolute
vtkIncrementalPointLocatorLocator
int PieceInvariant

Detailed Description

merge duplicate points, and/or remove unused points and/or remove degenerate cells

vtkCleanPolyData is a filter that takes polygonal data as input and generates polygonal data as output. vtkCleanPolyData will merge duplicate points (within specified tolerance and if enabled), eliminate points that are not used in any cell, and if enabled, transform degenerate cells into appropriate forms (for example, a triangle is converted into a line if two points of triangle are merged).

Conversion of degenerate cells is controlled by the flags ConvertLinesToPoints, ConvertPolysToLines, ConvertStripsToPolys which act cumulatively such that a degenerate strip may become a poly. The full set is Line with 1 points -> Vert (if ConvertLinesToPoints) Poly with 2 points -> Line (if ConvertPolysToLines) Poly with 1 points -> Vert (if ConvertPolysToLines && ConvertLinesToPoints) Strp with 3 points -> Poly (if ConvertStripsToPolys) Strp with 2 points -> Line (if ConvertStripsToPolys && ConvertPolysToLines) Strp with 1 points -> Vert (if ConvertStripsToPolys && ConvertPolysToLines && ConvertLinesToPoints)

If tolerance is specified precisely=0.0, then vtkCleanPolyData will use the vtkMergePoints object to merge points (which is faster). Otherwise the slower vtkIncrementalPointLocator is used. Before inserting points into the point locator, this class calls a function OperateOnPoint which can be used (in subclasses) to further refine the cleaning process. See vtkQuantizePolyDataPoints.

Note that merging of points can be disabled. In this case, a point locator will not be used, and points that are not used by any cells will be eliminated, but never merged.

Warning:
Merging points can alter topology, including introducing non-manifold forms. The tolerance should be chosen carefully to avoid these problems. Subclasses should handle OperateOnBounds as well as OperateOnPoint to ensure that the locator is correctly initialized (i.e. all modified points must lie inside modified bounds).
If you wish to operate on a set of coordinates that has no cells, you must add a vtkPolyVertex cell with all of the points to the PolyData (or use a vtkVertexGlyphFilter) before using the vtkCleanPolyData filter.
See also:
vtkQuantizePolyDataPoints
Examples:
vtkCleanPolyData (Examples)
Tests:
vtkCleanPolyData (Tests)

Definition at line 78 of file vtkCleanPolyData.h.


Member Typedef Documentation

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

Definition at line 83 of file vtkCleanPolyData.h.


Constructor & Destructor Documentation


Member Function Documentation

Create an object with Debug turned off, modified time initialized to zero, and reference counting on.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

void vtkCleanPolyData::PrintSelf ( ostream &  os,
vtkIndent  indent 
) [virtual]

Methods invoked by print to print information about the object including superclasses. Typically not called by the user (use Print() instead) but used in the hierarchical print process to combine the output of several classes.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

static int vtkCleanPolyData::IsTypeOf ( const char *  name) [static]

Return 1 if this class type is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

virtual int vtkCleanPolyData::IsA ( const char *  name) [virtual]

Return 1 if this class is the same type of (or a subclass of) the named class. Returns 0 otherwise. This method works in combination with vtkTypeMacro found in vtkSetGet.h.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

virtual vtkObjectBase* vtkCleanPolyData::NewInstanceInternal ( ) const [protected, virtual]

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented in vtkQuantizePolyDataPoints.

virtual void vtkCleanPolyData::SetToleranceIsAbsolute ( int  ) [virtual]

By default ToleranceIsAbsolute is false and Tolerance is a fraction of Bounding box diagonal, if true, AbsoluteTolerance is used when adding points to locator (merging)

virtual void vtkCleanPolyData::ToleranceIsAbsoluteOn ( ) [virtual]

By default ToleranceIsAbsolute is false and Tolerance is a fraction of Bounding box diagonal, if true, AbsoluteTolerance is used when adding points to locator (merging)

virtual void vtkCleanPolyData::ToleranceIsAbsoluteOff ( ) [virtual]

By default ToleranceIsAbsolute is false and Tolerance is a fraction of Bounding box diagonal, if true, AbsoluteTolerance is used when adding points to locator (merging)

By default ToleranceIsAbsolute is false and Tolerance is a fraction of Bounding box diagonal, if true, AbsoluteTolerance is used when adding points to locator (merging)

virtual void vtkCleanPolyData::SetTolerance ( double  ) [virtual]

Specify tolerance in terms of fraction of bounding box length. Default is 0.0.

virtual double vtkCleanPolyData::GetTolerance ( ) [virtual]

Specify tolerance in terms of fraction of bounding box length. Default is 0.0.

virtual void vtkCleanPolyData::SetAbsoluteTolerance ( double  ) [virtual]

Specify tolerance in absolute terms. Default is 1.0.

Specify tolerance in absolute terms. Default is 1.0.

virtual void vtkCleanPolyData::SetConvertLinesToPoints ( int  ) [virtual]

Turn on/off conversion of degenerate lines to points. Default is On.

virtual void vtkCleanPolyData::ConvertLinesToPointsOn ( ) [virtual]

Turn on/off conversion of degenerate lines to points. Default is On.

virtual void vtkCleanPolyData::ConvertLinesToPointsOff ( ) [virtual]

Turn on/off conversion of degenerate lines to points. Default is On.

Turn on/off conversion of degenerate lines to points. Default is On.

virtual void vtkCleanPolyData::SetConvertPolysToLines ( int  ) [virtual]

Turn on/off conversion of degenerate polys to lines. Default is On.

virtual void vtkCleanPolyData::ConvertPolysToLinesOn ( ) [virtual]

Turn on/off conversion of degenerate polys to lines. Default is On.

virtual void vtkCleanPolyData::ConvertPolysToLinesOff ( ) [virtual]

Turn on/off conversion of degenerate polys to lines. Default is On.

Turn on/off conversion of degenerate polys to lines. Default is On.

virtual void vtkCleanPolyData::SetConvertStripsToPolys ( int  ) [virtual]

Turn on/off conversion of degenerate strips to polys. Default is On.

virtual void vtkCleanPolyData::ConvertStripsToPolysOn ( ) [virtual]

Turn on/off conversion of degenerate strips to polys. Default is On.

virtual void vtkCleanPolyData::ConvertStripsToPolysOff ( ) [virtual]

Turn on/off conversion of degenerate strips to polys. Default is On.

Turn on/off conversion of degenerate strips to polys. Default is On.

virtual void vtkCleanPolyData::SetPointMerging ( int  ) [virtual]

Set/Get a boolean value that controls whether point merging is performed. If on, a locator will be used, and points laying within the appropriate tolerance may be merged. If off, points are never merged. By default, merging is on.

virtual int vtkCleanPolyData::GetPointMerging ( ) [virtual]

Set/Get a boolean value that controls whether point merging is performed. If on, a locator will be used, and points laying within the appropriate tolerance may be merged. If off, points are never merged. By default, merging is on.

virtual void vtkCleanPolyData::PointMergingOn ( ) [virtual]

Set/Get a boolean value that controls whether point merging is performed. If on, a locator will be used, and points laying within the appropriate tolerance may be merged. If off, points are never merged. By default, merging is on.

virtual void vtkCleanPolyData::PointMergingOff ( ) [virtual]

Set/Get a boolean value that controls whether point merging is performed. If on, a locator will be used, and points laying within the appropriate tolerance may be merged. If off, points are never merged. By default, merging is on.

virtual void vtkCleanPolyData::SetLocator ( vtkIncrementalPointLocator locator) [virtual]

Set/Get a spatial locator for speeding the search process. By default an instance of vtkMergePoints is used.

Set/Get a spatial locator for speeding the search process. By default an instance of vtkMergePoints is used.

Create default locator. Used to create one when none is specified.

void vtkCleanPolyData::ReleaseLocator ( void  ) [inline]

Release locator

Definition at line 149 of file vtkCleanPolyData.h.

unsigned long int vtkCleanPolyData::GetMTime ( ) [virtual]

Get the MTime of this object also considering the locator.

Reimplemented from vtkObject.

virtual void vtkCleanPolyData::OperateOnPoint ( double  in[3],
double  out[3] 
) [virtual]

Perform operation on a point

Reimplemented in vtkQuantizePolyDataPoints.

virtual void vtkCleanPolyData::OperateOnBounds ( double  in[6],
double  out[6] 
) [virtual]

Perform operation on bounds

Reimplemented in vtkQuantizePolyDataPoints.

virtual void vtkCleanPolyData::SetPieceInvariant ( int  ) [virtual]
virtual void vtkCleanPolyData::PieceInvariantOn ( ) [virtual]
virtual void vtkCleanPolyData::PieceInvariantOff ( ) [virtual]
virtual int vtkCleanPolyData::RequestData ( vtkInformation request,
vtkInformationVector **  inputVector,
vtkInformationVector outputVector 
) [protected, virtual]

This is called by the superclass. This is the method you should override.

Reimplemented from vtkPolyDataAlgorithm.

Reimplemented from vtkPolyDataAlgorithm.

This is called by the superclass. This is the method you should override.

Reimplemented from vtkPolyDataAlgorithm.


Member Data Documentation

Definition at line 178 of file vtkCleanPolyData.h.

Definition at line 179 of file vtkCleanPolyData.h.

Definition at line 180 of file vtkCleanPolyData.h.

Definition at line 181 of file vtkCleanPolyData.h.

Definition at line 182 of file vtkCleanPolyData.h.

Definition at line 183 of file vtkCleanPolyData.h.

Definition at line 184 of file vtkCleanPolyData.h.

Definition at line 185 of file vtkCleanPolyData.h.

Definition at line 187 of file vtkCleanPolyData.h.


The documentation for this class was generated from the following file: