13#ifndef QmitkUSNavigationStepPunctuationIntervention_h
14#define QmitkUSNavigationStepPunctuationIntervention_h
17#include <mitkPointSet.h>
19#include <vtkSmartPointer.h>
20#include <vtkSphereSource.h>
22#include <vtkOBBTree.h>
26class NeedleProjectionFilter;
27class NodeDisplacementFilter;
28class USNavigationGrabCutSegmentationUpdateFilter;
29class USNavigationTargetUpdateFilter;
30class USNavigationTargetOcclusionFilter;
31class USPointMarkInteractor;
32class LookupTableProperty;
98 bool CheckSphereLineIntersection(mitk::Point3D& sphereOrigin,
float& sphereRadius, mitk::Point3D& lineStart, mitk::Point3D& lineEnd);
101 Ui::QmitkUSNavigationStepPunctuationIntervention *m_Ui;
103 mitk::DataStorage::SetOfObjects::ConstPointer m_ZoneNodes;
109 mitk::NavigationTool::Pointer m_NeedleNavigationTool;
111 std::map<mitk::DataNode::Pointer,mitk::Color> m_OldColors;
Abstract base class for navigation step widgets.
std::vector< itk::SmartPointer< mitk::NavigationDataToNavigationDataFilter > > FilterVector
Navigations step for the actual punctuation intervention. The needle path is projected onto the image...
void OnShowToolAxisEnabled(int enabled)
bool CheckSphereLineIntersection(mitk::Point3D &sphereOrigin, float &sphereRadius, mitk::Point3D &lineStart, mitk::Point3D &lineEnd)
void OnAblationZoneSizeSliderChanged(int size)
void OnEnableAblationZoneMarkingClicked()
bool OnActivateStep() override
Called when the navigation step gets activated. This method has to be implemented by a concrete subcl...
bool GetIsRestartable() override
Indicates if it makes sense to be able to restart the step. This method must be implemented by concre...
void OnUpdate() override
Called periodically while a navigation step is active. This method has to be implemented by a concret...
void UpdateBodyMarkerStatus(mitk::NavigationData::Pointer bodyMarker)
bool OnRestartStep() override
Called when restarting a navigation step. This method may be implemented by a concrete subclass to ha...
QString GetTitle() override
Getter for the title of the navigation step. This title should be human readable and can be used to d...
bool OnStartStep() override
Called when the navigation step gets started. This method has to be implemented by a concrete subclas...
void UpdateCriticalStructures(mitk::NavigationData::Pointer needle, mitk::PointSet::Pointer path)
FilterVector GetFilter() override
Getter for navigation data filters of the navigation step. This method may be implemented by a concre...
~QmitkUSNavigationStepPunctuationIntervention() override
void AblationZoneChanged(int, int)
void AddAblationZoneClicked(int)
bool OnFinishStep() override
Called when all necessary actions for the step where done. This method has to be implemented by a con...
void OnSettingsChanged(const itk::SmartPointer< mitk::DataNode >) override
Called every time the settings for the navigation process where changed. This method may be implement...
void OnSetCombinedModality() override
Called every time SetCombinedModality() was called. This method may be implemented by a concrete subc...
void OnAddAblationZoneClicked()
QmitkUSNavigationStepPunctuationIntervention(QWidget *parent=nullptr)
void SetNeedleMetaData(mitk::NavigationTool::Pointer needleNavigationTool)
QProgressBar for displaying distances to zones. Colors are changed according to the distance to the z...