Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkLabelSetImageVtkMapper2D.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 mitkLabelSetImageVtkMapper2D_h
14 #define mitkLabelSetImageVtkMapper2D_h
15 
16 // MITK
17 #include "MitkMultilabelExports.h"
18 #include "mitkCommon.h"
19 
20 // MITK Rendering
21 #include "mitkBaseRenderer.h"
22 #include "mitkExtractSliceFilter.h"
23 #include "mitkLabelSetImage.h"
24 #include "mitkVtkMapper.h"
25 
26 // VTK
27 #include <vtkSmartPointer.h>
28 
29 class vtkActor;
30 class vtkPolyDataMapper;
31 class vtkPlaneSource;
32 class vtkImageData;
33 class vtkLookupTable;
34 class vtkImageReslice;
35 class vtkPoints;
37 class vtkPolyData;
39 class vtkImageMapToColors;
40 
41 namespace mitk
42 {
43  class IPreferences;
44 
60  {
61  public:
64 
66  itkNewMacro(Self);
67 
69  const mitk::Image *GetInput(void);
70 
73  void Update(mitk::BaseRenderer *renderer) override;
74 
75  //### methods of MITK-VTK rendering pipeline
76  vtkProp *GetVtkProp(mitk::BaseRenderer *renderer) override;
77  //### end of methods of MITK-VTK rendering pipeline
78 
87  {
88  public:
90 
95  std::vector<const Image*> m_GroupImageIDs;
96 
97  std::vector<vtkSmartPointer<vtkActor>> m_LayerActorVector;
98  std::vector<vtkSmartPointer<vtkPolyDataMapper>> m_LayerMapperVector;
99  std::vector<vtkSmartPointer<vtkImageData>> m_ReslicedImageVector;
100  std::vector<vtkSmartPointer<vtkImageMapToColors>> m_LayerImageMapToColors;
101  std::vector<vtkSmartPointer<vtkNeverTranslucentTexture>> m_LayerTextureVector;
102 
105 
106  std::vector<mitk::ExtractSliceFilter::Pointer> m_ReslicerVector;
107 
115 
117  itk::TimeStamp m_LastDataUpdateTime;
119  itk::TimeStamp m_LastPropertyUpdateTime;
122 
125 
128 
129  mitk::PlaneGeometry::Pointer m_WorldPlane;
131 
133 
134  unsigned int m_NumberOfLayers;
135 
137 
141  ~LocalStorage() override;
142  };
143 
146 
149 
151  static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer = nullptr, bool overwrite = false);
152 
157 
158  protected:
163 
177  void GeneratePlane(mitk::BaseRenderer *renderer, double planeBounds[6]);
178 
186  vtkImageData *image,
187  int pixelValue = 1);
188 
193 
206  void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override;
207 
208  void GenerateImageSlice(mitk::BaseRenderer* renderer, const std::vector<mitk::MultiLabelSegmentation::GroupIndexType>& outdatedGroupIDs);
209 
211 
215 
220 
231  bool RenderingGeometryIntersectsImage(const PlaneGeometry *renderingGeometry, const BaseGeometry* imageGeometry) const;
232 
233  private:
234  float GetOpacityFactor();
235  IPreferences* m_Preferences;
236  };
237 
238 } // namespace mitk
239 
240 #endif
#define MITKMULTILABEL_EXPORT
BaseGeometry Describes the geometry of a data object.
Class for nodes of the DataTree.
Definition: mitkDataNode.h:64
Interface to application preferences.
Image class for storing images.
Definition: mitkImage.h:70
Internal class holding the mapper, actor, etc. for each of the 3 2D render windows.
std::vector< vtkSmartPointer< vtkActor > > m_LayerActorVector
~LocalStorage() override
Default destructor of the local storage.
std::vector< vtkSmartPointer< vtkPolyDataMapper > > m_LayerMapperVector
std::vector< mitk::ExtractSliceFilter::Pointer > m_ReslicerVector
std::vector< vtkSmartPointer< vtkImageData > > m_ReslicedImageVector
itk::TimeStamp m_LastActiveLabelUpdateTime
Timestamp of last update of a property.
std::vector< vtkSmartPointer< vtkNeverTranslucentTexture > > m_LayerTextureVector
vtkSmartPointer< vtkPolyDataMapper > m_OutlineMapper
A mapper for the outline.
itk::TimeStamp m_LastPropertyUpdateTime
Timestamp of last update of a property.
LocalStorage()
Default constructor of the local storage.
itk::TimeStamp m_LastDataUpdateTime
Timestamp of last update of stored data.
vtkSmartPointer< vtkActor > m_OutlineActor
An actor for the outline.
vtkSmartPointer< vtkActor > m_OutlineShadowActor
An actor for the outline shadow.
std::vector< vtkSmartPointer< vtkImageMapToColors > > m_LayerImageMapToColors
mitk::ScalarType * m_mmPerPixel
mmPerPixel relation between pixel and mm. (World spacing).
Mapper to resample and display 2D slices of a 3D labelset image.
void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override
Does the actual resampling, without rendering the image yet. All the data is generated inside this me...
mitk::LocalStorageHandler< LocalStorage > m_LSH
The LocalStorageHandler holds all (three) LocalStorages for the three 2D render windows.
vtkProp * GetVtkProp(mitk::BaseRenderer *renderer) override
void GenerateImageSlice(mitk::BaseRenderer *renderer, const std::vector< mitk::MultiLabelSegmentation::GroupIndexType > &outdatedGroupIDs)
void GeneratePlane(mitk::BaseRenderer *renderer, double planeBounds[6])
Generates a plane according to the size of the resliced image in millimeters.
mitkClassMacro(LabelSetImageVtkMapper2D, VtkMapper)
void ApplyRenderingMode(mitk::BaseRenderer *renderer)
This method switches between different rendering modes (e.g. use a lookup table or a transfer functio...
static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer=nullptr, bool overwrite=false)
Set the default properties for general image rendering.
void Update(mitk::BaseRenderer *renderer) override
Checks whether this mapper needs to update itself and generate data.
const mitk::Image * GetInput(void)
Get the Image to map.
float CalculateLayerDepth(mitk::BaseRenderer *renderer)
This method uses the vtkCamera clipping range and the layer property to calculate the depth of the ob...
void GenerateActiveLabelOutline(mitk::BaseRenderer *renderer)
LocalStorage * GetLocalStorage(mitk::BaseRenderer *renderer)
Get the LocalStorage corresponding to the current renderer.
vtkSmartPointer< vtkPolyData > CreateOutlinePolyData(mitk::BaseRenderer *renderer, vtkImageData *image, int pixelValue=1)
Generates a vtkPolyData object containing the outline of a given binary slice.
void TransformActor(mitk::BaseRenderer *renderer)
Transforms the actor to the actual position in 3D.
bool RenderingGeometryIntersectsImage(const PlaneGeometry *renderingGeometry, const BaseGeometry *imageGeometry) const
Calculates whether the given rendering geometry intersects the given SlicedGeometry3D.
void GenerateLookupTable(mitk::BaseRenderer *renderer)
Generates the look up table that should be used.
Base class for mapper specific rendering resources.
Definition: mitkMapper.h:191
Base class of all mappers, Vtk as well as OpenGL mappers.
Definition: mitkMapper.h:47
static const LabelValueType UNLABELED_VALUE
mitk::Label::PixelType LabelValueType
Describes a two-dimensional, rectangular plane.
Base class of all Vtk Mappers in order to display primitives by exploiting Vtk functionality.
Definition: mitkVtkMapper.h:48
VTK Fix to speed up our image rendering.
Find image slices visible on a given plane.
std::size_t TimeStepType
double ScalarType