Cloned library of VTK-5.0.0 with extra build files for internal package management.
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
 
 

162 lines
5.8 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkGenericCutter.h,v $
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.
=========================================================================*/
// .NAME vtkGenericCutter - cut a vtkGenericDataSet with an implicit function or scalar data
// .SECTION Description
// vtkGenericCutter is a filter to cut through data using any subclass of
// vtkImplicitFunction. That is, a polygonal surface is created
// corresponding to the implicit function F(x,y,z) = value(s), where
// you can specify one or more values used to cut with.
//
// In VTK, cutting means reducing a cell of dimension N to a cut surface
// of dimension N-1. For example, a tetrahedron when cut by a plane (i.e.,
// vtkPlane implicit function) will generate triangles. (In comparison,
// clipping takes a N dimensional cell and creates N dimension primitives.)
//
// vtkGenericCutter is generally used to "slice-through" a dataset, generating
// a surface that can be visualized. It is also possible to use
// vtkGenericCutter to do a form of volume rendering. vtkGenericCutter does
// this by generating multiple cut surfaces (usually planes) which are ordered
// (and rendered) from back-to-front. The surfaces are set translucent to give
// a volumetric rendering effect.
//
// This filter has been implemented to operate on generic datasets, rather
// than the typical vtkDataSet (and subclasses). vtkGenericDataSet is a more
// complex cousin of vtkDataSet, typically consisting of nonlinear,
// higher-order cells. To process this type of data, generic cells are
// automatically tessellated into linear cells prior to isocontouring.
// .SECTION See Also
// vtkCutter vtkImplicitFunction vtkClipPolyData vtkGenericDataSet
#ifndef __vtkGenericCutter_h
#define __vtkGenericCutter_h
#include "vtkPolyDataAlgorithm.h"
class vtkContourValues;
class vtkImplicitFunction;
class vtkPointLocator;
class vtkPointData;
class vtkCellData;
class VTK_GENERIC_FILTERING_EXPORT vtkGenericCutter : public vtkPolyDataAlgorithm
{
public:
vtkTypeRevisionMacro(vtkGenericCutter,vtkPolyDataAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Construct with user-specified implicit function; initial value of 0.0; and
// generating cut scalars turned off.
static vtkGenericCutter *New();
// Description:
// Set a particular contour value at contour number i. The index i ranges
// between 0<=i<NumberOfContours.
void SetValue(int i, double value);
// Description:
// Get the ith contour value.
double GetValue(int i);
// Description:
// Get a pointer to an array of contour values. There will be
// GetNumberOfContours() values in the list.
double *GetValues();
// Description:
// Fill a supplied list with contour values. There will be
// GetNumberOfContours() values in the list. Make sure you allocate
// enough memory to hold the list.
void GetValues(double *contourValues);
// Description:
// Set the number of contours to place into the list. You only really
// need to use this method to reduce list size. The method SetValue()
// will automatically increase list size as needed.
void SetNumberOfContours(int number);
// Description:
// Get the number of contours in the list of contour values.
int GetNumberOfContours();
// Description:
// Generate numContours equally spaced contour values between specified
// range. Contour values will include min/max range values.
void GenerateValues(int numContours, double range[2]);
// Description:
// Generate numContours equally spaced contour values between specified
// range. Contour values will include min/max range values.
void GenerateValues(int numContours, double rangeStart, double rangeEnd);
// Description:
// Override GetMTime because we delegate to vtkContourValues and refer to
// vtkImplicitFunction.
unsigned long GetMTime();
// Description
// Specify the implicit function to perform the cutting.
virtual void SetCutFunction(vtkImplicitFunction*);
vtkGetObjectMacro(CutFunction,vtkImplicitFunction);
// Description:
// If this flag is enabled, then the output scalar values will be
// interpolated from the implicit function values, and not the input scalar
// data.
vtkSetMacro(GenerateCutScalars,int);
vtkGetMacro(GenerateCutScalars,int);
vtkBooleanMacro(GenerateCutScalars,int);
// Description:
// Specify a spatial locator for merging points. By default,
// an instance of vtkMergePoints is used.
void SetLocator(vtkPointLocator *locator);
vtkGetObjectMacro(Locator,vtkPointLocator);
// Description:
// Create default locator. Used to create one when none is specified. The
// locator is used to merge coincident points.
void CreateDefaultLocator();
protected:
vtkGenericCutter(vtkImplicitFunction *cf=NULL);
~vtkGenericCutter();
// Description:
// Actual implementation of the cutter operation.
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
int FillInputPortInformation(int, vtkInformation*);
vtkImplicitFunction *CutFunction;
vtkPointLocator *Locator;
vtkContourValues *ContourValues;
int GenerateCutScalars;
// Used internal by vtkGenericAdaptorCell::Contour()
vtkPointData *internalPD;
vtkPointData *secondaryPD;
vtkCellData *secondaryCD;
private:
vtkGenericCutter(const vtkGenericCutter&); // Not implemented.
void operator=(const vtkGenericCutter&); // Not implemented.
};
#endif