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.
 
 
 
 
 
 

125 lines
4.0 KiB

/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkProperty2D.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 vtkProperty2D - represent surface properties of a 2D image
// .SECTION Description
// vtkProperty2D contains properties used to render two dimensional images
// and annotations.
// .SECTION See Also
// vtkActor2D
#ifndef __vtkProperty2D_h
#define __vtkProperty2D_h
#include "vtkObject.h"
class vtkViewport;
#define VTK_BACKGROUND_LOCATION 0
#define VTK_FOREGROUND_LOCATION 1
class VTK_COMMON_EXPORT vtkProperty2D : public vtkObject
{
public:
vtkTypeRevisionMacro(vtkProperty2D,vtkObject);
void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Creates a vtkProperty2D with the following default values:
// Opacity 1, Color (1,1,1)
static vtkProperty2D *New();
// Description:
// Assign one property to another.
void DeepCopy(vtkProperty2D *p);
// Description:
// Set/Get the RGB color of this property.
vtkSetVector3Macro(Color, double);
vtkGetVectorMacro(Color, double, 3);
// Description:
// Set/Get the Opacity of this property.
vtkGetMacro(Opacity, double);
vtkSetMacro(Opacity, double);
// Description:
// Set/Get the diameter of a Point. The size is expressed in screen units.
// This is only implemented for OpenGL. The default is 1.0.
vtkSetClampMacro(PointSize,float,0,VTK_LARGE_FLOAT);
vtkGetMacro(PointSize,float);
// Description:
// Set/Get the width of a Line. The width is expressed in screen units.
// This is only implemented for OpenGL. The default is 1.0.
vtkSetClampMacro(LineWidth,float,0,VTK_LARGE_FLOAT);
vtkGetMacro(LineWidth,float);
// Description:
// Set/Get the stippling pattern of a Line, as a 16-bit binary pattern
// (1 = pixel on, 0 = pixel off).
// This is only implemented for OpenGL. The default is 0xFFFF.
vtkSetMacro(LineStipplePattern,int);
vtkGetMacro(LineStipplePattern,int);
// Description:
// Set/Get the stippling repeat factor of a Line, which specifies how
// many times each bit in the pattern is to be repeated.
// This is only implemented for OpenGL. The default is 1.
vtkSetClampMacro(LineStippleRepeatFactor,int,1,VTK_LARGE_INTEGER);
vtkGetMacro(LineStippleRepeatFactor,int);
// Description:
// The DisplayLocation is either background or foreground.
// If it is background, then this 2D actor will be drawn
// behind all 3D props or foreground 2D actors. If it is
// background, then this 2D actor will be drawn in front of
// all 3D props and background 2D actors. Within 2D actors
// of the same DisplayLocation type, order is determined by
// the order in which the 2D actors were added to the viewport.
vtkSetClampMacro( DisplayLocation, int,
VTK_BACKGROUND_LOCATION, VTK_FOREGROUND_LOCATION );
vtkGetMacro( DisplayLocation, int );
void SetDisplayLocationToBackground()
{this->DisplayLocation = VTK_BACKGROUND_LOCATION;};
void SetDisplayLocationToForeground()
{this->DisplayLocation = VTK_FOREGROUND_LOCATION;};
// Description:
// Have the device specific subclass render this property.
virtual void Render (vtkViewport* vtkNotUsed(viewport)) {}
protected:
vtkProperty2D();
~vtkProperty2D();
double Color[3];
double Opacity;
float PointSize;
float LineWidth;
int LineStipplePattern;
int LineStippleRepeatFactor;
int DisplayLocation;
private:
vtkProperty2D(const vtkProperty2D&); // Not implemented.
void operator=(const vtkProperty2D&); // Not implemented.
};
#endif