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.
 
 
 
 
 
 

93 lines
3.4 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkRegularPolygonSource.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 vtkRegularPolygonSource - create a regular, n-sided polygon and/or polyline
// .SECTION Description
// vtkRegularPolygonSource is a source object that creates a single n-sided polygon and/or
// polyline. The polygon is centered at a specified point, orthogonal to
// a specified normal, and with a circumscribing radius set by the user. The user can
// also specify the number of sides of the polygon ranging from [3,N].
//
// This object can be used for seeding streamlines or defining regions for clipping/cutting.
#ifndef __vtkRegularPolygonSource_h
#define __vtkRegularPolygonSource_h
#include "vtkPolyDataAlgorithm.h"
class VTK_GRAPHICS_EXPORT vtkRegularPolygonSource : public vtkPolyDataAlgorithm
{
public:
// Description:
// Standard methods for instantiation, obtaining type and printing instance values.
static vtkRegularPolygonSource *New();
vtkTypeRevisionMacro(vtkRegularPolygonSource,vtkPolyDataAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Set/Get the number of sides of the polygon. By default, the number of sides
// is set to six.
vtkSetClampMacro(NumberOfSides,int,3,VTK_LARGE_INTEGER);
vtkGetMacro(NumberOfSides,int);
// Description:
// Set/Get the center of the polygon. By default, the center is set at the
// origin (0,0,0).
vtkSetVector3Macro(Center,double);
vtkGetVectorMacro(Center,double,3);
// Description:
// Set/Get the normal to the polygon. The ordering of the polygon will be
// counter-clockwise around the normal (i.e., using the right-hand rule).
// By default, the normal is set to (0,0,1).
vtkSetVector3Macro(Normal,double);
vtkGetVectorMacro(Normal,double,3);
// Description:
// Set/Get the radius of the polygon. By default, the radius is set to 0.5.
vtkSetMacro(Radius,double);
vtkGetMacro(Radius,double);
// Description:
// Control whether a polygon is produced. By default, GeneratePolygon is enabled.
vtkSetMacro(GeneratePolygon,int);
vtkGetMacro(GeneratePolygon,int);
vtkBooleanMacro(GeneratePolygon,int);
// Description:
// Control whether a polyline is produced. By default, GeneratePolyline is enabled.
vtkSetMacro(GeneratePolyline,int);
vtkGetMacro(GeneratePolyline,int);
vtkBooleanMacro(GeneratePolyline,int);
protected:
vtkRegularPolygonSource();
~vtkRegularPolygonSource() {}
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
int RequestInformation(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
int NumberOfSides;
double Center[3];
double Normal[3];
double Radius;
int GeneratePolygon;
int GeneratePolyline;
private:
vtkRegularPolygonSource(const vtkRegularPolygonSource&); // Not implemented.
void operator=(const vtkRegularPolygonSource&); // Not implemented.
};
#endif