Medical Imaging Interaction Toolkit  2018.4.99-389bf124
Medical Imaging Interaction Toolkit
mitkSurfaceVtkMapper2D.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 mitkSurfaceVtkMapper2D_h
14 #define mitkSurfaceVtkMapper2D_h
15 
16 #include "mitkBaseRenderer.h"
18 #include "mitkVtkMapper.h"
19 #include <MitkCoreExports.h>
20 
21 // VTK
22 #include <vtkSmartPointer.h>
23 class vtkAssembly;
24 class vtkCutter;
25 class vtkPlane;
26 class vtkLookupTable;
27 class vtkGlyph3D;
28 class vtkArrowSource;
29 class vtkReverseSense;
30 
31 namespace mitk
32 {
33  class Surface;
34 
57  {
58  public:
60 
61  itkFactorylessNewMacro(Self);
62 
63  itkCloneMacro(Self);
64 
65  virtual const mitk::Surface *GetInput() const;
66 
68  vtkProp *GetVtkProp(mitk::BaseRenderer *renderer) override;
69 
71  static void SetDefaultProperties(mitk::DataNode *node, mitk::BaseRenderer *renderer = nullptr, bool overwrite = false);
72 
75  {
76  public:
78  itk::TimeStamp m_LastUpdateTime;
86  vtkSmartPointer<vtkAssembly> m_PropAssembly;
87 
91  vtkSmartPointer<vtkActor> m_Actor;
95  vtkSmartPointer<vtkActor> m_NormalActor;
99  vtkSmartPointer<vtkActor> m_InverseNormalActor;
103  vtkSmartPointer<vtkPolyDataMapper> m_Mapper;
107  vtkSmartPointer<vtkCutter> m_Cutter;
111  vtkSmartPointer<vtkPlane> m_CuttingPlane;
112 
116  vtkSmartPointer<vtkPolyDataMapper> m_NormalMapper;
117 
121  vtkSmartPointer<vtkPolyDataMapper> m_InverseNormalMapper;
122 
126  vtkSmartPointer<vtkGlyph3D> m_NormalGlyph;
127 
131  vtkSmartPointer<vtkGlyph3D> m_InverseNormalGlyph;
132 
136  vtkSmartPointer<vtkArrowSource> m_ArrowSource;
137 
141  vtkSmartPointer<vtkReverseSense> m_ReverseSense;
142 
144  LocalStorage();
146  ~LocalStorage() override;
147  };
148 
151 
162  void UpdateVtkTransform(mitk::BaseRenderer * /*renderer*/) override {}
163  protected:
168 
172  ~SurfaceVtkMapper2D() override;
173 
178  void GenerateDataForRenderer(mitk::BaseRenderer *renderer) override;
179 
187  void ResetMapper(BaseRenderer *renderer) override;
188 
200  virtual void FixupLegacyProperties(PropertyList *properties);
201 
206  void ApplyAllProperties(BaseRenderer *renderer);
207 
212  void Update(BaseRenderer *renderer) override;
213  };
214 } // namespace mitk
215 #endif /* mitkSurfaceVtkMapper2D_h */
void UpdateVtkTransform(mitk::BaseRenderer *) override
UpdateVtkTransform Overwrite the method of the base class.
Vtk-based mapper for cutting 2D slices out of Surfaces.
vtkSmartPointer< vtkPlane > m_CuttingPlane
m_CuttingPlane The plane where to cut off the 2D slice.
Class for storing surfaces (vtkPolyData).
Definition: mitkSurface.h:28
Base class for mapper specific rendering ressources.
Definition: mitkMapper.h:193
#define MITKCORE_EXPORT
Internal class holding the mapper, actor, etc. for each of the 3 2D render windows.
Organizes the rendering process.
vtkSmartPointer< vtkArrowSource > m_ArrowSource
m_ArrowSource Arrow representation of the normals.
static void Update(vtkPolyData *)
Definition: mitkSurface.cpp:31
itk::TimeStamp m_LastUpdateTime
Timestamp of last update of stored data.
DataCollection - Class to facilitate loading/accessing structured data.
vtkSmartPointer< vtkActor > m_InverseNormalActor
m_InverseNormalActor actor for the inverse normals.
Key-value list holding instances of BaseProperty.
Base class of all Vtk Mappers in order to display primitives by exploiting Vtk functionality.
Definition: mitkVtkMapper.h:48
Base class of all mappers, Vtk as well as OpenGL mappers.
Definition: mitkMapper.h:49
vtkSmartPointer< vtkGlyph3D > m_InverseNormalGlyph
m_InverseNormalGlyph Glyph for creating inverse normals.
vtkSmartPointer< vtkGlyph3D > m_NormalGlyph
m_NormalGlyph Glyph for creating normals.
#define mitkClassMacro(className, SuperClassName)
Definition: mitkCommon.h:40
vtkSmartPointer< vtkPolyDataMapper > m_NormalMapper
m_NormalMapper Mapper for the normals.
vtkSmartPointer< vtkPolyDataMapper > m_InverseNormalMapper
m_InverseNormalMapper Mapper for the inverse normals.
vtkSmartPointer< vtkReverseSense > m_ReverseSense
m_ReverseSense Filter to invert the normals.
vtkSmartPointer< vtkActor > m_NormalActor
m_NormalActor actor for the normals.
mitk::LocalStorageHandler< LocalStorage > m_LSH
The LocalStorageHandler holds all (three) LocalStorages for the three 2D render windows.
vtkSmartPointer< vtkAssembly > m_PropAssembly
m_PropAssembly Contains all vtkProps for the final rendering.
vtkSmartPointer< vtkPolyDataMapper > m_Mapper
m_Mapper VTK mapper for all types of 2D polydata e.g. werewolves.
vtkSmartPointer< vtkActor > m_Actor
m_Actor actor for the surface cut.
Class for nodes of the DataTree.
Definition: mitkDataNode.h:57
vtkSmartPointer< vtkCutter > m_Cutter
m_Cutter Filter to cut out the 2D slice.