Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkVolumeMapperVtkSmart3D.h
Go to the documentation of this file.
1 /*============================================================================
2 
3 The Medical Imaging Interaction Toolkit (MITK)
4 
5 Copyright (c) German Cancer Research Center (DKFZ)
6 All rights reserved.
7 
8 Use of this source code is governed by a 3-clause BSD license that can be
9 found in the LICENSE file.
10 
11 ============================================================================*/
12 
13 #ifndef mitkVolumeMapperVtkSmart3D_h
14 #define mitkVolumeMapperVtkSmart3D_h
15 
16 // MITK
17 #include "MitkMapperExtExports.h"
18 #include "mitkBaseRenderer.h"
19 #include "mitkCommon.h"
20 #include "mitkImage.h"
21 #include "mitkVtkMapper.h"
22 
23 // VTK
24 #include <vtkImageChangeInformation.h>
25 #include <vtkSmartPointer.h>
26 #include <vtkVersionMacros.h>
27 #include <vtkVolumeProperty.h>
28 #include <vtkSmartVolumeMapper.h>
29 #include <vtkImageData.h>
30 #include <vtkImageChangeInformation.h>
31 
32 namespace mitk
33 {
34 
35  //##Documentation
36  //## @brief Vtk-based mapper for VolumeData
37  //##
38  //## @ingroup Mapper
40  {
41  public:
43 
44  itkFactorylessNewMacro(Self);
45 
46  itkCloneMacro(Self);
47 
48  vtkProp *GetVtkProp(mitk::BaseRenderer *renderer) override;
49 
50  void ApplyProperties(vtkActor *actor, mitk::BaseRenderer *renderer) override;
51  static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer = nullptr, bool overwrite = false);
52 
53  protected:
56 
57  void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override;
58 
59  void createMapper(vtkImageData*);
60  void createVolume();
62  vtkImageData* GetInputImage();
63 
68 
71  };
72 
73 } // namespace mitk
74 
75 #endif
#define MITKMAPPEREXT_EXPORT
Class for nodes of the DataTree.
Definition: mitkDataNode.h:64
Base class of all mappers, Vtk as well as OpenGL mappers.
Definition: mitkMapper.h:47
Vtk-based mapper for VolumeData.
static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer=nullptr, bool overwrite=false)
void ApplyProperties(vtkActor *actor, mitk::BaseRenderer *renderer) override
Apply color and opacity properties read from the PropertyList.
vtkSmartPointer< vtkSmartVolumeMapper > m_SmartVolumeMapper
void UpdateTransferFunctions(mitk::BaseRenderer *renderer)
void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override
Generate the data needed for rendering into renderer.
void createMapper(vtkImageData *)
mitkClassMacro(VolumeMapperVtkSmart3D, VtkMapper)
vtkProp * GetVtkProp(mitk::BaseRenderer *renderer) override
vtkSmartPointer< vtkVolumeProperty > m_VolumeProperty
vtkSmartPointer< vtkVolume > m_Volume
vtkImageData * GetInputImage()
void UpdateRenderMode(mitk::BaseRenderer *renderer)
vtkSmartPointer< vtkImageChangeInformation > m_ImageChangeInformation
Base class of all Vtk Mappers in order to display primitives by exploiting Vtk functionality.
Definition: mitkVtkMapper.h:48
Find image slices visible on a given plane.