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 
32 VTK_ABI_NAMESPACE_BEGIN
33 class vtkRenderer;
34 class vtkPropCollection;
35 class vtkImageProperty;
36 class vtkImageMapper3D;
37 
38 class VTKRENDERINGCORE_EXPORT vtkImageSlice : public vtkProp3D
39 {
40 public:
41  vtkTypeMacro(vtkImageSlice, vtkProp3D);
42  void PrintSelf(ostream& os, vtkIndent indent) override;
43 
49  static vtkImageSlice* New();
50 
52 
55  void SetMapper(vtkImageMapper3D* mapper);
56  vtkGetObjectMacro(Mapper, vtkImageMapper3D);
58 
60 
63  void SetProperty(vtkImageProperty* property);
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 
90  vtkMTimeType GetMTime() override;
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 
145  void ReleaseGraphicsResources(vtkWindow* win) override;
146 
153  void SetStackedImagePass(int pass);
154 
155 protected:
157  ~vtkImageSlice() override;
158 
161 
163 
164 private:
165  vtkImageSlice(const vtkImageSlice&) = delete;
166  void operator=(const vtkImageSlice&) = delete;
167 };
168 
169 VTK_ABI_NAMESPACE_END
170 #endif
abstract class for mapping images to the screen
image display properties
represents an image in a 3D scene
Definition: vtkImageSlice.h:39
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.
int RenderOpaqueGeometry(vtkViewport *viewport) override
Support the standard render methods.
static vtkImageSlice * New()
Creates an Image with the following defaults: origin(0,0,0) position=(0,0,0) scale=1 visibility=1 pic...
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.
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.
virtual vtkImageProperty * GetProperty()
Set/Get the image display properties.
double * GetBounds() override
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.
Definition: vtkImageSlice.h:78
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