diff --git a/Modules/Segmentation/Interactions/mitkPickingTool.cpp b/Modules/Segmentation/Interactions/mitkPickingTool.cpp
index e2bfed1ca1..207de88634 100644
--- a/Modules/Segmentation/Interactions/mitkPickingTool.cpp
+++ b/Modules/Segmentation/Interactions/mitkPickingTool.cpp
@@ -1,269 +1,220 @@
 /*============================================================================
 
 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 "mitkPickingTool.h"
 
 #include "mitkProperties.h"
 #include "mitkToolManager.h"
 
+#include "mitkInteractionPositionEvent.h"
 // us
 #include <usGetModuleContext.h>
 #include <usModule.h>
 #include <usModuleContext.h>
 #include <usModuleResource.h>
 
 #include "mitkITKImageImport.h"
 #include "mitkImageAccessByItk.h"
 #include "mitkImageCast.h"
 #include "mitkImageTimeSelector.h"
 #include "mitkImageTimeSelector.h"
 
+#include <itkImage.h>
 #include <itkConnectedThresholdImageFilter.h>
 
 #include <mitkLabelSetImage.h>
 
 namespace mitk
 {
   MITK_TOOL_MACRO(MITKSEGMENTATION_EXPORT, PickingTool, "PickingTool");
 }
 
-mitk::PickingTool::PickingTool() : m_WorkingData(nullptr)
+mitk::PickingTool::PickingTool() : AutoSegmentationWithPreviewTool(false, "PressMoveReleaseAndPointSetting")
 {
-  m_PointSetNode = mitk::DataNode::New();
-  m_PointSetNode->GetPropertyList()->SetProperty("name", mitk::StringProperty::New("Picking_Seedpoint"));
-  m_PointSetNode->GetPropertyList()->SetProperty("helper object", mitk::BoolProperty::New(true));
-  m_PointSet = mitk::PointSet::New();
-  m_PointSetNode->SetData(m_PointSet);
-
-  // Watch for point added or modified
-  itk::SimpleMemberCommand<PickingTool>::Pointer pointAddedCommand = itk::SimpleMemberCommand<PickingTool>::New();
-  pointAddedCommand->SetCallbackFunction(this, &mitk::PickingTool::OnPointAdded);
-  m_PointSetAddObserverTag = m_PointSet->AddObserver(mitk::PointSetAddEvent(), pointAddedCommand);
-
-  // create new node for picked region
-  m_ResultNode = mitk::DataNode::New();
-  // set some properties
-  m_ResultNode->SetProperty("name", mitk::StringProperty::New("result"));
-  m_ResultNode->SetProperty("helper object", mitk::BoolProperty::New(true));
-  m_ResultNode->SetProperty("color", mitk::ColorProperty::New(0, 1, 0));
-  m_ResultNode->SetProperty("layer", mitk::IntProperty::New(1));
-  m_ResultNode->SetProperty("opacity", mitk::FloatProperty::New(0.33f));
 }
 
 mitk::PickingTool::~PickingTool()
 {
-  m_PointSet->RemoveObserver(m_PointSetAddObserverTag);
 }
 
 bool mitk::PickingTool::CanHandle(const BaseData* referenceData, const BaseData* workingData) const
 {
   if (!Superclass::CanHandle(referenceData,workingData))
     return false;
 
   auto* image = dynamic_cast<const Image*>(referenceData);
 
   if (image == nullptr)
     return false;
 
-  if (image->GetTimeSteps() > 1) //release quickfix for T28248
-    return false;
-
   return true;
 }
 
 const char **mitk::PickingTool::GetXPM() const
 {
   return nullptr;
 }
 
 const char *mitk::PickingTool::GetName() const
 {
   return "Picking";
 }
 
 us::ModuleResource mitk::PickingTool::GetIconResource() const
 {
   us::Module *module = us::GetModuleContext()->GetModule();
   us::ModuleResource resource = module->GetResource("Pick_48x48.png");
   return resource;
 }
 
 void mitk::PickingTool::Activated()
 {
   Superclass::Activated();
 
-  DataStorage *dataStorage = this->GetDataStorage();
-  m_WorkingData = this->GetWorkingData();
-
-  // add to datastorage and enable interaction
-  if (!dataStorage->Exists(m_PointSetNode))
-    dataStorage->Add(m_PointSetNode, m_WorkingData);
+  m_PointSet = mitk::PointSet::New();
+  //ensure that the seed points are visible for all timepoints.
+  dynamic_cast<ProportionalTimeGeometry*>(m_PointSet->GetTimeGeometry())->SetStepDuration(std::numeric_limits<TimePointType>::max());
 
-  m_SeedPointInteractor = mitk::SinglePointDataInteractor::New();
-  m_SeedPointInteractor->LoadStateMachine("PointSet.xml");
-  m_SeedPointInteractor->SetEventConfig("PointSetConfig.xml");
-  m_SeedPointInteractor->SetDataNode(m_PointSetNode);
+  m_PointSetNode = mitk::DataNode::New();
+  m_PointSetNode->SetData(m_PointSet);
+  m_PointSetNode->SetName(std::string(this->GetName()) + "_PointSet");
+  m_PointSetNode->SetBoolProperty("helper object", true);
+  m_PointSetNode->SetColor(0.0, 1.0, 0.0);
+  m_PointSetNode->SetVisibility(true);
 
-  // now add result to data tree
-  dataStorage->Add(m_ResultNode, m_WorkingData);
+  this->GetDataStorage()->Add(m_PointSetNode, this->GetToolManager()->GetWorkingData(0));
 }
 
 void mitk::PickingTool::Deactivated()
 {
-  m_PointSet->Clear();
+  this->ClearSeeds();
+
   // remove from data storage and disable interaction
   GetDataStorage()->Remove(m_PointSetNode);
-  GetDataStorage()->Remove(m_ResultNode);
+  m_PointSetNode = nullptr;
+  m_PointSet = nullptr;
 
   Superclass::Deactivated();
 }
 
-mitk::DataNode *mitk::PickingTool::GetReferenceData()
+void mitk::PickingTool::ConnectActionsAndFunctions()
 {
-  return this->m_ToolManager->GetReferenceData(0);
+  CONNECT_FUNCTION("ShiftSecondaryButtonPressed", OnAddPoint);
+  CONNECT_FUNCTION("ShiftPrimaryButtonPressed", OnAddPoint);
+  CONNECT_FUNCTION("DeletePoint", OnDelete);
 }
 
-mitk::DataStorage *mitk::PickingTool::GetDataStorage()
+void mitk::PickingTool::OnAddPoint(StateMachineAction*, InteractionEvent* interactionEvent)
 {
-  return this->m_ToolManager->GetDataStorage();
-}
+  if (!this->IsUpdating() && m_PointSet.IsNotNull())
+  {
+    const auto positionEvent = dynamic_cast<mitk::InteractionPositionEvent*>(interactionEvent);
 
-mitk::DataNode *mitk::PickingTool::GetWorkingData()
-{
-  return this->m_ToolManager->GetWorkingData(0);
-}
+    if (positionEvent != nullptr)
+    {
+      auto workingPlaneGeometry = positionEvent->GetSender()->GetCurrentWorldPlaneGeometry();
 
-mitk::DataNode::Pointer mitk::PickingTool::GetPointSetNode()
-{
-  return m_PointSetNode;
+      m_PointSet->InsertPoint(m_PointSet->GetSize(), positionEvent->GetPositionInWorld());
+
+      mitk::RenderingManager::GetInstance()->RequestUpdateAll();
+
+      this->UpdatePreview();
+    }
+  }
 }
 
-void mitk::PickingTool::OnPointAdded()
+void mitk::PickingTool::OnDelete(StateMachineAction*, InteractionEvent* /*interactionEvent*/)
 {
-  if (m_WorkingData != this->GetWorkingData())
+  if (!this->IsUpdating() && m_PointSet.IsNotNull())
   {
-    DataStorage *dataStorage = this->GetDataStorage();
-
-    if (dataStorage->Exists(m_PointSetNode))
+    // delete last seed point
+    if (this->m_PointSet->GetSize() > 0)
     {
-      dataStorage->Remove(m_PointSetNode);
-      dataStorage->Add(m_PointSetNode, this->GetWorkingData());
-    }
+      m_PointSet->RemovePointAtEnd(0);
 
-    if (dataStorage->Exists(m_ResultNode))
-    {
-      dataStorage->Remove(m_ResultNode);
-      dataStorage->Add(m_ResultNode, this->GetWorkingData());
-    }
+      mitk::RenderingManager::GetInstance()->RequestUpdateAll();
 
-    m_WorkingData = this->GetWorkingData();
+      this->UpdatePreview();
+    }
   }
+}
 
-  // Perform region growing/picking
-
-  int timeStep =
-    mitk::BaseRenderer::GetInstance(mitk::BaseRenderer::GetRenderWindowByName("stdmulti.widget0"))->GetTimeStep();
-
-  mitk::PointSet::PointType seedPoint = m_PointSet->GetPointSet(timeStep)->GetPoints()->Begin().Value();
-
-  // as we want to pick a region from our segmentation image use the working data from ToolManager
-  mitk::Image::Pointer orgImage = dynamic_cast<mitk::Image *>(m_ToolManager->GetWorkingData(0)->GetData());
+void mitk::PickingTool::ClearPicks()
+{
+  this->ClearSeeds();
+  mitk::RenderingManager::GetInstance()->RequestUpdateAll();
+  this->UpdatePreview();
+}
 
-  if (orgImage.IsNotNull())
+void mitk::PickingTool::ClearSeeds()
+{
+  if (this->m_PointSet.IsNotNull())
   {
-    if (orgImage->GetDimension() == 4)
-    { // there may be 4D segmentation data even though we currently don't support that
-      mitk::ImageTimeSelector::Pointer timeSelector = mitk::ImageTimeSelector::New();
-      timeSelector->SetInput(orgImage);
-      timeSelector->SetTimeNr(timeStep);
-      timeSelector->UpdateLargestPossibleRegion();
-      mitk::Image *timedImage = timeSelector->GetOutput();
-
-      AccessByItk_2(timedImage, StartRegionGrowing, timedImage->GetGeometry(), seedPoint);
-    }
-    else if (orgImage->GetDimension() == 3)
-    {
-      AccessByItk_2(orgImage, StartRegionGrowing, orgImage->GetGeometry(), seedPoint);
-    }
-    this->m_PointSet->Clear();
+    // renew pointset
+    this->m_PointSet = mitk::PointSet::New();
+    //ensure that the seed points are visible for all timepoints.
+    dynamic_cast<ProportionalTimeGeometry*>(m_PointSet->GetTimeGeometry())->SetStepDuration(std::numeric_limits<TimePointType>::max());
+    this->m_PointSetNode->SetData(this->m_PointSet);
   }
 }
 
 template <typename TPixel, unsigned int VImageDimension>
-void mitk::PickingTool::StartRegionGrowing(itk::Image<TPixel, VImageDimension> *itkImage,
-                                           mitk::BaseGeometry *imageGeometry,
-                                           mitk::PointSet::PointType seedPoint)
+void DoITKRegionGrowing(const itk::Image<TPixel, VImageDimension>* oldSegImage,
+  mitk::Image* segmentation,
+  const mitk::PointSet* seedPoints,
+  unsigned int timeStep, const mitk::BaseGeometry* inputGeometry)
 {
   typedef itk::Image<TPixel, VImageDimension> InputImageType;
   typedef typename InputImageType::IndexType IndexType;
   typedef itk::ConnectedThresholdImageFilter<InputImageType, InputImageType> RegionGrowingFilterType;
   typename RegionGrowingFilterType::Pointer regionGrower = RegionGrowingFilterType::New();
 
   // convert world coordinates to image indices
-  IndexType seedIndex;
-  imageGeometry->WorldToIndex(seedPoint, seedIndex);
+  for (auto pos = seedPoints->Begin(); pos != seedPoints->End(); ++pos)
+  {
+    IndexType seedIndex;
+    inputGeometry->WorldToIndex(pos->Value(), seedIndex);
+    regionGrower->AddSeed(seedIndex);
+  }
 
   // perform region growing in desired segmented region
-  regionGrower->SetInput(itkImage);
-  regionGrower->AddSeed(seedIndex);
+  regionGrower->SetInput(oldSegImage);
 
   // TODO: conversion added to silence warning and
   // maintain existing behaviour, should be fixed
   // since it's not correct e.g. for signed char
   regionGrower->SetLower(static_cast<typename InputImageType::PixelType>(1));
   regionGrower->SetUpper(static_cast<typename InputImageType::PixelType>(255));
 
   try
   {
     regionGrower->Update();
   }
   catch (const itk::ExceptionObject &)
   {
     return; // can't work
   }
   catch (...)
   {
     return;
   }
 
-  // Store result and preview
-  mitk::Image::Pointer resultImage = mitk::ImportItkImage(regionGrower->GetOutput(), imageGeometry)->Clone();
-  mitk::LabelSetImage::Pointer resultLabelSetImage = mitk::LabelSetImage::New();
-  resultLabelSetImage->InitializeByLabeledImage(resultImage);
-
-  m_ResultNode->SetData(resultLabelSetImage);
-
-  mitk::RenderingManager::GetInstance()->RequestUpdateAll();
+  segmentation->SetVolume((void*)(regionGrower->GetOutput()->GetPixelContainer()->GetBufferPointer()), timeStep);
 }
 
-void mitk::PickingTool::ConfirmSegmentation()
+void mitk::PickingTool::DoUpdatePreview(const Image* /*inputAtTimeStep*/, const Image* oldSegAtTimeStep, Image* previewImage, TimeStepType timeStep)
 {
-  mitk::DataNode::Pointer newNode = mitk::DataNode::New();
-  newNode->SetProperty("name", mitk::StringProperty::New(m_WorkingData->GetName() + "_picked"));
-
-  float rgb[3] = {1.0f, 0.0f, 0.0f};
-  m_WorkingData->GetColor(rgb);
-  newNode->SetProperty("color", mitk::ColorProperty::New(rgb));
-
-  float opacity = 1.0f;
-  m_WorkingData->GetOpacity(opacity, nullptr);
-  newNode->SetProperty("opacity", mitk::FloatProperty::New(opacity));
-
-  newNode->SetData(m_ResultNode->GetData());
-
-  GetDataStorage()->Add(newNode, this->GetReferenceData());
-  m_WorkingData->SetVisibility(false);
-
-  m_ResultNode->SetData(nullptr);
-
-  mitk::RenderingManager::GetInstance()->RequestUpdateAll();
-}
+  if (nullptr != oldSegAtTimeStep && nullptr != previewImage && m_PointSet.IsNotNull())
+  {
+    AccessFixedDimensionByItk_n(oldSegAtTimeStep, DoITKRegionGrowing, 3, (previewImage, this->m_PointSet, timeStep, oldSegAtTimeStep->GetGeometry()));
+  }
+}
\ No newline at end of file
diff --git a/Modules/Segmentation/Interactions/mitkPickingTool.h b/Modules/Segmentation/Interactions/mitkPickingTool.h
index a619ecbf3d..a1254c2207 100644
--- a/Modules/Segmentation/Interactions/mitkPickingTool.h
+++ b/Modules/Segmentation/Interactions/mitkPickingTool.h
@@ -1,95 +1,83 @@
 /*============================================================================
 
 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.
 
 ============================================================================*/
 
 #ifndef mitkPickingTool_h_Included
 #define mitkPickingTool_h_Included
 
-#include "itkImage.h"
-#include "mitkAutoSegmentationTool.h"
-#include "mitkCommon.h"
-#include "mitkDataStorage.h"
+#include "mitkAutoSegmentationWithPreviewTool.h"
 #include "mitkPointSet.h"
-#include "mitkSinglePointDataInteractor.h"
+
 #include <MitkSegmentationExports.h>
 
 namespace us
 {
   class ModuleResource;
 }
 
 namespace mitk
 {
   /**
   \brief Extracts a single region from a segmentation image and creates a new image with same geometry of the input
   image.
 
   The region is extracted in 3D space. This is done by performing region growing within the desired region.
   Use shift click to add the seed point.
 
   \ingroup ToolManagerEtAl
   \sa mitk::Tool
   \sa QmitkInteractiveSegmentation
 
   */
-  class MITKSEGMENTATION_EXPORT PickingTool : public AutoSegmentationTool
+  class MITKSEGMENTATION_EXPORT PickingTool : public AutoSegmentationWithPreviewTool
   {
   public:
-    mitkClassMacro(PickingTool, AutoSegmentationTool);
+    mitkClassMacro(PickingTool, AutoSegmentationWithPreviewTool);
     itkFactorylessNewMacro(Self);
     itkCloneMacro(Self);
 
-      const char **GetXPM() const override;
+    const char **GetXPM() const override;
     const char *GetName() const override;
     us::ModuleResource GetIconResource() const override;
 
-    void Activated() override;
-    void Deactivated() override;
-
     bool CanHandle(const BaseData* referenceData, const BaseData* workingData) const override;
 
-    virtual DataNode::Pointer GetPointSetNode();
-
-    mitk::DataNode *GetReferenceData();
-    mitk::DataNode *GetWorkingData();
-    mitk::DataStorage *GetDataStorage();
+    void Activated() override;
+    void Deactivated() override;
 
-    void ConfirmSegmentation();
+    /**Clears all picks and updates the preview.*/
+    void ClearPicks();
 
   protected:
     PickingTool(); // purposely hidden
     ~PickingTool() override;
 
-    // Callback for point add event of PointSet
-    void OnPointAdded();
+    void ConnectActionsAndFunctions() override;
 
-    // Observer id
-    long m_PointSetAddObserverTag;
+    /// \brief Add point action of StateMachine pattern
+    virtual void OnAddPoint(StateMachineAction*, InteractionEvent* interactionEvent);
 
-    mitk::DataNode::Pointer m_ResultNode;
+    /// \brief Delete action of StateMachine pattern
+    virtual void OnDelete(StateMachineAction*, InteractionEvent* interactionEvent);
 
-    // itk regrowing
-    template <typename TPixel, unsigned int VImageDimension>
-    void StartRegionGrowing(itk::Image<TPixel, VImageDimension> *itkImage,
-                            mitk::BaseGeometry *imageGeometry,
-                            mitk::PointSet::PointType seedPoint);
+    /// \brief Clear all seed points.
+    void ClearSeeds();
+
+    void DoUpdatePreview(const Image* inputAtTimeStep, const Image* oldSegAtTimeStep, Image* previewImage, TimeStepType timeStep) override;
 
     // seed point
     PointSet::Pointer m_PointSet;
-    SinglePointDataInteractor::Pointer m_SeedPointInteractor;
     DataNode::Pointer m_PointSetNode;
-
-    DataNode *m_WorkingData;
   };
 
 } // namespace
 
 #endif
diff --git a/Modules/Segmentation/Resources/Interactions/PickingTool.xml b/Modules/Segmentation/Resources/Interactions/PickingTool.xml
new file mode 100644
index 0000000000..1baf80a04b
--- /dev/null
+++ b/Modules/Segmentation/Resources/Interactions/PickingTool.xml
@@ -0,0 +1,19 @@
+<statemachine name="FastMarchingTool">
+
+  <state name="neutral" ID="1" startstate="TRUE">
+  
+    <transition event_class="MousePressEvent" event_variant="ShiftPrimaryButtonPressed" name="Shift+press" target="neutral" EVENT_ID="3">
+      <action name="ShiftPrimaryButtonPressed" ID="10" />
+    </transition>
+    
+    <transition event_class="MousePressEvent" event_variant="ShiftSecondaryButtonPressed" name="Shift+pressRMB" target="neutral" EVENT_ID="2000">
+      <action name="ShiftSecondaryButtonPressed" ID="6000" />
+    </transition>
+    
+    <transition event_class="InteractionKeyEvent" event_variant="KeyDelete" name="ENTF" target="neutral" EVENT_ID="12">
+      <action name="DeletePoint" ID="100" />
+    </transition>
+    
+  </state>
+  
+</statemachine>
\ No newline at end of file
diff --git a/Modules/Segmentation/files.cmake b/Modules/Segmentation/files.cmake
index 68d22a6ccc..cb3c19d915 100644
--- a/Modules/Segmentation/files.cmake
+++ b/Modules/Segmentation/files.cmake
@@ -1,116 +1,117 @@
 set(CPP_FILES
   Algorithms/mitkCalculateSegmentationVolume.cpp
   Algorithms/mitkContourModelSetToImageFilter.cpp
   Algorithms/mitkContourSetToPointSetFilter.cpp
   Algorithms/mitkContourUtils.cpp
   Algorithms/mitkCorrectorAlgorithm.cpp
   Algorithms/mitkDiffImageApplier.cpp
   Algorithms/mitkDiffSliceOperation.cpp
   Algorithms/mitkDiffSliceOperationApplier.cpp
   Algorithms/mitkFeatureBasedEdgeDetectionFilter.cpp
   Algorithms/mitkImageLiveWireContourModelFilter.cpp
   Algorithms/mitkImageToContourFilter.cpp
   #Algorithms/mitkImageToContourModelFilter.cpp
   Algorithms/mitkImageToLiveWireContourFilter.cpp
   Algorithms/mitkManualSegmentationToSurfaceFilter.cpp
   Algorithms/mitkOtsuSegmentationFilter.cpp
   Algorithms/mitkOverwriteDirectedPlaneImageFilter.cpp
   Algorithms/mitkOverwriteSliceImageFilter.cpp
   Algorithms/mitkSegmentationObjectFactory.cpp
   Algorithms/mitkShapeBasedInterpolationAlgorithm.cpp
   Algorithms/mitkShowSegmentationAsSmoothedSurface.cpp
   Algorithms/mitkShowSegmentationAsSurface.cpp
   Algorithms/mitkVtkImageOverwrite.cpp
   Controllers/mitkSegmentationInterpolationController.cpp
   Controllers/mitkToolManager.cpp
   Controllers/mitkSegmentationModuleActivator.cpp
   Controllers/mitkToolManagerProvider.cpp
   DataManagement/mitkContour.cpp
   DataManagement/mitkContourSet.cpp
   DataManagement/mitkExtrudedContour.cpp
   Interactions/mitkAdaptiveRegionGrowingTool.cpp
   Interactions/mitkAddContourTool.cpp
   Interactions/mitkAutoCropTool.cpp
   Interactions/mitkAutoSegmentationTool.cpp
   Interactions/mitkAutoSegmentationWithPreviewTool.cpp
   Interactions/mitkAutoMLSegmentationWithPreviewTool.cpp
   Interactions/mitkBinaryThresholdBaseTool.cpp
   Interactions/mitkBinaryThresholdTool.cpp
   Interactions/mitkBinaryThresholdULTool.cpp
   Interactions/mitkCalculateGrayValueStatisticsTool.cpp
   Interactions/mitkCalculateVolumetryTool.cpp
   Interactions/mitkContourModelInteractor.cpp
   Interactions/mitkContourModelLiveWireInteractor.cpp
   Interactions/mitkLiveWireTool2D.cpp
   Interactions/mitkContourTool.cpp
   Interactions/mitkCreateSurfaceTool.cpp
   Interactions/mitkDrawPaintbrushTool.cpp
   Interactions/mitkErasePaintbrushTool.cpp
   Interactions/mitkEraseRegionTool.cpp
   Interactions/mitkFastMarchingBaseTool.cpp
   Interactions/mitkFastMarchingTool.cpp
   Interactions/mitkFastMarchingTool3D.cpp
   Interactions/mitkFeedbackContourTool.cpp
   Interactions/mitkFillRegionTool.cpp
   Interactions/mitkOtsuTool3D.cpp
   Interactions/mitkPaintbrushTool.cpp
   Interactions/mitkPixelManipulationTool.cpp
   Interactions/mitkRegionGrowingTool.cpp
   Interactions/mitkSegmentationsProcessingTool.cpp
   Interactions/mitkSetRegionTool.cpp
   Interactions/mitkSegTool2D.cpp
   Interactions/mitkSubtractContourTool.cpp
   Interactions/mitkTool.cpp
   Interactions/mitkToolCommand.cpp
   Interactions/mitkWatershedTool.cpp
   Interactions/mitkPickingTool.cpp
   Interactions/mitkSegmentationInteractor.cpp #SO
   Rendering/mitkContourMapper2D.cpp
   Rendering/mitkContourSetMapper2D.cpp
   Rendering/mitkContourSetVtkMapper3D.cpp
   Rendering/mitkContourVtkMapper3D.cpp
   SegmentationUtilities/BooleanOperations/mitkBooleanOperation.cpp
   SegmentationUtilities/MorphologicalOperations/mitkMorphologicalOperations.cpp
 #Added from ML
   Controllers/mitkSliceBasedInterpolationController.cpp
   Algorithms/mitkSurfaceStampImageFilter.cpp
 )
 
 set(RESOURCE_FILES
   Add_48x48.png
   Add_Cursor_32x32.png
   Erase_48x48.png
   Erase_Cursor_32x32.png
   FastMarching_48x48.png
   FastMarching_Cursor_32x32.png
   Fill_48x48.png
   Fill_Cursor_32x32.png
   LiveWire_48x48.png
   LiveWire_Cursor_32x32.png
   Otsu_48x48.png
   Paint_48x48.png
   Paint_Cursor_32x32.png
   Pick_48x48.png
   RegionGrowing_48x48.png
   RegionGrowing_Cursor_32x32.png
   Subtract_48x48.png
   Subtract_Cursor_32x32.png
   Threshold_48x48.png
   TwoThresholds_48x48.png
   Watershed_48x48.png
   Watershed_Cursor_32x32.png
   Wipe_48x48.png
   Wipe_Cursor_32x32.png
 
   Interactions/dummy.xml
   Interactions/LiveWireTool.xml
   Interactions/FastMarchingTool.xml
+  Interactions/PickingTool.xml
   Interactions/PressMoveRelease.xml
   Interactions/PressMoveReleaseAndPointSetting.xml
   Interactions/PressMoveReleaseWithCTRLInversion.xml
   Interactions/PressMoveReleaseWithCTRLInversionAllMouseMoves.xml
   Interactions/SegmentationToolsConfig.xml
 
   Interactions/ContourModelModificationConfig.xml
   Interactions/ContourModelModificationInteractor.xml
 )
diff --git a/Modules/SegmentationUI/Qmitk/QmitkAutoSegmentationToolGUIBase.h b/Modules/SegmentationUI/Qmitk/QmitkAutoSegmentationToolGUIBase.h
index 6501a2e1b5..2c6eddf881 100644
--- a/Modules/SegmentationUI/Qmitk/QmitkAutoSegmentationToolGUIBase.h
+++ b/Modules/SegmentationUI/Qmitk/QmitkAutoSegmentationToolGUIBase.h
@@ -1,81 +1,93 @@
 /*============================================================================
 
 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.
 
 ============================================================================*/
 
 #ifndef QmitkAutoSegmentationToolGUIBase_h_Included
 #define QmitkAutoSegmentationToolGUIBase_h_Included
 
 #include "QmitkToolGUI.h"
 
 #include "mitkAutoSegmentationWithPreviewTool.h"
 
 #include <MitkSegmentationUIExports.h>
 
 class QCheckBox;
 class QPushButton;
 class QBoxLayout;
 
 /**
   \ingroup org_mitk_gui_qt_interactivesegmentation_internal
   \brief GUI base clase for tools derived from mitk::AutoSegmentationTool.
 */
 class MITKSEGMENTATIONUI_EXPORT QmitkAutoSegmentationToolGUIBase : public QmitkToolGUI
 {
   Q_OBJECT
 
 public:
   mitkClassMacro(QmitkAutoSegmentationToolGUIBase, QmitkToolGUI);
   itkCloneMacro(Self);
 
   itkGetConstMacro(Mode2D, bool);
 
 protected slots:
 
   void OnNewToolAssociated(mitk::Tool *);
 
   void OnAcceptPreview();
 
 protected:
   QmitkAutoSegmentationToolGUIBase(bool mode2D);
   ~QmitkAutoSegmentationToolGUIBase() override;
 
   virtual void DisconnectOldTool(mitk::AutoSegmentationWithPreviewTool* oldTool);
   virtual void ConnectNewTool(mitk::AutoSegmentationWithPreviewTool* newTool);
+
+  /**This method is called by OnNewToolAssociated if the UI is initialized the
+   first time to allow derived classes to introduce own UI code. Overwrite to change.
+   The implementation should ensure that alle widgets needed for the tool UI are
+   properly allocated. If one needs to eecute time (e.g. to connect events between the tool
+   and the UI) each time the tool changes, override the functions ConnectNewTool() and
+   DisconnectOldTool().*/
   virtual void InitializeUI(QBoxLayout* mainLayout);
 
   void BusyStateChanged(bool isBusy) override;
 
   using EnableConfirmSegBtnFunctionType = std::function<bool(bool)>;
   EnableConfirmSegBtnFunctionType m_EnableConfirmSegBtnFnc;
 
+  /**This method is used to control/set the enabled state of the tool UI
+    widgets. It is e.g. used if the busy state is changed (see BusyStateChanged).
+    Override the default implmentation, e.g. if a tool adds his own UI elements
+    (normally by overriding InitializeUI()) and wants to control how the widgets
+    are enabled/disabled.*/
   virtual void EnableWidgets(bool enabled);
 
   template <class TTool>
   TTool* GetConnectedToolAs()
   {
     return dynamic_cast<TTool*>(m_Tool.GetPointer());
   };
 
 
 
 private:
   QCheckBox* m_CheckProcessAll = nullptr;
   QCheckBox* m_CheckCreateNew = nullptr;
   QPushButton* m_ConfirmSegBtn = nullptr;
   QBoxLayout* m_MainLayout = nullptr;
 
   /**Indicates if the tool is in 2D or 3D mode.*/
   bool m_Mode2D;
 
   mitk::AutoSegmentationWithPreviewTool::Pointer m_Tool;
 };
 
 #endif
diff --git a/Modules/SegmentationUI/Qmitk/QmitkOtsuTool3DGUI.h b/Modules/SegmentationUI/Qmitk/QmitkOtsuTool3DGUI.h
index f9d87fd615..55b7030ea5 100644
--- a/Modules/SegmentationUI/Qmitk/QmitkOtsuTool3DGUI.h
+++ b/Modules/SegmentationUI/Qmitk/QmitkOtsuTool3DGUI.h
@@ -1,64 +1,64 @@
 /*============================================================================
 
 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.
 
 ============================================================================*/
 
 #ifndef QmitkOtsuTool3DGUI_h_Included
 #define QmitkOtsuTool3DGUI_h_Included
 
 #include "QmitkAutoMLSegmentationToolGUIBase.h"
 
 #include "ui_QmitkOtsuToolWidgetControls.h"
 
 #include <MitkSegmentationUIExports.h>
 
 /**
   \ingroup org_mitk_gui_qt_interactivesegmentation_internal
-  \brief GUI for mitk::.
+  \brief GUI for mitk::OtsuTool3D.
   \sa mitk::
 
   This GUI shows ...
 
   Last contributor: $Author$
 */
 class MITKSEGMENTATIONUI_EXPORT QmitkOtsuTool3DGUI : public QmitkAutoMLSegmentationToolGUIBase
 {
   Q_OBJECT
 
 public:
   mitkClassMacro(QmitkOtsuTool3DGUI, QmitkAutoMLSegmentationToolGUIBase);
   itkFactorylessNewMacro(Self);
   itkCloneMacro(Self);
 
 protected slots :
 
   void OnPreviewBtnClicked();
 
   void OnRegionSpinboxChanged(int);
 
 private slots:
 
   void OnAdvancedSettingsButtonToggled(bool toggled);
 
 protected:
   QmitkOtsuTool3DGUI();
   ~QmitkOtsuTool3DGUI() = default;
 
   void ConnectNewTool(mitk::AutoSegmentationWithPreviewTool* newTool) override;
   void InitializeUI(QBoxLayout* mainLayout) override;
 
   void EnableWidgets(bool enabled) override;
 
   Ui_QmitkOtsuToolWidgetControls m_Controls;
 
   bool m_FirstPreviewComputation = true;
 };
 
 #endif
diff --git a/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.cpp b/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.cpp
index be695b9ae5..17e5fea371 100644
--- a/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.cpp
+++ b/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.cpp
@@ -1,51 +1,61 @@
 /*============================================================================
 
 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 "QmitkPickingToolGUI.h"
 
-#include "QmitkNewSegmentationDialog.h"
-
-#include "mitkBaseRenderer.h"
-#include "mitkStepper.h"
+#include <mitkPickingTool.h>
 #include <qlabel.h>
-#include <qlayout.h>
-#include <qpainter.h>
 #include <qpushbutton.h>
-#include <qslider.h>
+#include <qboxlayout.h>
 
 MITK_TOOL_GUI_MACRO(MITKSEGMENTATIONUI_EXPORT, QmitkPickingToolGUI, "")
 
-QmitkPickingToolGUI::QmitkPickingToolGUI() : QmitkToolGUI()
+QmitkPickingToolGUI::QmitkPickingToolGUI() : QmitkAutoSegmentationToolGUIBase(false)
 {
-  m_Controls.setupUi(this);
-
-  connect(m_Controls.m_ConfirmButton, SIGNAL(clicked()), this, SLOT(OnConfirmSegmentation()));
-
-  connect(this, SIGNAL(NewToolAssociated(mitk::Tool *)), this, SLOT(OnNewToolAssociated(mitk::Tool *)));
 }
 
 QmitkPickingToolGUI::~QmitkPickingToolGUI()
 {
 }
 
-void QmitkPickingToolGUI::OnNewToolAssociated(mitk::Tool *tool)
+void QmitkPickingToolGUI::OnResetPicksClicked()
+{
+  auto tool = this->GetConnectedToolAs<mitk::PickingTool>();
+  if (nullptr != tool)
+  {
+    tool->ClearPicks();
+  }
+}
+
+void QmitkPickingToolGUI::InitializeUI(QBoxLayout* mainLayout)
 {
-  m_PickingTool = dynamic_cast<mitk::PickingTool *>(tool);
+  QLabel* label = new QLabel("Press SHIFT and click to pick region(s).\nPress DEL to remove last pick.", this);
+  mainLayout->addWidget(label);
+
+  auto clearButton = new QPushButton("Reset picks",this);
+  connect(clearButton, &QPushButton::clicked, this, &QmitkPickingToolGUI::OnResetPicksClicked);
+  mainLayout->addWidget(clearButton);
+  m_ClearPicksBtn = clearButton;
+
+  Superclass::InitializeUI(mainLayout);
 }
 
-void QmitkPickingToolGUI::OnConfirmSegmentation()
+void QmitkPickingToolGUI::EnableWidgets(bool enabled)
 {
-  if (m_PickingTool.IsNotNull())
+  Superclass::EnableWidgets(enabled);
+
+  if (nullptr != m_ClearPicksBtn)
   {
-    m_PickingTool->ConfirmSegmentation();
+    m_ClearPicksBtn->setEnabled(enabled);
   }
 }
+
diff --git a/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.h b/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.h
index bf8a3b78b5..0a1c65aecb 100644
--- a/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.h
+++ b/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUI.h
@@ -1,60 +1,47 @@
 /*============================================================================
 
 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.
 
 ============================================================================*/
 
 #ifndef QmitkPickingToolGUI_h_Included
 #define QmitkPickingToolGUI_h_Included
 
-#include "QmitkToolGUI.h"
-#include "mitkPickingTool.h"
-#include "ui_QmitkPickingToolGUIControls.h"
+#include "QmitkAutoSegmentationToolGUIBase.h"
 #include <MitkSegmentationUIExports.h>
 
-class QSlider;
-class QLabel;
-class QFrame;
-class QPushButton;
-#include <QCheckBox>
-
-#include "QmitkStepperAdapter.h"
-
-class QmitkPickingToolGUIControls;
-
 /**
 \ingroup org_mitk_gui_qt_interactivesegmentation_internal
-\brief GUI for mitk::LiveWireTool.
+\brief GUI for mitk::PickingTool.
 \sa mitk::PickingTool
 */
-class MITKSEGMENTATIONUI_EXPORT QmitkPickingToolGUI : public QmitkToolGUI
+class MITKSEGMENTATIONUI_EXPORT QmitkPickingToolGUI : public QmitkAutoSegmentationToolGUIBase
 {
   Q_OBJECT
 
 public:
-  mitkClassMacro(QmitkPickingToolGUI, QmitkToolGUI);
+  mitkClassMacro(QmitkPickingToolGUI, QmitkAutoSegmentationToolGUIBase);
   itkFactorylessNewMacro(Self);
   itkCloneMacro(Self);
 
-    protected slots :
-
-    void OnNewToolAssociated(mitk::Tool *);
-
-  void OnConfirmSegmentation();
+protected slots :
+  void OnResetPicksClicked();
 
 protected:
   QmitkPickingToolGUI();
   ~QmitkPickingToolGUI() override;
 
-  Ui::QmitkPickingToolGUIControls m_Controls;
+  void InitializeUI(QBoxLayout* mainLayout) override;
+  void EnableWidgets(bool enabled) override;
 
-  mitk::PickingTool::Pointer m_PickingTool;
+private:
+  QWidget* m_ClearPicksBtn = nullptr;
 };
 
 #endif
diff --git a/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUIControls.ui b/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUIControls.ui
deleted file mode 100644
index 02979d04cf..0000000000
--- a/Modules/SegmentationUI/Qmitk/QmitkPickingToolGUIControls.ui
+++ /dev/null
@@ -1,93 +0,0 @@
-<?xml version="1.0" encoding="UTF-8"?>
-<ui version="4.0">
- <class>QmitkPickingToolGUIControls</class>
- <widget class="QWidget" name="QmitkPickingToolGUIControls">
-  <property name="geometry">
-   <rect>
-    <x>0</x>
-    <y>0</y>
-    <width>421</width>
-    <height>263</height>
-   </rect>
-  </property>
-  <property name="sizePolicy">
-   <sizepolicy hsizetype="Ignored" vsizetype="Minimum">
-    <horstretch>0</horstretch>
-    <verstretch>0</verstretch>
-   </sizepolicy>
-  </property>
-  <property name="minimumSize">
-   <size>
-    <width>0</width>
-    <height>0</height>
-   </size>
-  </property>
-  <property name="windowTitle">
-   <string>QmitkPickingToolGUIControls</string>
-  </property>
-  <property name="toolTip">
-   <string>Confirm all previous contour.</string>
-  </property>
-  <layout class="QVBoxLayout" name="verticalLayout">
-   <property name="margin">
-    <number>0</number>
-   </property>
-   <item>
-    <layout class="QVBoxLayout" name="verticalLayout_2">
-     <item>
-      <widget class="QLabel" name="label">
-       <property name="maximumSize">
-        <size>
-         <width>16777215</width>
-         <height>20</height>
-        </size>
-       </property>
-       <property name="text">
-        <string>Use shift click to pick a single</string>
-       </property>
-      </widget>
-     </item>
-     <item>
-      <widget class="QLabel" name="label_2">
-       <property name="maximumSize">
-        <size>
-         <width>16777215</width>
-         <height>20</height>
-        </size>
-       </property>
-       <property name="text">
-        <string>region from the segmentation image.</string>
-       </property>
-      </widget>
-     </item>
-     <item>
-      <spacer name="verticalSpacer_2">
-       <property name="orientation">
-        <enum>Qt::Vertical</enum>
-       </property>
-       <property name="sizeType">
-        <enum>QSizePolicy::Fixed</enum>
-       </property>
-       <property name="sizeHint" stdset="0">
-        <size>
-         <width>20</width>
-         <height>15</height>
-        </size>
-       </property>
-      </spacer>
-     </item>
-     <item>
-      <widget class="QPushButton" name="m_ConfirmButton">
-       <property name="text">
-        <string>Confirm picked region</string>
-       </property>
-      </widget>
-     </item>
-    </layout>
-   </item>
-  </layout>
- </widget>
- <layoutdefault spacing="6" margin="11"/>
- <resources/>
- <connections/>
-</ui>
diff --git a/Modules/SegmentationUI/files.cmake b/Modules/SegmentationUI/files.cmake
index fb35d7707a..e71eb77792 100644
--- a/Modules/SegmentationUI/files.cmake
+++ b/Modules/SegmentationUI/files.cmake
@@ -1,91 +1,90 @@
 set( CPP_FILES
 Qmitk/QmitkAdaptiveRegionGrowingToolGUI.cpp
 Qmitk/QmitkAutoSegmentationToolGUIBase.cpp
 Qmitk/QmitkAutoMLSegmentationToolGUIBase.cpp
 Qmitk/QmitkBinaryThresholdToolGUIBase.cpp
 Qmitk/QmitkBinaryThresholdToolGUI.cpp
 Qmitk/QmitkBinaryThresholdULToolGUI.cpp
 Qmitk/QmitkCalculateGrayValueStatisticsToolGUI.cpp
 Qmitk/QmitkConfirmSegmentationDialog.cpp
 Qmitk/QmitkCopyToClipBoardDialog.cpp
 Qmitk/QmitkDrawPaintbrushToolGUI.cpp
 Qmitk/QmitkErasePaintbrushToolGUI.cpp
 Qmitk/QmitkFastMarchingToolGUIBase.cpp
 Qmitk/QmitkFastMarchingTool3DGUI.cpp
 Qmitk/QmitkFastMarchingToolGUI.cpp
 Qmitk/QmitkLiveWireTool2DGUI.cpp
 Qmitk/QmitkNewSegmentationDialog.cpp
 Qmitk/QmitkOtsuTool3DGUI.cpp
 Qmitk/QmitkPaintbrushToolGUI.cpp
 Qmitk/QmitkPickingToolGUI.cpp
 Qmitk/QmitkPixelManipulationToolGUI.cpp
 Qmitk/QmitkSlicesInterpolator.cpp
 Qmitk/QmitkToolGUI.cpp
 Qmitk/QmitkToolGUIArea.cpp
 Qmitk/QmitkToolSelectionBox.cpp
 Qmitk/QmitkWatershedToolGUI.cpp
 #Added from ML
 Qmitk/QmitkLabelSetWidget.cpp
 Qmitk/QmitkSurfaceStampWidget.cpp
 Qmitk/QmitkMaskStampWidget.cpp
 Qmitk/QmitkSliceBasedInterpolatorWidget.cpp
 Qmitk/QmitkSurfaceBasedInterpolatorWidget.cpp
 Qmitk/QmitkSearchLabelDialog.cpp
 Qmitk/QmitkSimpleLabelSetListWidget.cpp
 )
 
 set(MOC_H_FILES
 Qmitk/QmitkAdaptiveRegionGrowingToolGUI.h
 Qmitk/QmitkAutoSegmentationToolGUIBase.h
 Qmitk/QmitkAutoMLSegmentationToolGUIBase.h
 Qmitk/QmitkBinaryThresholdToolGUIBase.h
 Qmitk/QmitkBinaryThresholdToolGUI.h
 Qmitk/QmitkBinaryThresholdULToolGUI.h
 Qmitk/QmitkCalculateGrayValueStatisticsToolGUI.h
 Qmitk/QmitkConfirmSegmentationDialog.h
 Qmitk/QmitkCopyToClipBoardDialog.h
 Qmitk/QmitkDrawPaintbrushToolGUI.h
 Qmitk/QmitkErasePaintbrushToolGUI.h
 Qmitk/QmitkFastMarchingToolGUIBase.h
 Qmitk/QmitkFastMarchingTool3DGUI.h
 Qmitk/QmitkFastMarchingToolGUI.h
 Qmitk/QmitkLiveWireTool2DGUI.h
 Qmitk/QmitkNewSegmentationDialog.h
 Qmitk/QmitkOtsuTool3DGUI.h
 Qmitk/QmitkPaintbrushToolGUI.h
 Qmitk/QmitkPickingToolGUI.h
 Qmitk/QmitkPixelManipulationToolGUI.h
 Qmitk/QmitkSlicesInterpolator.h
 Qmitk/QmitkToolGUI.h
 Qmitk/QmitkToolGUIArea.h
 Qmitk/QmitkToolSelectionBox.h
 Qmitk/QmitkWatershedToolGUI.h
 #Added from ML
 Qmitk/QmitkLabelSetWidget.h
 Qmitk/QmitkSurfaceStampWidget.h
 Qmitk/QmitkMaskStampWidget.h
 Qmitk/QmitkSliceBasedInterpolatorWidget.h
 Qmitk/QmitkSurfaceBasedInterpolatorWidget.h
 Qmitk/QmitkSearchLabelDialog.h
 Qmitk/QmitkSimpleLabelSetListWidget.h
 )
 
 set(UI_FILES
 Qmitk/QmitkAdaptiveRegionGrowingToolGUIControls.ui
 Qmitk/QmitkConfirmSegmentationDialog.ui
 Qmitk/QmitkOtsuToolWidgetControls.ui
-Qmitk/QmitkPickingToolGUIControls.ui
 Qmitk/QmitkLiveWireTool2DGUIControls.ui
 Qmitk/QmitkWatershedToolGUIControls.ui
 #Added from ML
 Qmitk/QmitkLabelSetWidgetControls.ui
 Qmitk/QmitkSurfaceStampWidgetGUIControls.ui
 Qmitk/QmitkMaskStampWidgetGUIControls.ui
 Qmitk/QmitkSliceBasedInterpolatorWidgetGUIControls.ui
 Qmitk/QmitkSurfaceBasedInterpolatorWidgetGUIControls.ui
 Qmitk/QmitkSearchLabelDialogGUI.ui
 )
 
 set(QRC_FILES
   resources/SegmentationUI.qrc
 )