VTK
vtkImageStack.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkImageStack.h
5 
6  Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
7  All rights reserved.
8  See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
9 
10  This software is distributed WITHOUT ANY WARRANTY; without even
11  the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
12  PURPOSE. See the above copyright notice for more information.
13 
14 =========================================================================*/
35 #ifndef vtkImageStack_h
36 #define vtkImageStack_h
37 
38 #include "vtkRenderingImageModule.h" // For export macro
39 #include "vtkImageSlice.h"
40 
42 class vtkImageProperty;
43 class vtkImageMapper3D;
44 class vtkCollection;
45 
46 class VTKRENDERINGIMAGE_EXPORT vtkImageStack : public vtkImageSlice
47 {
48 public:
50  void PrintSelf(ostream& os, vtkIndent indent);
51  static vtkImageStack *New();
52 
57  void AddImage(vtkImageSlice *prop);
58 
64 
68  int HasImage(vtkImageSlice *prop);
69 
73  vtkImageSliceCollection *GetImages() { return this->Images; }
74 
76 
80  vtkSetMacro(ActiveLayer, int);
81  int GetActiveLayer() { return this->ActiveLayer; }
83 
90 
95 
100 
102 
105  double *GetBounds();
106  void GetBounds(double bounds[6]) { this->vtkProp3D::GetBounds( bounds ); };
108 
113 
121 
125  void ShallowCopy(vtkProp *prop);
126 
133 
135 
138  virtual int RenderOverlay(vtkViewport *viewport);
139  virtual int RenderOpaqueGeometry(vtkViewport *viewport);
142 
147 
152 
154 
162 
169 
170 protected:
173 
175  void SetProperty(vtkImageProperty *property);
176 
177  void PokeMatrices(vtkMatrix4x4 *matrix);
178  void UpdatePaths();
179 
184 
185 private:
186  vtkImageStack(const vtkImageStack&) VTK_DELETE_FUNCTION;
187  void operator=(const vtkImageStack&) VTK_DELETE_FUNCTION;
188 };
189 
190 #endif
vtkImageStack::RenderOverlay
virtual int RenderOverlay(vtkViewport *viewport)
Support the standard render methods.
vtkImageStack::RemoveImage
void RemoveImage(vtkImageSlice *prop)
Remove an image from the stack.
vtkImageStack::PokeMatrices
void PokeMatrices(vtkMatrix4x4 *matrix)
vtkImageStack::UpdatePaths
void UpdatePaths()
vtkImageStack::PathTime
vtkTimeStamp PathTime
Definition: vtkImageStack.h:180
vtkImageStack::GetBounds
double * GetBounds()
Get the combined bounds of all of the images.
vtkImageStack::~vtkImageStack
~vtkImageStack()
vtkImageStack::ActiveLayer
int ActiveLayer
Definition: vtkImageStack.h:183
vtkTimeStamp
record modification and/or execution time
Definition: vtkTimeStamp.h:36
vtkImageStack::RenderOpaqueGeometry
virtual int RenderOpaqueGeometry(vtkViewport *viewport)
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THESE METHODS OUTSIDE OF THE RENDE...
vtkImageStack::GetBounds
void GetBounds(double bounds[6])
Definition: vtkImageStack.h:106
vtkImageStack::ShallowCopy
void ShallowCopy(vtkProp *prop)
Shallow copy of this prop.
vtkImageStack::New
static vtkImageStack * New()
vtkImageStack::GetNumberOfPaths
int GetNumberOfPaths()
vtkAssemblyPath
a list of nodes that form an assembly path
Definition: vtkAssemblyPath.h:42
vtkAssemblyPaths
a list of lists of props representing an assembly hierarchy
Definition: vtkAssemblyPaths.h:38
vtkImageStack::BuildPaths
void BuildPaths(vtkAssemblyPaths *paths, vtkAssemblyPath *path)
WARNING: INTERNAL METHOD - NOT INTENDED FOR GENERAL USE DO NOT USE THIS METHOD OUTSIDE OF THE RENDERI...
vtkImageStack::GetNextPath
vtkAssemblyPath * GetNextPath()
vtkWindow
window superclass for vtkRenderWindow
Definition: vtkWindow.h:35
vtkImageStack::RenderTranslucentPolygonalGeometry
virtual int RenderTranslucentPolygonalGeometry(vtkViewport *viewport)
vtkImageStack::GetRedrawMTime
vtkMTimeType GetRedrawMTime()
Return the mtime of anything that would cause the rendered image to appear differently.
vtkMTimeType
vtkTypeUInt64 vtkMTimeType
Definition: vtkType.h:248
vtkImageStack::InitPathTraversal
void InitPathTraversal()
Methods for traversing the stack as if it was an assembly.
vtkImageStack::HasTranslucentPolygonalGeometry
virtual int HasTranslucentPolygonalGeometry()
Does this prop have some translucent polygonal geometry?
vtkImageStack::vtkImageStack
vtkImageStack()
vtkCollection
create and manipulate unsorted lists of objects
Definition: vtkCollection.h:52
vtkImageSlice
represents an image in a 3D scene
Definition: vtkImageSlice.h:53
vtkImageProperty
image display properties
Definition: vtkImageProperty.h:43
vtkImageStack::HasImage
int HasImage(vtkImageSlice *prop)
Check if an image is present.
vtkImageStack::GetActiveLayer
int GetActiveLayer()
Definition: vtkImageStack.h:81
vtkImageStack::GetProperty
vtkImageProperty * GetProperty()
Get the property for the currently active image.
vtkImageStack::SetMapper
void SetMapper(vtkImageMapper3D *mapper)
vtkIndent
a simple class to control print indentation
Definition: vtkIndent.h:40
vtkMatrix4x4
represent and manipulate 4x4 transformation matrices
Definition: vtkMatrix4x4.h:42
vtkImageStack::SetProperty
void SetProperty(vtkImageProperty *property)
vtkImageSliceCollection
a sorted list of image slice objects
Definition: vtkImageSliceCollection.h:34
vtkImageStack::GetImages
vtkImageSliceCollection * GetImages()
Get the list of images as a vtkImageSliceCollection.
Definition: vtkImageStack.h:73
vtkViewport
abstract specification for Viewports
Definition: vtkViewport.h:48
vtkImageStack
manages a stack of composited images
Definition: vtkImageStack.h:47
vtkSetMacro
vtkSetMacro(IgnoreDriverBugs, bool)
Updates the extensions string.
vtkProp
abstract superclass for all actors, volumes and annotations
Definition: vtkProp.h:48
vtkImageStack::ImageMatrices
vtkCollection * ImageMatrices
Definition: vtkImageStack.h:181
vtkImageMapper3D
abstract class for mapping images to the screen
Definition: vtkImageMapper3D.h:51
vtkImageSlice.h
vtkImageStack::GetActiveImage
vtkImageSlice * GetActiveImage()
Get the active image.
vtkImageStack::GetImages
void GetImages(vtkPropCollection *)
For some exporters and other other operations we must be able to collect all the actors,...
vtkImageStack::Images
vtkImageSliceCollection * Images
Definition: vtkImageStack.h:182
vtkImageStack::GetMTime
vtkMTimeType GetMTime()
Return the max MTime of all the images.
vtkPropCollection
a list of Props
Definition: vtkPropCollection.h:39
vtkImageStack::GetMapper
vtkImageMapper3D * GetMapper()
Get the mapper for the currently active image.
vtkImageStack::ReleaseGraphicsResources
void ReleaseGraphicsResources(vtkWindow *win)
Release any resources held by this prop.
vtkImageStack::AddImage
void AddImage(vtkImageSlice *prop)
Add an image to the stack.
vtkImageStack::PrintSelf
void PrintSelf(ostream &os, vtkIndent indent)
Methods invoked by print to print information about the object including superclasses.
vtkProp3D::GetBounds
virtual double * GetBounds()=0
Get the bounds for this Prop as (Xmin,Xmax,Ymin,Ymax,Zmin,Zmax).