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
29#ifndef vtkImageSlice_h
30#define vtkImageSlice_h
31
32#include "vtkProp3D.h"
33#include "vtkRenderingCoreModule.h" // For export macro
34
35VTK_ABI_NAMESPACE_BEGIN
36class vtkRenderer;
40
41class VTKRENDERINGCORE_EXPORT vtkImageSlice : public vtkProp3D
42{
43public:
44 vtkTypeMacro(vtkImageSlice, vtkProp3D);
45 void PrintSelf(ostream& os, vtkIndent indent) override;
46
52 static vtkImageSlice* New();
53
55
59 vtkGetObjectMacro(Mapper, vtkImageMapper3D);
61
63
69
73 void Update();
74
76
80 double* GetBounds() override;
81 void GetBounds(double bounds[6]) { this->vtkProp3D::GetBounds(bounds); }
82 double GetMinXBound();
83 double GetMaxXBound();
84 double GetMinYBound();
85 double GetMaxYBound();
86 double GetMinZBound();
87 double GetMaxZBound();
89
94
102
104
107 vtkGetMacro(ForceTranslucent, bool);
108 vtkSetMacro(ForceTranslucent, bool);
109 vtkBooleanMacro(ForceTranslucent, bool);
111
115 void ShallowCopy(vtkProp* prop) override;
116
123
125
128 int RenderOverlay(vtkViewport* viewport) override;
129 int RenderOpaqueGeometry(vtkViewport* viewport) override;
132
138
143 virtual void Render(vtkRenderer*);
144
149
156 void SetStackedImagePass(int pass);
157
158protected:
160 ~vtkImageSlice() override;
161
164
166
167private:
168 vtkImageSlice(const vtkImageSlice&) = delete;
169 void operator=(const vtkImageSlice&) = delete;
170};
171
172VTK_ABI_NAMESPACE_END
173#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:46
abstract specification for renderers
Definition vtkRenderer.h:62
abstract specification for Viewports
Definition vtkViewport.h:45
window superclass for vtkRenderWindow
Definition vtkWindow.h:28
int vtkTypeBool
Definition vtkABI.h:64
vtkTypeUInt32 vtkMTimeType
Definition vtkType.h:270