VTK  9.3.0
vtkImageSlice.h
Go to the documentation of this file.
1// SPDX-FileCopyrightText: Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
2// SPDX-License-Identifier: BSD-3-Clause
26#ifndef vtkImageSlice_h
27#define vtkImageSlice_h
28
29#include "vtkProp3D.h"
30#include "vtkRenderingCoreModule.h" // For export macro
31
32VTK_ABI_NAMESPACE_BEGIN
33class vtkRenderer;
37
38class VTKRENDERINGCORE_EXPORT vtkImageSlice : public vtkProp3D
39{
40public:
41 vtkTypeMacro(vtkImageSlice, vtkProp3D);
42 void PrintSelf(ostream& os, vtkIndent indent) override;
43
49 static vtkImageSlice* New();
50
52
56 vtkGetObjectMacro(Mapper, vtkImageMapper3D);
58
60
66
70 void Update();
71
73
77 double* GetBounds() override;
78 void GetBounds(double bounds[6]) { this->vtkProp3D::GetBounds(bounds); }
79 double GetMinXBound();
80 double GetMaxXBound();
81 double GetMinYBound();
82 double GetMaxYBound();
83 double GetMinZBound();
84 double GetMaxZBound();
86
91
99
101
104 vtkGetMacro(ForceTranslucent, bool);
105 vtkSetMacro(ForceTranslucent, bool);
106 vtkBooleanMacro(ForceTranslucent, bool);
108
112 void ShallowCopy(vtkProp* prop) override;
113
120
122
125 int RenderOverlay(vtkViewport* viewport) override;
126 int RenderOpaqueGeometry(vtkViewport* viewport) override;
129
135
140 virtual void Render(vtkRenderer*);
141
146
153 void SetStackedImagePass(int pass);
154
155protected:
157 ~vtkImageSlice() override;
158
161
163
164private:
165 vtkImageSlice(const vtkImageSlice&) = delete;
166 void operator=(const vtkImageSlice&) = delete;
167};
168
169VTK_ABI_NAMESPACE_END
170#endif
abstract class for mapping images to the screen
image display properties
represents an image in a 3D scene
virtual void Render(vtkRenderer *)
This causes the image and its mapper to be rendered.
double GetMaxYBound()
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
vtkMTimeType GetMTime() override
Return the MTime also considering the property etc.
void PrintSelf(ostream &os, vtkIndent indent) override
Methods invoked by print to print information about the object including superclasses.
vtkImageMapper3D * Mapper
double GetMinXBound()
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
int RenderTranslucentPolygonalGeometry(vtkViewport *viewport) override
Support the standard render methods.
double GetMinZBound()
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
double GetMinYBound()
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
double GetMaxZBound()
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
void Update()
Update the rendering pipeline by updating the ImageMapper.
virtual vtkImageProperty * GetProperty()
Set/Get the image display properties.
static vtkImageSlice * New()
Creates an Image with the following defaults: origin(0,0,0) position=(0,0,0) scale=1 visibility=1 pic...
int RenderOpaqueGeometry(vtkViewport *viewport) override
Support the standard render methods.
void SetProperty(vtkImageProperty *property)
Set/Get the image display properties.
void SetMapper(vtkImageMapper3D *mapper)
Set/Get the mapper.
int RenderOverlay(vtkViewport *viewport) override
Support the standard render methods.
double * GetBounds() override
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
void SetStackedImagePass(int pass)
For stacked image rendering, set the pass.
void ShallowCopy(vtkProp *prop) override
Shallow copy of this vtkImageSlice.
vtkMTimeType GetRedrawMTime() override
Return the mtime of anything that would cause the rendered image to appear differently.
void ReleaseGraphicsResources(vtkWindow *win) override
Release any resources held by this prop.
void GetImages(vtkPropCollection *)
For some exporters and other other operations we must be able to collect all the actors,...
~vtkImageSlice() override
double GetMaxXBound()
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
vtkImageProperty * Property
vtkTypeBool HasTranslucentPolygonalGeometry() override
Internal method, should only be used by rendering.
void GetBounds(double bounds[6])
Get the bounds - either all six at once (xmin, xmax, ymin, ymax, zmin, zmax) or one at a time.
a simple class to control print indentation
Definition vtkIndent.h:29
represents an 3D object for placement in a rendered scene
Definition vtkProp3D.h:39
double * GetBounds() override=0
Return a reference to the Prop3D's composite transform.
an ordered list of Props
abstract superclass for all actors, volumes and annotations
Definition vtkProp.h:43
abstract specification for renderers
Definition vtkRenderer.h:59
abstract specification for Viewports
Definition vtkViewport.h:45
window superclass for vtkRenderWindow
Definition vtkWindow.h:25
int vtkTypeBool
Definition vtkABI.h:64
vtkTypeUInt32 vtkMTimeType
Definition vtkType.h:270