Medical Imaging Interaction Toolkit  2018.4.99-389bf124
Medical Imaging Interaction Toolkit
Step7.cpp
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 #include "Step7.h"
14 
15 #include <QmitkRenderWindow.h>
16 #include <QmitkSliceWidget.h>
17 
18 #include <mitkProperties.h>
19 
20 #include <mitkRenderingManager.h>
21 #include <mitkSurface.h>
22 
23 #include <vtkImageData.h>
24 #include <vtkMarchingCubes.h>
25 #include <vtkSTLWriter.h>
26 
27 //##Documentation
28 //## @brief Convert result of region-grower into a surface
29 //## by means of a VTK filter
30 Step7::Step7(int argc, char *argv[], QWidget *parent) : Step6(argc, argv, parent)
31 {
32 }
34 {
36 
37  std::cout << "7";
38  if (m_ResultImage.IsNotNull())
39  {
40  m_ResultNode->SetProperty("volumerendering", mitk::BoolProperty::New(false));
41 
42  vtkMarchingCubes *surfaceCreator = vtkMarchingCubes::New();
43  surfaceCreator->SetInputData(m_ResultImage->GetVtkImageData());
44  surfaceCreator->SetValue(0, 1);
45  surfaceCreator->Update();
46 
48  surface->SetVtkPolyData(surfaceCreator->GetOutput()); // VTK6_TODO
49 
51  surfaceNode->SetData(surface);
52 
53  m_DataStorage->Add(surfaceNode);
54 
56  std::cout << "8";
57  surfaceCreator->Delete();
58  }
59 
60  std::cout << "9";
61 }
62 
virtual void StartRegionGrowing()
Definition: Step6.cpp:106
Definition: Step6.h:28
void StartRegionGrowing() override
Definition: Step7.cpp:33
mitk::Image::Pointer m_ResultImage
Definition: Step6.h:50
Step7(int argc, char *argv[], QWidget *parent=nullptr)
Convert result of region-grower into a surface by means of a VTK filter.
Definition: Step7.cpp:30
static Pointer New()
static Pointer New()
static RenderingManager * GetInstance()
mitk::DataNode::Pointer m_ResultNode
Definition: Step6.h:51
static Pointer New()
void RequestUpdateAll(RequestType type=REQUEST_UPDATE_ALL)
mitk::StandaloneDataStorage::Pointer m_DataStorage
Definition: Step6.h:46