Medical Imaging Interaction Toolkit  2025.12.02
Medical Imaging Interaction Toolkit
mitkPointSetVtkMapper2D.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 mitkPointSetVtkMapper2D_h
14 #define mitkPointSetVtkMapper2D_h
15 
16 #include "mitkBaseRenderer.h"
18 #include "mitkVtkMapper.h"
19 #include <MitkCoreExports.h>
21 
22 // VTK
23 #include <vtkSmartPointer.h>
24 class vtkActor;
25 class vtkPropAssembly;
26 class vtkPolyData;
27 class vtkPolyDataMapper;
28 class vtkGlyphSource2D;
29 class vtkGlyph3D;
30 class vtkFloatArray;
31 class vtkCellArray;
32 
33 namespace mitk
34 {
35  class PointSet;
36 
118  {
119  public:
121 
122  itkFactorylessNewMacro(Self);
123 
124  itkCloneMacro(Self);
125 
126  virtual const mitk::PointSet *GetInput() const;
127 
129  vtkProp *GetVtkProp(mitk::BaseRenderer *renderer) override;
130 
132  static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer = nullptr, bool overwrite = false);
133 
136  {
137  public:
138  /* constructor */
140 
141  /* destructor */
142  ~LocalStorage() override;
143 
144  // points
148 
149  // scales
153 
154  // distances
156 
157  // lines
159 
160  // glyph source (provides different shapes for the points)
164 
165  // glyph
169 
170  // polydata
175 
176  // actor
182 
183  std::vector<vtkSmartPointer<vtkTextActor>> m_VtkTextLabelActors;
184  std::vector<vtkSmartPointer<vtkTextActor>> m_VtkTextDistanceActors;
185  std::vector<vtkSmartPointer<vtkTextActor>> m_VtkTextAngleActors;
186 
187  // mappers
192 
193  // propassembly
195  };
196 
199 
200  protected:
201  /* constructor */
203 
204  /* destructor */
206 
207  /* \brief Applies the color and opacity properties and calls CreateVTKRenderObjects */
208  void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override;
209  /* \brief Called in mitk::Mapper::Update
210  * If TimeGeometry or time step is not valid of point set: reset mapper so that nothing is
211  * displayed e.g. toggle visibility of the propassembly */
212  void ResetMapper(BaseRenderer *renderer) override;
213 
214  /* \brief Fills the vtk objects, thus it is only called when the point set has been changed.
215  * This function iterates over the input point set and determines the glyphs which lie in a specific
216  * range around the current slice. Those glyphs are rendered using a specific shape defined in vtk glyph source
217  * to mark each point. The shape can be changed in MITK using the property "PointSet.2D.shape".
218  *
219  * There were issues when rendering vtk glyphs in the 2D-render windows. By default, the glyphs are
220  * rendered within the x-y plane in each 2D-render window, so you would only see them from the
221  * side in the sagittal and coronal 2D-render window. The solution to this is to rotate the glyphs in order
222  * to be orthogonal to the current view vector. To achieve this, the rotation (vtktransform) of the current
223  * PlaneGeometry is applied to the orientation of the glyphs. */
225 
226  // member variables holding the current value of the properties used in this mapper
227  bool m_ShowContour; // "show contour" property
228  bool m_CloseContour; // "close contour" property
229  bool m_ShowPoints; // "show points" property
230  bool m_ShowDistances; // "show distances" property
231  int m_DistancesDecimalDigits; // "distance decimal digits" property
232  bool m_ShowAngles; // "show angles" property
233  bool m_ShowDistantLines; // "show distant lines" property
234  int m_LineWidth; // "line width" property
235  int m_PointLineWidth; // "point line width" property
236  float m_Point2DSize; // "point 2D size" property
237  int m_IDShapeProperty; // ID for mitkPointSetShape Enumeration Property "Pointset.2D.shape"
238  bool m_FillShape; // "Pointset.2D.fill shape" property
239  float m_DistanceToPlane; // "Pointset.2D.distance to plane" property
240  bool m_FixedSizeOnScreen; // "Pointset.2D.fixed size on screen" property
241  int m_Resolution; // "Pointset.2D.resolution" property
242  bool m_KeepShapeWhenSelected; // "Pointset.2D.keep shape when selected" property
243  bool m_ShowSelectedContour; // "Pointset.2D.selected.show contour" property
244  };
245 
246 } // namespace mitk
247 
248 #endif
#define MITKCORE_EXPORT
Class for nodes of the DataTree.
Definition: mitkDataNode.h:64
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
Internal class holding the mapper, actor, etc. for each of the 3 2D render windows.
vtkSmartPointer< vtkPolyDataMapper > m_VtkUnselectedPolyDataMapper
vtkSmartPointer< vtkPoints > m_UnselectedPoints
vtkSmartPointer< vtkGlyphSource2D > m_SelectedContourGlyphSource2D
vtkSmartPointer< vtkPolyData > m_VtkContourPolyData
std::vector< vtkSmartPointer< vtkTextActor > > m_VtkTextAngleActors
vtkSmartPointer< vtkFloatArray > m_UnselectedScales
vtkSmartPointer< vtkGlyphSource2D > m_UnselectedGlyphSource2D
vtkSmartPointer< vtkTextActor > m_VtkTextActor
vtkSmartPointer< vtkFloatArray > m_SelectedScales
vtkSmartPointer< vtkGlyph3D > m_SelectedGlyph3D
std::vector< vtkSmartPointer< vtkTextActor > > m_VtkTextLabelActors
vtkSmartPointer< vtkPolyData > m_VtkUnselectedPointListPolyData
vtkSmartPointer< vtkGlyph3D > m_SelectedContourGlyph3D
vtkSmartPointer< vtkPolyData > m_VtkSelectedContourPointListPolyData
vtkSmartPointer< vtkGlyph3D > m_UnselectedGlyph3D
vtkSmartPointer< vtkActor > m_SelectedContourActor
vtkSmartPointer< vtkFloatArray > m_SelectedContourScales
std::vector< vtkSmartPointer< vtkTextActor > > m_VtkTextDistanceActors
vtkSmartPointer< vtkPolyDataMapper > m_VtkSelectedContourPolyDataMapper
vtkSmartPointer< vtkPolyData > m_VtkSelectedPointListPolyData
vtkSmartPointer< vtkPropAssembly > m_PropAssembly
vtkSmartPointer< vtkGlyphSource2D > m_SelectedGlyphSource2D
vtkSmartPointer< vtkPolyDataMapper > m_VtkSelectedPolyDataMapper
vtkSmartPointer< vtkPolyDataMapper > m_VtkContourPolyDataMapper
vtkSmartPointer< vtkFloatArray > m_DistancesBetweenPoints
vtkSmartPointer< vtkCellArray > m_ContourLines
Vtk-based 2D mapper for PointSet.
static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer=nullptr, bool overwrite=false)
set the default properties for this mapper
vtkProp * GetVtkProp(mitk::BaseRenderer *renderer) override
returns the a prop assembly
virtual const mitk::PointSet * GetInput() const
void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override
Generate the data needed for rendering into renderer.
mitk::LocalStorageHandler< LocalStorage > m_LSH
The LocalStorageHandler holds all (three) LocalStorages for the three 2D render windows.
virtual void CreateVTKRenderObjects(mitk::BaseRenderer *renderer)
void ResetMapper(BaseRenderer *renderer) override
Reset the mapper (i.e., make sure that nothing is displayed) if no valid data is present....
Data structure which stores a set of points.
Definition: mitkPointSet.h:72
Base class of all Vtk Mappers in order to display primitives by exploiting Vtk functionality.
Definition: mitkVtkMapper.h:48
#define mitkClassMacro(className, SuperClassName)
Definition: mitkCommon.h:36
Find image slices visible on a given plane.