VTK  9.2.20230205
vtkImageSlice.h
Go to the documentation of this file.
1 /*=========================================================================
2 
3  Program: Visualization Toolkit
4  Module: vtkImageSlice.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 =========================================================================*/
147 #ifndef vtkImageSlice_h
148 #define vtkImageSlice_h
149 
150 #include "vtkProp3D.h"
151 #include "vtkRenderingCoreModule.h" // For export macro
152 
153 VTK_ABI_NAMESPACE_BEGIN
154 class vtkRenderer;
155 class vtkPropCollection;
156 class vtkImageProperty;
157 class vtkImageMapper3D;
158 
159 class VTKRENDERINGCORE_EXPORT vtkImageSlice : public vtkProp3D
160 {
161 public:
162  vtkTypeMacro(vtkImageSlice, vtkProp3D);
163  void PrintSelf(ostream& os, vtkIndent indent) override;
164 
170  static vtkImageSlice* New();
171 
173 
177  vtkGetObjectMacro(Mapper, vtkImageMapper3D);
179 
181 
184  void SetProperty(vtkImageProperty* property);
187 
191  void Update();
192 
194 
198  double* GetBounds() override;
199  void GetBounds(double bounds[6]) { this->vtkProp3D::GetBounds(bounds); }
200  double GetMinXBound();
201  double GetMaxXBound();
202  double GetMinYBound();
203  double GetMaxYBound();
204  double GetMinZBound();
205  double GetMaxZBound();
207 
211  vtkMTimeType GetMTime() override;
212 
220 
222 
225  vtkGetMacro(ForceTranslucent, bool);
226  vtkSetMacro(ForceTranslucent, bool);
227  vtkBooleanMacro(ForceTranslucent, bool);
229 
233  void ShallowCopy(vtkProp* prop) override;
234 
241 
243 
246  int RenderOverlay(vtkViewport* viewport) override;
247  int RenderOpaqueGeometry(vtkViewport* viewport) override;
250 
256 
261  virtual void Render(vtkRenderer*);
262 
266  void ReleaseGraphicsResources(vtkWindow* win) override;
267 
274  void SetStackedImagePass(int pass);
275 
276 protected:
278  ~vtkImageSlice() override;
279 
282 
284 
285 private:
286  vtkImageSlice(const vtkImageSlice&) = delete;
287  void operator=(const vtkImageSlice&) = delete;
288 };
289 
290 VTK_ABI_NAMESPACE_END
291 #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.
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.
a simple class to control print indentation
Definition: vtkIndent.h:120
represents an 3D object for placement in a rendered scene
Definition: vtkProp3D.h:100
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:77
abstract specification for renderers
Definition: vtkRenderer.h:183
abstract specification for Viewports
Definition: vtkViewport.h:57
window superclass for vtkRenderWindow
Definition: vtkWindow.h:40
int vtkTypeBool
Definition: vtkABI.h:71
vtkTypeUInt32 vtkMTimeType
Definition: vtkType.h:282