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.
 
 
 
 
 
 

95 lines
3.6 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkTextureMapToSphere.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 vtkTextureMapToSphere - generate texture coordinates by mapping points to sphere
// .SECTION Description
// vtkTextureMapToSphere is a filter that generates 2D texture coordinates by
// mapping input dataset points onto a sphere. The sphere can either be user
// specified or generated automatically. (The sphere is generated
// automatically by computing the center (i.e., averaged coordinates) of the
// sphere.) Note that the generated texture coordinates range between
// (0,1). The s-coordinate lies in the angular direction around the z-axis,
// measured counter-clockwise from the x-axis. The t-coordinate lies in the
// angular direction measured down from the north pole towards the south
// pole.
//
// A special ivar controls how the s-coordinate is generated. If PreventSeam
// is set to true, the s-texture varies from 0->1 and then 1->0 (corresponding
// to angles of 0->180 and 180->360).
// .SECTION Caveats
// The resulting texture coordinates will lie between (0,1), and the texture
// coordinates are determined with respect to the modeler's x-y-z coordinate
// system. Use the class vtkTransformTextureCoords to linearly scale and
// shift the origin of the texture coordinates (if necessary).
// .SECTION See Also
// vtkTextureMapToPlane vtkTextureMapToCylinder vtkTextureMapToBox
// vtkTransformTexture vtkThresholdTextureCoords
#ifndef __vtkTextureMapToSphere_h
#define __vtkTextureMapToSphere_h
#include "vtkDataSetAlgorithm.h"
class VTK_GRAPHICS_EXPORT vtkTextureMapToSphere : public vtkDataSetAlgorithm
{
public:
vtkTypeRevisionMacro(vtkTextureMapToSphere,vtkDataSetAlgorithm);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Create object with Center (0,0,0) and the PreventSeam ivar is set to
// true. The sphere center is automatically computed.
static vtkTextureMapToSphere *New();
// Description:
// Specify a point defining the center of the sphere.
vtkSetVector3Macro(Center,double);
vtkGetVectorMacro(Center,double,3);
// Description:
// Turn on/off automatic sphere generation. This means it automatically
// finds the sphere center.
vtkSetMacro(AutomaticSphereGeneration,int);
vtkGetMacro(AutomaticSphereGeneration,int);
vtkBooleanMacro(AutomaticSphereGeneration,int);
// Description:
// Control how the texture coordinates are generated. If PreventSeam is
// set, the s-coordinate ranges from 0->1 and 1->0 corresponding to the
// theta angle variation between 0->180 and 180->0 degrees. Otherwise, the
// s-coordinate ranges from 0->1 between 0->360 degrees.
vtkSetMacro(PreventSeam,int);
vtkGetMacro(PreventSeam,int);
vtkBooleanMacro(PreventSeam,int);
protected:
vtkTextureMapToSphere();
~vtkTextureMapToSphere() {};
int RequestData(vtkInformation *, vtkInformationVector **, vtkInformationVector *);
double Center[3];
int AutomaticSphereGeneration;
int PreventSeam;
private:
vtkTextureMapToSphere(const vtkTextureMapToSphere&); // Not implemented.
void operator=(const vtkTextureMapToSphere&); // Not implemented.
};
#endif