diff --git a/Modules/Core/src/DataManagement/mitkLevelWindowManager.cpp b/Modules/Core/src/DataManagement/mitkLevelWindowManager.cpp
index 18e8da1d1a..fd7cb484f6 100644
--- a/Modules/Core/src/DataManagement/mitkLevelWindowManager.cpp
+++ b/Modules/Core/src/DataManagement/mitkLevelWindowManager.cpp
@@ -1,721 +1,724 @@
 /*============================================================================
 
 The Medical Imaging Interaction Toolkit (MITK)
 
 Copyright (c) German Cancer Research Center (DKFZ)
 All rights reserved.
 
 Use of this source code is governed by a 3-clause BSD license that can be
 found in the LICENSE file.
 
 ============================================================================*/
 
 #include "mitkLevelWindowManager.h"
 #include "mitkDataStorage.h"
 #include "mitkImage.h"
 #include "mitkMessage.h"
 #include "mitkNodePredicateAnd.h"
 #include "mitkNodePredicateBase.h"
 #include "mitkNodePredicateDataType.h"
 #include "mitkNodePredicateNot.h"
 #include "mitkNodePredicateOr.h"
 #include "mitkNodePredicateProperty.h"
 #include "mitkProperties.h"
 #include "mitkRenderingModeProperty.h"
 #include <itkCommand.h>
 
 mitk::LevelWindowManager::LevelWindowManager()
   : m_DataStorage(nullptr)
   , m_LevelWindowProperty(nullptr)
   , m_AutoTopMost(true)
   , m_SelectedImagesMode(false)
   , m_CurrentImage(nullptr)
   , m_IsPropertyModifiedTagSet(false)
   , m_LevelWindowMutex(false)
 {
 }
 
 mitk::LevelWindowManager::~LevelWindowManager()
 {
   if (m_DataStorage.IsNotNull())
   {
     m_DataStorage->AddNodeEvent.RemoveListener(
       MessageDelegate1<LevelWindowManager, const DataNode *>(this, &LevelWindowManager::DataStorageAddedNode));
     m_DataStorage->RemoveNodeEvent.RemoveListener(
       MessageDelegate1<LevelWindowManager, const DataNode *>(this, &LevelWindowManager::DataStorageRemovedNode));
     m_DataStorage = nullptr;
   }
 
   if (m_IsPropertyModifiedTagSet && m_LevelWindowProperty.IsNotNull())
   {
     m_LevelWindowProperty->RemoveObserver(m_PropertyModifiedTag);
     m_IsPropertyModifiedTagSet = false;
   }
 
   this->ClearPropertyObserverMaps();
 }
 
 void mitk::LevelWindowManager::SetDataStorage(DataStorage *dataStorage)
 {
   if (nullptr == dataStorage)
     return;
 
   // remove listeners of old DataStorage
   if (m_DataStorage.IsNotNull())
   {
     m_DataStorage->AddNodeEvent.RemoveListener(
       MessageDelegate1<LevelWindowManager, const DataNode *>(this, &LevelWindowManager::DataStorageAddedNode));
     m_DataStorage->RemoveNodeEvent.RemoveListener(
       MessageDelegate1<LevelWindowManager, const DataNode *>(this, &LevelWindowManager::DataStorageRemovedNode));
   }
 
   // register listener for new DataStorage
   m_DataStorage = dataStorage;
   m_DataStorage->AddNodeEvent.AddListener(
     MessageDelegate1<LevelWindowManager, const DataNode *>(this, &LevelWindowManager::DataStorageAddedNode));
   m_DataStorage->RemoveNodeEvent.AddListener(
     MessageDelegate1<LevelWindowManager, const DataNode *>(this, &LevelWindowManager::DataStorageRemovedNode));
 
   this->DataStorageAddedNode();
 }
 
 mitk::DataStorage *mitk::LevelWindowManager::GetDataStorage()
 {
   return m_DataStorage.GetPointer();
 }
 
 void mitk::LevelWindowManager::SetAutoTopMostImage(bool autoTopMost, const DataNode *removedNode/* = nullptr*/)
 {
   m_AutoTopMost = autoTopMost;
   if (false == m_AutoTopMost)
   {
     return;
   }
 
   // deactivate other mode
   m_SelectedImagesMode = false;
 
   if (m_IsPropertyModifiedTagSet && m_LevelWindowProperty.IsNotNull())
   {
     m_LevelWindowProperty->RemoveObserver(m_PropertyModifiedTag);
     m_IsPropertyModifiedTagSet = false;
   }
 
   // find topmost image in the data storage
   if (m_DataStorage.IsNull())
   {
     mitkThrow() << "DataStorage not set";
   }
 
   DataNode::Pointer topLevelNode;
   int maxVisibleLayer = itk::NumericTraits<int>::min();
   m_LevelWindowProperty = nullptr;
   m_CurrentImage = nullptr;
 
   DataStorage::SetOfObjects::ConstPointer all = this->GetRelevantNodes();
   for (DataStorage::SetOfObjects::ConstIterator it = all->Begin(); it != all->End(); ++it)
   {
     DataNode::Pointer node = it->Value();
     if (node.IsNull() || node == removedNode)
     {
       continue;
     }
 
     // reset the "imageForLevelWindow" of each node
     m_LevelWindowMutex = true;
     node->SetBoolProperty("imageForLevelWindow", false);
     m_LevelWindowMutex = false;
 
     if (false == node->IsVisible(nullptr))
     {
       continue;
     }
 
     bool validRenderingMode = HasLevelWindowRenderingMode(node);
     if (false == validRenderingMode)
     {
       continue;
     }
 
     int layer = -1;
     node->GetIntProperty("layer", layer);
     if (layer < maxVisibleLayer)
     {
       continue;
     }
 
     m_LevelWindowProperty = dynamic_cast<LevelWindowProperty*>(node->GetProperty("levelwindow"));
     topLevelNode = node;
     maxVisibleLayer = layer;
   }
 
   // this will set the "imageForLevelWindow" property and the 'm_CurrentImage' and call 'Modified()'
   this->SetLevelWindowProperty(m_LevelWindowProperty);
 
   if (m_LevelWindowProperty.IsNull())
   {
     this->Modified();
   }
 }
 
 void mitk::LevelWindowManager::SetSelectedImages(bool selectedImagesMode, const DataNode *removedNode/* = nullptr*/)
 {
   m_SelectedImagesMode = selectedImagesMode;
   if (false == m_SelectedImagesMode)
   {
     return;
   }
 
   // deactivate other mode
   m_AutoTopMost = false;
 
   if (m_IsPropertyModifiedTagSet && m_LevelWindowProperty.IsNotNull())
   {
     m_LevelWindowProperty->RemoveObserver(m_PropertyModifiedTag);
     m_IsPropertyModifiedTagSet = false;
   }
 
   // find selected images in the data storage
   if (m_DataStorage.IsNull())
   {
     mitkThrow() << "DataStorage not set";
   }
 
   DataNode::Pointer lastSelectedNode;
   m_LevelWindowProperty = nullptr;
   m_CurrentImage = nullptr;
 
   DataStorage::SetOfObjects::ConstPointer all = this->GetRelevantNodes();
   for (DataStorage::SetOfObjects::ConstIterator it = all->Begin(); it != all->End(); ++it)
   {
     DataNode::Pointer node = it->Value();
     if (node.IsNull() || node == removedNode)
     {
       continue;
     }
 
     // reset the "imageForLevelWindow" of each node
     m_LevelWindowMutex = true;
     node->SetBoolProperty("imageForLevelWindow", false);
     m_LevelWindowMutex = false;
 
     if (false == node->IsSelected())
     {
       continue;
     }
 
 
     bool validRenderingMode = HasLevelWindowRenderingMode(node);
     if (false == validRenderingMode)
     {
       continue;
     }
 
     m_LevelWindowProperty = dynamic_cast<LevelWindowProperty*>(node->GetProperty("levelwindow"));
     m_RelevantDataNodes.push_back(node);
     lastSelectedNode = node;
   }
 
   // this will set the "imageForLevelWindow" property and the 'm_CurrentImage' and call 'Modified()'
   this->SetLevelWindowProperty(m_LevelWindowProperty);
 
   if (m_LevelWindowProperty.IsNull())
   {
     this->Modified();
   }
 }
 
 void mitk::LevelWindowManager::RecalculateLevelWindowForSelectedComponent(const itk::EventObject &event)
 {
   DataStorage::SetOfObjects::ConstPointer all = this->GetRelevantNodes();
   for (DataStorage::SetOfObjects::ConstIterator it = all->Begin(); it != all->End(); ++it)
   {
     DataNode::Pointer node = it->Value();
     if (node.IsNull())
       continue;
 
     bool isSelected = false;
     node->GetBoolProperty("selected", isSelected);
     if (isSelected)
     {
       LevelWindow selectedLevelWindow;
       node->GetLevelWindow(selectedLevelWindow); // node is an image node because of predicates
 
       auto *image = dynamic_cast<Image *>(node->GetData());
       int displayedComponent = 0;
       if (image && (node->GetIntProperty("Image.Displayed Component", displayedComponent)))
       { // we found a selected image with a displayed component
         // let's recalculate the levelwindow for this.
         selectedLevelWindow.SetAuto(image, true, true, static_cast<unsigned>(displayedComponent));
         node->SetLevelWindow(selectedLevelWindow);
       }
     }
 
     LevelWindow levelWindow;
     node->GetLevelWindow(levelWindow);
   }
 
   this->Update(event);
 }
 
 void mitk::LevelWindowManager::Update(const itk::EventObject &)
 {
   if (m_LevelWindowMutex) // no mutex, should still help
   {
     return;
   }
 
   m_RelevantDataNodes.clear();
   if (m_AutoTopMost)
   {
     this->SetAutoTopMostImage(true);
     return;
   }
 
   if (m_SelectedImagesMode)
   {
     this->SetSelectedImages(true);
     return;
   }
 
   int maxVisibleLayer = itk::NumericTraits<int>::min();
   DataNode::Pointer topLevelNode = nullptr;
   std::vector<DataNode::Pointer> nodesForLevelWindow;
 
   DataStorage::SetOfObjects::ConstPointer all = this->GetRelevantNodes();
   for (DataStorage::SetOfObjects::ConstIterator it = all->Begin(); it != all->End(); ++it)
   {
     DataNode::Pointer node = it->Value();
     if (node.IsNull())
     {
       continue;
     }
 
     if (false == node->IsVisible(nullptr))
     {
       continue;
     }
 
     bool validRenderingMode = HasLevelWindowRenderingMode(node);
     if (false == validRenderingMode)
     {
       continue;
     }
 
     bool prop = false;
     node->GetBoolProperty("imageForLevelWindow", prop);
     if (prop)
     {
       nodesForLevelWindow.push_back(node);
       continue;
     }
 
     int layer = -1;
     node->GetIntProperty("layer", layer);
     if (layer > maxVisibleLayer)
     {
       // top level node is backup node, if no node with
       // "imageForLevelWindow" property with value "true" is found
       topLevelNode = node;
       maxVisibleLayer = layer;
     }
   }
 
   int nodesForLevelWindowSize = nodesForLevelWindow.size();
   if (nodesForLevelWindowSize > 2)
   {
     MITK_ERROR << "Error: not more than two visible nodes are expected to have the imageForLevelWindow property set at "
                   "any point.";
   }
 
   if (nodesForLevelWindowSize > 0)
   {
     // 1 or 2 nodes for level window found
     for (const auto& node : nodesForLevelWindow)
     {
       LevelWindowProperty::Pointer newProp = dynamic_cast<LevelWindowProperty *>(node->GetProperty("levelwindow"));
       if (newProp != m_LevelWindowProperty)
       {
         this->SetLevelWindowProperty(newProp);
         return;
       }
     }
   }
   else if (topLevelNode)
   {
     // no nodes for level window found
     LevelWindowProperty::Pointer lvlProp = dynamic_cast<LevelWindowProperty *>(topLevelNode->GetProperty("levelwindow"));
     this->SetLevelWindowProperty(lvlProp);
   }
   else
   {
     // no nodes for level window found and no visible top level node found
     this->Modified();
   }
 }
 
 void mitk::LevelWindowManager::UpdateSelected(const itk::EventObject &)
 {
   if (m_LevelWindowMutex) // no mutex, should still help
   {
     return;
   }
 
   m_RelevantDataNodes.clear();
   if (m_SelectedImagesMode)
   {
     this->SetSelectedImages(true);
   }
 }
 
 void mitk::LevelWindowManager::SetLevelWindowProperty(LevelWindowProperty::Pointer levelWindowProperty)
 {
   if (levelWindowProperty.IsNull())
   {
     return;
   }
 
   // find data node that belongs to the property
   DataStorage::SetOfObjects::ConstPointer all = m_DataStorage->GetAll();
   mitk::DataNode::Pointer propNode = nullptr;
   for (DataStorage::SetOfObjects::ConstIterator it = all->Begin(); it != all->End(); ++it)
   {
     DataNode::Pointer node = it.Value();
     LevelWindowProperty::Pointer property = dynamic_cast<LevelWindowProperty *>(node->GetProperty("levelwindow"));
     if (property == levelWindowProperty)
     {
       propNode = node;
     }
     else
     {
       m_LevelWindowMutex = true;
       node->SetBoolProperty("imageForLevelWindow", false);
       m_LevelWindowMutex = false;
     }
   }
 
   if (propNode.IsNull())
   {
     mitkThrow() << "No Image in the data storage that belongs to level-window property " << m_LevelWindowProperty;
   }
 
   if (m_IsPropertyModifiedTagSet) // remove listener for old property
   {
     m_LevelWindowProperty->RemoveObserver(m_PropertyModifiedTag);
     m_IsPropertyModifiedTagSet = false;
   }
 
   m_LevelWindowProperty = levelWindowProperty;
 
   auto command = itk::ReceptorMemberCommand<LevelWindowManager>::New(); // register listener for new property
   command->SetCallbackFunction(this, &LevelWindowManager::OnPropertyModified);
   m_PropertyModifiedTag = m_LevelWindowProperty->AddObserver(itk::ModifiedEvent(), command);
   m_IsPropertyModifiedTagSet = true;
 
   m_CurrentImage = dynamic_cast<Image *>(propNode->GetData());
 
   m_LevelWindowMutex = true;
   propNode->SetBoolProperty("imageForLevelWindow", true);
   m_LevelWindowMutex = false;
 
   this->Modified();
 }
 
 void mitk::LevelWindowManager::SetLevelWindow(const LevelWindow &levelWindow)
 {
-  if (m_LevelWindowProperty.IsNotNull())
+  if (m_LevelWindowProperty.IsNull())
   {
-    m_LevelWindowProperty->SetLevelWindow(levelWindow);
-    for (const auto &dataNode : m_RelevantDataNodes)
-    {
-      auto levelWindowProperty = dynamic_cast<LevelWindowProperty *>(dataNode->GetProperty("levelwindow"));
-      if (nullptr == levelWindowProperty)
-      {
-        continue;
-      }
+    return;
+  }
 
-      levelWindowProperty->SetLevelWindow(levelWindow);
+  m_LevelWindowProperty->SetLevelWindow(levelWindow);
+  for (const auto &dataNode : m_RelevantDataNodes)
+  {
+    auto levelWindowProperty = dynamic_cast<LevelWindowProperty *>(dataNode->GetProperty("levelwindow"));
+    if (nullptr == levelWindowProperty)
+    {
+      continue;
     }
+
+    levelWindowProperty->SetLevelWindow(levelWindow);
   }
+
   this->Modified();
 }
 
 mitk::LevelWindowProperty::Pointer mitk::LevelWindowManager::GetLevelWindowProperty()
 {
   return m_LevelWindowProperty;
 }
 
 const mitk::LevelWindow &mitk::LevelWindowManager::GetLevelWindow()
 {
   if (m_LevelWindowProperty.IsNotNull())
   {
     return m_LevelWindowProperty->GetLevelWindow();
   }
   else
   {
     mitkThrow() << "No LevelWindow available!";
   }
 }
 
 bool mitk::LevelWindowManager::IsAutoTopMost()
 {
   return m_AutoTopMost;
 }
 
 bool mitk::LevelWindowManager::IsSelectedImages()
 {
   return m_SelectedImagesMode;
 }
 
 void mitk::LevelWindowManager::DataStorageAddedNode(const DataNode *)
 {
   // update observers with new data storage
   this->UpdateObservers();
 
   // initialize LevelWindowManager to new image
   this->SetAutoTopMostImage(true);
 
   // check if everything is still ok
   if ((m_ObserverToVisibleProperty.size() != m_ObserverToLayerProperty.size()) ||
       (m_ObserverToLayerProperty.size() != this->GetRelevantNodes()->size()))
   {
     mitkThrow() << "Wrong number of observers in Level Window Manager!";
   }
 }
 
 void mitk::LevelWindowManager::DataStorageRemovedNode(const DataNode *removedNode)
 {
   // First: check if deleted node is part of relevant nodes.
   // If not, abort method because there is no need change anything.
   bool removedNodeIsRelevant = false;
   DataStorage::SetOfObjects::ConstPointer relevantNodes = GetRelevantNodes();
   for (DataStorage::SetOfObjects::ConstIterator it = relevantNodes->Begin(); it != relevantNodes->End(); ++it)
   {
     if (it->Value() == removedNode)
     {
       removedNodeIsRelevant = true;
     }
   }
 
   if (false == removedNodeIsRelevant)
   {
     return;
   }
 
   // remember node which will be removed
   m_NodeMarkedToDelete = removedNode;
 
   // update observers
   this->UpdateObservers();
 
   // search image that belongs to the property
   if (m_LevelWindowProperty.IsNull())
   {
     this->SetAutoTopMostImage(true, removedNode);
   }
   else
   {
     auto property = NodePredicateProperty::New("levelwindow", m_LevelWindowProperty);
     DataNode *n = m_DataStorage->GetNode(property);
     if (n == nullptr || m_AutoTopMost) // if node was deleted, change our behavior to AutoTopMost, if AutoTopMost is
                                        // true change level window to topmost node
     {
       this->SetAutoTopMostImage(true, removedNode);
     }
   }
 
   // reset variable
   m_NodeMarkedToDelete = nullptr;
 
   // check if everything is still ok
   if ((m_ObserverToVisibleProperty.size() != m_ObserverToLayerProperty.size()) ||
       (m_ObserverToLayerProperty.size() != (relevantNodes->size() - 1)))
   {
     mitkThrow() << "Wrong number of observers in Level Window Manager!";
   }
 }
 
 void mitk::LevelWindowManager::OnPropertyModified(const itk::EventObject &)
 {
   this->Modified();
 }
 
 mitk::Image *mitk::LevelWindowManager::GetCurrentImage()
 {
   return m_CurrentImage;
 }
 
 int mitk::LevelWindowManager::GetNumberOfObservers()
 {
   return m_ObserverToVisibleProperty.size();
 }
 
 mitk::DataStorage::SetOfObjects::ConstPointer mitk::LevelWindowManager::GetRelevantNodes()
 {
   if (m_DataStorage.IsNull())
   {
     return DataStorage::SetOfObjects::ConstPointer(DataStorage::SetOfObjects::New());
   }
 
   auto notBinary = NodePredicateProperty::New("binary", BoolProperty::New(false));
   auto hasLevelWindow = NodePredicateProperty::New("levelwindow", nullptr);
 
   auto isImage = NodePredicateDataType::New("Image");
   auto isDImage = NodePredicateDataType::New("DiffusionImage");
   auto isTImage = NodePredicateDataType::New("TensorImage");
   auto isOdfImage = NodePredicateDataType::New("OdfImage");
   auto isShImage = NodePredicateDataType::New("ShImage");
   auto predicateTypes = NodePredicateOr::New();
   predicateTypes->AddPredicate(isImage);
   predicateTypes->AddPredicate(isDImage);
   predicateTypes->AddPredicate(isTImage);
   predicateTypes->AddPredicate(isOdfImage);
   predicateTypes->AddPredicate(isShImage);
 
   NodePredicateAnd::Pointer predicate = NodePredicateAnd::New();
   predicate->AddPredicate(notBinary);
   predicate->AddPredicate(hasLevelWindow);
   predicate->AddPredicate(predicateTypes);
 
   DataStorage::SetOfObjects::ConstPointer relevantNodes = m_DataStorage->GetSubset(predicate);
 
   return relevantNodes;
 }
 
 void mitk::LevelWindowManager::UpdateObservers()
 {
   this->ClearPropertyObserverMaps();
   this->CreatePropertyObserverMaps();
 }
 
 void mitk::LevelWindowManager::ClearPropertyObserverMaps()
 {
   for (auto iter = m_ObserverToVisibleProperty.begin(); iter != m_ObserverToVisibleProperty.end(); ++iter)
   {
     (*iter).second->RemoveObserver((*iter).first.first);
     (*iter).second = nullptr;
   }
   m_ObserverToVisibleProperty.clear();
 
   for (auto iter = m_ObserverToLayerProperty.begin(); iter != m_ObserverToLayerProperty.end(); ++iter)
   {
     (*iter).second->RemoveObserver((*iter).first.first);
     (*iter).second = nullptr;
   }
   m_ObserverToLayerProperty.clear();
 
   for (auto iter = m_ObserverToRenderingModeProperty.begin(); iter != m_ObserverToRenderingModeProperty.end(); ++iter)
   {
     (*iter).second->RemoveObserver((*iter).first.first);
     (*iter).second = nullptr;
   }
   m_ObserverToRenderingModeProperty.clear();
 
   for (auto iter = m_ObserverToDisplayedComponentProperty.begin(); iter != m_ObserverToDisplayedComponentProperty.end(); ++iter)
   {
     (*iter).second->RemoveObserver((*iter).first.first);
     (*iter).second = nullptr;
   }
   m_ObserverToDisplayedComponentProperty.clear();
 
   for (auto iter = m_ObserverToLevelWindowImageProperty.begin(); iter != m_ObserverToLevelWindowImageProperty.end(); ++iter)
   {
     (*iter).second->RemoveObserver((*iter).first.first);
     (*iter).second = nullptr;
   }
   m_ObserverToLevelWindowImageProperty.clear();
 
   for (auto iter = m_ObserverToSelectedProperty.begin(); iter != m_ObserverToSelectedProperty.end(); ++iter)
   {
     (*iter).second->RemoveObserver((*iter).first.first);
     (*iter).second = nullptr;
   }
   m_ObserverToSelectedProperty.clear();
 }
 
 void mitk::LevelWindowManager::CreatePropertyObserverMaps()
 {
   if (m_DataStorage.IsNull())
   {
     mitkThrow() << "DataStorage not set";
   }
 
   // add observers for all relevant nodes
   DataStorage::SetOfObjects::ConstPointer all = this->GetRelevantNodes();
   for (DataStorage::SetOfObjects::ConstIterator it = all->Begin(); it != all->End(); ++it)
   {
     DataNode::Pointer node = it->Value();
     if (node.IsNull() || node == m_NodeMarkedToDelete)
     {
       continue;
     }
 
     auto command = itk::ReceptorMemberCommand<LevelWindowManager>::New();
     command->SetCallbackFunction(this, &LevelWindowManager::Update);
     unsigned long visIdx = node->GetProperty("visible")->AddObserver(itk::ModifiedEvent(), command);
     m_ObserverToVisibleProperty[PropDataPair(visIdx, node)] = node->GetProperty("visible");
 
     auto command2 = itk::ReceptorMemberCommand<LevelWindowManager>::New();
     command2->SetCallbackFunction(this, &LevelWindowManager::Update);
     unsigned long layerIdx = node->GetProperty("layer")->AddObserver(itk::ModifiedEvent(), command2);
     m_ObserverToLayerProperty[PropDataPair(layerIdx, node)] = node->GetProperty("layer");
 
    auto command3 = itk::ReceptorMemberCommand<LevelWindowManager>::New();
     command3->SetCallbackFunction(this, &LevelWindowManager::Update);
     BaseProperty::Pointer imageRenderingMode = node->GetProperty("Image Rendering.Mode");
     if (imageRenderingMode.IsNotNull())
     {
       unsigned long rendIdx = imageRenderingMode->AddObserver(itk::ModifiedEvent(), command3);
       m_ObserverToRenderingModeProperty[PropDataPair(rendIdx, node)] = imageRenderingMode.GetPointer();
     }
 
     auto command4 = itk::ReceptorMemberCommand<LevelWindowManager>::New();
     command4->SetCallbackFunction(this, &LevelWindowManager::RecalculateLevelWindowForSelectedComponent);
     BaseProperty::Pointer displayedImageComponent = node->GetProperty("Image.Displayed Component");
     if (displayedImageComponent.IsNotNull())
     {
       unsigned long dispIdx = displayedImageComponent->AddObserver(itk::ModifiedEvent(), command4);
       m_ObserverToDisplayedComponentProperty[PropDataPair(dispIdx, node)] = displayedImageComponent.GetPointer();
     }
 
     auto command5 = itk::ReceptorMemberCommand<LevelWindowManager>::New();
     command5->SetCallbackFunction(this, &LevelWindowManager::Update);
     BaseProperty::Pointer imgForLvlWin = node->GetProperty("imageForLevelWindow");
     if (imgForLvlWin.IsNull())
     {
       node->SetBoolProperty("imageForLevelWindow", false);
       imgForLvlWin = node->GetProperty("imageForLevelWindow");
     }
     unsigned long lvlWinIdx = imgForLvlWin->AddObserver(itk::ModifiedEvent(), command5);
     m_ObserverToLevelWindowImageProperty[PropDataPair(lvlWinIdx, node)] = node->GetProperty("imageForLevelWindow");
 
     auto command6 = itk::ReceptorMemberCommand<LevelWindowManager>::New();
     command6->SetCallbackFunction(this, &LevelWindowManager::UpdateSelected);
     BaseProperty::Pointer selectedDataNode = node->GetProperty("selected");
     if (selectedDataNode.IsNull())
     {
       node->SetBoolProperty("selected", false);
       selectedDataNode = node->GetProperty("selected");
     }
     unsigned long selectedIdx = selectedDataNode->AddObserver(itk::ModifiedEvent(), command5);
     m_ObserverToSelectedProperty[PropDataPair(selectedIdx, node)] = node->GetProperty("selected");
   }
 }
 
 bool mitk::LevelWindowManager::HasLevelWindowRenderingMode(DataNode *dataNode)
 {
   RenderingModeProperty::Pointer mode =
     dynamic_cast<RenderingModeProperty*>(dataNode->GetProperty("Image Rendering.Mode"));
 
   if (mode.IsNotNull())
   {
     int currMode = mode->GetRenderingMode();
     if (currMode == RenderingModeProperty::LOOKUPTABLE_LEVELWINDOW_COLOR ||
         currMode == RenderingModeProperty::COLORTRANSFERFUNCTION_LEVELWINDOW_COLOR)
     {
       return true;
     }
   }
 
   return false;
 }