Medical Imaging Interaction Toolkit  2018.4.99-389bf124
Medical Imaging Interaction Toolkit
QmitkDataNodeShowSelectedNodesAction.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 
15 
16 // mitk core
17 #include <mitkRenderingManager.h>
18 
20  : QAction(parent)
21  , QmitkAbstractDataNodeAction(workbenchpartSite)
22 {
23  setText(tr("Show only selected nodes"));
25 }
26 
28  : QAction(parent)
29  , QmitkAbstractDataNodeAction(berry::IWorkbenchPartSite::Pointer(workbenchpartSite))
30 {
31  setText(tr("Show only selected nodes"));
33 }
34 
36 {
37  connect(this, &QmitkDataNodeShowSelectedNodesAction::triggered, this, &QmitkDataNodeShowSelectedNodesAction::OnActionTriggered);
38 }
39 
40 void QmitkDataNodeShowSelectedNodesAction::OnActionTriggered(bool /*checked*/)
41 {
43  {
44  return;
45  }
46 
47  auto dataStorage = m_DataStorage.Lock();
48 
50 
51  auto selectedNodes = GetSelectedNodes();
52 
53  auto allNodes = dataStorage->GetAll();
54 
55  for (auto& node : *allNodes)
56  {
57  if (node.IsNotNull() && node->GetData() != nullptr && strcmp(node->GetData()->GetNameOfClass(), "PlaneGeometryData"))
58  {
59  node->SetVisibility(selectedNodes.contains(node), baseRenderer);
60  }
61  }
62 
63  if (nullptr == baseRenderer)
64  {
66  }
67  else
68  {
69  mitk::RenderingManager::GetInstance()->RequestUpdate(baseRenderer->GetRenderWindow());
70  }
71 }
mitk::BaseRenderer::Pointer GetBaseRenderer()
Grants access to the base renderer stored for the action. Will return nullptr if renderer was never s...
itk::SmartPointer< T > Lock() const
QList< mitk::DataNode::Pointer > GetSelectedNodes() const
static RenderingManager * GetInstance()
bool IsExpired() const noexcept
QmitkDataNodeShowSelectedNodesAction(QWidget *parent, berry::IWorkbenchPartSite::Pointer workbenchPartSite)
mitk::WeakPointer< mitk::DataStorage > m_DataStorage
void RequestUpdate(vtkRenderWindow *renderWindow)
void RequestUpdateAll(RequestType type=REQUEST_UPDATE_ALL)