Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkDoseImageVtkMapper2D.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 mitkDoseImageVtkMapper2D_h
14 #define mitkDoseImageVtkMapper2D_h
15 
16 //MITK
17 #include <mitkCommon.h>
18 #include <MitkRTExports.h>
19 
20 //MITK Rendering
21 #include "mitkBaseRenderer.h"
22 #include "mitkVtkMapper.h"
23 #include "mitkExtractSliceFilter.h"
24 
25 //VTK
26 #include <vtkSmartPointer.h>
27 #include <vtkPropAssembly.h>
28 #include <vtkCellArray.h>
29 
30 class vtkActor;
31 class vtkPolyDataMapper;
32 class vtkPlaneSource;
33 class vtkImageData;
34 class vtkLookupTable;
35 class vtkImageExtractComponents;
36 class vtkImageReslice;
37 class vtkImageChangeInformation;
38 class vtkPoints;
40 class vtkPolyData;
41 class vtkMitkApplyLevelWindowToRGBFilter;
43 
44 namespace mitk {
45 
112  {
113 
114  public:
117 
119  itkFactorylessNewMacro(Self);
120  itkCloneMacro(Self);
121 
123  const mitk::Image *GetInput(void);
124 
127  void Update(mitk::BaseRenderer * renderer) override;
128 
129  //### methods of MITK-VTK rendering pipeline
130  vtkProp* GetVtkProp(mitk::BaseRenderer* renderer) override;
131  //### end of methods of MITK-VTK rendering pipeline
132 
133 
142  {
143  public:
146 
177 
179  itk::TimeStamp m_LastUpdateTime;
180 
183 
186 
190  ~LocalStorage() override;
191  };
192 
195 
198 
200  static void SetDefaultProperties(mitk::DataNode* node, mitk::BaseRenderer* renderer = nullptr, bool overwrite = false);
201 
206 
207  protected:
212 
226  void GeneratePlane(mitk::BaseRenderer* renderer, double planeBounds[6]);
227 
233 
238 
251  void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override;
252 
257 
263 
270 
277 
279  void ApplyColor( mitk::BaseRenderer* renderer );
280 
282  void ApplyOpacity( mitk::BaseRenderer* renderer );
283 
294  bool RenderingGeometryIntersectsImage( const PlaneGeometry* renderingGeometry, SlicedGeometry3D* imageGeometry );
295 
296  private:
297  void CreateLevelOutline(mitk::BaseRenderer* renderer, const mitk::IsoDoseLevel* level, float pref, vtkSmartPointer<vtkPoints> points, vtkSmartPointer<vtkCellArray> lines, vtkSmartPointer<vtkUnsignedCharArray> colors);
298 
299  };
300 
301 } // namespace mitk
302 
303 #endif
#define MITKRT_EXPORT
Definition: MitkRTExports.h:15
Class for nodes of the DataTree.
Definition: mitkDataNode.h:64
Internal class holding the mapper, actor, etc. for each of the 3 2D render windows.
vtkSmartPointer< vtkLookupTable > m_ColorLookupTable
vtkSmartPointer< vtkTexture > m_Texture
The texture which is used to render the current slice.
~LocalStorage() override
Default deconstructor of the local storage.
mitk::ScalarType * m_mmPerPixel
mmPerPixel relation between pixel and mm. (World spacing).
vtkSmartPointer< vtkImageExtractComponents > m_VectorComponentExtractor
vtkSmartPointer< vtkPlaneSource > m_Plane
Plane on which the slice is rendered as texture.
vtkSmartPointer< vtkImageData > m_ReslicedImage
Current slice of a 2D render window.
vtkSmartPointer< vtkActor > m_Actor
Actor of a 2D render window.
vtkSmartPointer< vtkPolyDataMapper > m_Mapper
Mapper of a 2D render window.
LocalStorage()
Default constructor of the local storage.
vtkSmartPointer< vtkLookupTable > m_BinaryLookupTable
mitk::ExtractSliceFilter::Pointer m_Reslicer
The actual reslicer (one per renderer)
vtkSmartPointer< vtkMitkLevelWindowFilter > m_LevelWindowFilter
This filter is used to apply the level window to Grayvalue and RBG(A) images.
vtkSmartPointer< vtkPolyData > m_EmptyPolyData
Empty vtkPolyData that is set when rendering geometry does not intersect the image geometry.
itk::TimeStamp m_LastUpdateTime
Timestamp of last update of stored data.
vtkSmartPointer< vtkLookupTable > m_DefaultLookupTable
The lookuptables for colors and level window.
vtkSmartPointer< vtkPropAssembly > m_Actors
vtkSmartPointer< vtkPolyData > m_OutlinePolyData
PolyData object containing all lines/points needed for outlining the contour. This container is used ...
vtkSmartPointer< vtkMitkThickSlicesFilter > m_TSFilter
Filter for thick slices.
Mapper to resample and display 2D slices of a 3D image.
void TransformActor(mitk::BaseRenderer *renderer)
Transforms the actor to the actual position in 3D.
void ApplyLevelWindow(mitk::BaseRenderer *renderer)
ApplyLevelWindow Apply the level window for the given renderer.
void ApplyLookuptable(mitk::BaseRenderer *renderer)
This method applies (or modifies) the lookuptable for all types of images.
vtkSmartPointer< vtkPolyData > CreateOutlinePolyData(mitk::BaseRenderer *renderer)
Generates a vtkPolyData object containing the outline of a given binary slice.
void ApplyColor(mitk::BaseRenderer *renderer)
Set the color of the image/polydata.
const mitk::Image * GetInput(void)
Get the Image to map.
void ApplyOpacity(mitk::BaseRenderer *renderer)
Set the opacity of the actor.
vtkProp * GetVtkProp(mitk::BaseRenderer *renderer) override
mitk::LocalStorageHandler< LocalStorage > m_LSH
The LocalStorageHandler holds all (three) LocalStorages for the three 2D render windows.
float CalculateLayerDepth(mitk::BaseRenderer *renderer)
This method uses the vtkCamera clipping range and the layer property to calculate the depth of the ob...
void ApplyRenderingMode(mitk::BaseRenderer *renderer)
This method switches between different rendering modes (e.g. use a lookup table or a transfer functio...
void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override
Does the actual resampling, without rendering the image yet. All the data is generated inside this me...
static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer=nullptr, bool overwrite=false)
Set the default properties for general image rendering.
void ApplyColorTransferFunction(mitk::BaseRenderer *renderer)
This method applies a color transfer function. Internally, a vtkColorTransferFunction is used....
void GeneratePlane(mitk::BaseRenderer *renderer, double planeBounds[6])
Generates a plane according to the size of the resliced image in millimeters.
void Update(mitk::BaseRenderer *renderer) override
Checks whether this mapper needs to update itself and generate data.
mitkClassMacro(DoseImageVtkMapper2D, VtkMapper)
bool RenderingGeometryIntersectsImage(const PlaneGeometry *renderingGeometry, SlicedGeometry3D *imageGeometry)
Calculates whether the given rendering geometry intersects the given SlicedGeometry3D.
LocalStorage * GetLocalStorage(mitk::BaseRenderer *renderer)
Get the LocalStorage corresponding to the current renderer.
Image class for storing images.
Definition: mitkImage.h:70
Stores values needed for the representation/visualization of dose iso levels.
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
Describes a two-dimensional, rectangular plane.
Describes the geometry of a data object consisting of slices.
Base class of all Vtk Mappers in order to display primitives by exploiting Vtk functionality.
Definition: mitkVtkMapper.h:48
Applies the grayvalue or color/opacity level window to scalar or RGB(A) images.
Find image slices visible on a given plane.
double ScalarType