Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkRegEvaluationMapper2D.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 mitkRegEvaluationMapper2D_h
14 #define mitkRegEvaluationMapper2D_h
15 
16 //MatchPoint
17 #include <mapRegistration.h>
19 
20 //MITK
21 #include <mitkCommon.h>
22 
23 //MITK Rendering
24 #include "mitkBaseRenderer.h"
25 #include "mitkVtkMapper.h"
26 #include "mitkExtractSliceFilter.h"
27 
28 //VTK
29 #include <vtkSmartPointer.h>
30 #include <vtkPropAssembly.h>
31 
32 //MITK
34 
35 class vtkActor;
36 class vtkPolyDataMapper;
37 class vtkPlaneSource;
38 class vtkImageData;
39 class vtkLookupTable;
40 class vtkImageExtractComponents;
41 class vtkImageReslice;
42 class vtkImageChangeInformation;
43 class vtkPoints;
45 class vtkPolyData;
46 class vtkMitkApplyLevelWindowToRGBFilter;
48 
49 namespace mitk {
50 
55 {
56 
57 public:
60 
62  itkFactorylessNewMacro(Self);
63  itkCloneMacro(Self);
64 
73 
76  void Update(mitk::BaseRenderer * renderer) override;
77 
78  //### methods of MITK-VTK rendering pipeline
79  vtkProp* GetVtkProp(mitk::BaseRenderer* renderer) override;
80  //### end of methods of MITK-VTK rendering pipeline
81 
90  {
91  public:
94 
100 
118 
124 
126  itk::TimeStamp m_LastUpdateTime;
127 
130 
133 
136 
139 
143  ~LocalStorage() override;
144  };
145 
148 
151 
153  static void SetDefaultProperties(mitk::DataNode* node, mitk::BaseRenderer* renderer = nullptr, bool overwrite = false);
154 
155 protected:
160 
174  void GeneratePlane(mitk::BaseRenderer* renderer, double planeBounds[6]);
175 
180 
193  void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override;
194 
195  void PrepareContour( mitk::DataNode* datanode, LocalStorage * localStorage );
196 
197  void PrepareDifference( LocalStorage * localStorage );
198 
199  void PrepareWipe(mitk::DataNode* datanode, LocalStorage * localStorage, const Point2D& currentIndex2D);
200 
201  void PrepareCheckerBoard( mitk::DataNode* datanode, LocalStorage * localStorage );
202 
203  void PrepareColorBlend( LocalStorage * localStorage );
204 
205  void PrepareBlend( mitk::DataNode* datanode, LocalStorage * localStorage );
206 
211 
216  void ApplyLookuptable(mitk::BaseRenderer* renderer, const mitk::DataNode* dataNode, vtkMitkLevelWindowFilter* levelFilter);
217 
225  void ApplyLevelWindow(mitk::BaseRenderer *renderer, const mitk::DataNode* dataNode, vtkMitkLevelWindowFilter* levelFilter);
226 
228  void ApplyOpacity( mitk::BaseRenderer* renderer );
229 
243  bool RenderingGeometryIntersectsImage( const PlaneGeometry* renderingGeometry, SlicedGeometry3D* imageGeometry );
244 };
245 
246 } // namespace mitk
247 
248 #endif
#define MITKMATCHPOINTREGISTRATION_EXPORT
Class for nodes of the DataTree.
Definition: mitkDataNode.h:64
Image class for storing images.
Definition: mitkImage.h:70
MAPRegistrationWrapper Wrapper class to allow the handling of MatchPoint registration objects as mitk...
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.
Internal class holding the mapper, actor, etc. for each of the 3 2D render windows.
vtkSmartPointer< vtkPropAssembly > m_Actors
vtkSmartPointer< vtkLookupTable > m_DefaultLookupTable
vtkSmartPointer< vtkImageData > m_EvaluationImage
Current slice of a 2D render window.
mitk::ExtractSliceFilter::Pointer m_Reslicer
The actual reslicer (one per renderer)
vtkSmartPointer< vtkLookupTable > m_ColorLookupTable
The lookuptables for colors and level window.
itk::TimeStamp m_LastUpdateTime
Timestamp of last update of stored data.
vtkSmartPointer< vtkImageExtractComponents > m_MappedExtractFilter
vtkSmartPointer< vtkMitkLevelWindowFilter > m_MappedLevelWindowFilter
This filter is used to apply the level window to moving image.
vtkSmartPointer< vtkPlaneSource > m_Plane
Plane on which the slice is rendered as texture.
vtkSmartPointer< vtkImageExtractComponents > m_TargetExtractFilter
LocalStorage()
Default constructor of the local storage.
~LocalStorage() override
Default deconstructor of the local storage.
vtkSmartPointer< vtkMitkLevelWindowFilter > m_TargetLevelWindowFilter
This filter is used to apply the level window to target image.
vtkSmartPointer< vtkActor > m_Actor
Actor of a 2D render window.
vtkSmartPointer< vtkTexture > m_Texture
The texture which is used to render the current slice.
vtkSmartPointer< vtkPolyData > m_EmptyPolyData
Empty vtkPolyData that is set when rendering geometry does not intersect the image geometry.
mitk::ScalarType * m_mmPerPixel
mmPerPixel relation between pixel and mm. (World spacing).
vtkSmartPointer< vtkPolyDataMapper > m_Mapper
Mapper of a 2D render window.
Mapper to resample and display 2D slices of registration evaluation visualization.
void TransformActor(mitk::BaseRenderer *renderer)
Transforms the actor to the actual position in 3D.
const mitk::MAPRegistrationWrapper * GetRegistration(void)
Get the target image to map.
void ApplyLevelWindow(mitk::BaseRenderer *renderer, const mitk::DataNode *dataNode, vtkMitkLevelWindowFilter *levelFilter)
ApplyLevelWindow Apply the level window for the given renderer.
bool RenderingGeometryIntersectsImage(const PlaneGeometry *renderingGeometry, SlicedGeometry3D *imageGeometry)
Calculates whether the given rendering geometry intersects the given SlicedGeometry3D.
void Update(mitk::BaseRenderer *renderer) override
Checks whether this mapper needs to update itself and generate data.
const mitk::DataNode * GetMovingNode(void)
void PrepareContour(mitk::DataNode *datanode, LocalStorage *localStorage)
void PrepareDifference(LocalStorage *localStorage)
void ApplyLookuptable(mitk::BaseRenderer *renderer, const mitk::DataNode *dataNode, vtkMitkLevelWindowFilter *levelFilter)
This method applies (or modifies) the lookuptable for all types of images.
static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer=nullptr, bool overwrite=false)
Set the default properties for general image rendering.
mitkClassMacro(RegEvaluationMapper2D, VtkMapper)
void PrepareCheckerBoard(mitk::DataNode *datanode, LocalStorage *localStorage)
float CalculateLayerDepth(mitk::BaseRenderer *renderer)
This method uses the vtkCamera clipping range and the layer property to calculate the depth of the ob...
vtkProp * GetVtkProp(mitk::BaseRenderer *renderer) override
void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override
Does the actual resampling, without rendering the image yet. All the data is generated inside this me...
void PrepareWipe(mitk::DataNode *datanode, LocalStorage *localStorage, const Point2D &currentIndex2D)
const mitk::DataNode * GetTargetNode(void)
const mitk::Image * GetTargetImage(void)
Get the target image to map.
void PrepareBlend(mitk::DataNode *datanode, LocalStorage *localStorage)
LocalStorage * GetLocalStorage(mitk::BaseRenderer *renderer)
Get the LocalStorage corresponding to the current renderer.
void ApplyOpacity(mitk::BaseRenderer *renderer)
Set the opacity of the actor.
mitk::LocalStorageHandler< LocalStorage > m_LSH
The LocalStorageHandler holds all (three) LocalStorages for the three 2D render windows.
void GeneratePlane(mitk::BaseRenderer *renderer, double planeBounds[6])
Generates a plane according to the size of the resliced image in millimeters.
void PrepareColorBlend(LocalStorage *localStorage)
const mitk::Image * GetMovingImage(void)
Get the moving image to map.
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