1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77
|
/*=========================================================================
Program: Visualization Toolkit
Module: $RCSfile: vtkMesaImageActor.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 vtkMesaImageActor - Mesa texture map
// .SECTION Description
// vtkMesaImageActor is a concrete implementation of the abstract class
// vtkImageActor. vtkMesaImageActor interfaces to the Mesa rendering library.
#ifndef __vtkMesaImageActor_h
#define __vtkMesaImageActor_h
#include "vtkImageActor.h"
class vtkWindow;
class vtkMesaRenderer;
class vtkRenderWindow;
class VTK_RENDERING_EXPORT vtkMesaImageActor : public vtkImageActor
{
public:
static vtkMesaImageActor *New();
vtkTypeRevisionMacro(vtkMesaImageActor,vtkImageActor);
virtual void PrintSelf(ostream& os, vtkIndent indent);
// Description:
// Implement base class method.
void Load(vtkRenderer *ren);
// Description:
// Implement base class method.
void Render(vtkRenderer *ren);
// Description:
// Release any graphics resources that are being consumed by this texture.
// The parameter window could be used to determine which graphic
// resources to release. Using the same texture object in multiple
// render windows is NOT currently supported.
void ReleaseGraphicsResources(vtkWindow *);
protected:
vtkMesaImageActor();
~vtkMesaImageActor();
unsigned char *MakeDataSuitable(int &xsize, int &ysize,
int &release, int &reuseTexture);
vtkTimeStamp LoadTime;
long Index;
static long GlobalIndex;
vtkRenderWindow *RenderWindow; // RenderWindow used for previous render
double Coords[12];
double TCoords[8];
int TextureSize[2];
// Non-recursive internal method
void InternalRender(vtkRenderer *ren);
// Is a certain size texture supported?
int TextureSizeOK( int size[2] );
private:
vtkMesaImageActor(const vtkMesaImageActor&); // Not implemented.
void operator=(const vtkMesaImageActor&); // Not implemented.
};
#endif
|