You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
150 lines
4.4 KiB
C++
150 lines
4.4 KiB
C++
/*=========================================================================
|
|
|
|
Program: Visualization Toolkit
|
|
Module: vtkResliceImageViewerMeasurements.h
|
|
|
|
Copyright (c) Ken Martin, Will Schroeder, Bill Lorensen
|
|
All rights reserved.
|
|
See Copyright.txt or http://www.kitware.com/Copyright.htm for details.
|
|
|
|
This software is distributed WITHOUT ANY WARRANTY; without even
|
|
the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
|
|
PURPOSE. See the above copyright notice for more information.
|
|
|
|
=========================================================================*/
|
|
/**
|
|
* @class vtkResliceImageViewerMeasurements
|
|
* @brief Manage measurements on a resliced image
|
|
*
|
|
* This class manages measurements on the resliced image. It toggles the
|
|
* the visibility of the measurements based on whether the resliced image
|
|
* is the same orientation as when the measurement was initially placed.
|
|
* @sa
|
|
* vtkResliceCursor vtkResliceCursorWidget vtkResliceCursorRepresentation
|
|
*/
|
|
|
|
#ifndef vtkResliceImageViewerMeasurements_h
|
|
#define vtkResliceImageViewerMeasurements_h
|
|
|
|
#include "vtkInteractionImageModule.h" // For export macro
|
|
#include "vtkObject.h"
|
|
|
|
class vtkResliceImageViewer;
|
|
class vtkAbstractWidget;
|
|
class vtkCallbackCommand;
|
|
class vtkCollection;
|
|
class vtkDistanceWidget;
|
|
class vtkAngleWidget;
|
|
class vtkBiDimensionalWidget;
|
|
class vtkHandleRepresentation;
|
|
class vtkHandleWidget;
|
|
class vtkCaptionWidget;
|
|
class vtkContourWidget;
|
|
class vtkSeedWidget;
|
|
|
|
class VTKINTERACTIONIMAGE_EXPORT vtkResliceImageViewerMeasurements : public vtkObject
|
|
{
|
|
public:
|
|
|
|
//@{
|
|
/**
|
|
* Standard VTK methods.
|
|
*/
|
|
static vtkResliceImageViewerMeasurements *New();
|
|
vtkTypeMacro(vtkResliceImageViewerMeasurements,vtkObject);
|
|
void PrintSelf(ostream& os, vtkIndent indent);
|
|
//@}
|
|
|
|
/**
|
|
* Render the measurements.
|
|
*/
|
|
virtual void Render();
|
|
|
|
//@{
|
|
/**
|
|
* Add / remove a measurement widget
|
|
*/
|
|
virtual void AddItem(vtkAbstractWidget *);
|
|
virtual void RemoveItem(vtkAbstractWidget *);
|
|
virtual void RemoveAllItems();
|
|
//@}
|
|
|
|
//@{
|
|
/**
|
|
* Methods to change whether the widget responds to interaction.
|
|
* Set this to Off to disable interaction. On by default.
|
|
* Subclasses must overide SetProcessEvents() to make sure
|
|
* that they pass on the flag to all component widgets.
|
|
*/
|
|
vtkSetClampMacro(ProcessEvents, int, 0, 1);
|
|
vtkGetMacro(ProcessEvents, int);
|
|
vtkBooleanMacro(ProcessEvents, int);
|
|
//@}
|
|
|
|
//@{
|
|
/**
|
|
* Tolerance for Point-in-Plane check
|
|
*/
|
|
vtkSetMacro( Tolerance, double );
|
|
vtkGetMacro( Tolerance, double );
|
|
//@}
|
|
|
|
//@{
|
|
/**
|
|
* Set the reslice image viewer. This is automatically done in the class
|
|
* vtkResliceImageViewer
|
|
*/
|
|
virtual void SetResliceImageViewer( vtkResliceImageViewer * );
|
|
vtkGetObjectMacro( ResliceImageViewer, vtkResliceImageViewer );
|
|
//@}
|
|
|
|
/**
|
|
* Update the measurements. This is automatically called when the reslice
|
|
* cursor's axes are change.
|
|
*/
|
|
virtual void Update();
|
|
|
|
protected:
|
|
vtkResliceImageViewerMeasurements();
|
|
~vtkResliceImageViewerMeasurements();
|
|
|
|
//@{
|
|
/**
|
|
* Check if a measurement widget is on the resliced plane.
|
|
*/
|
|
bool IsItemOnReslicedPlane( vtkAbstractWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkDistanceWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkAngleWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkBiDimensionalWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkCaptionWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkContourWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkSeedWidget * w );
|
|
bool IsWidgetOnReslicedPlane( vtkHandleWidget * w );
|
|
bool IsPointOnReslicedPlane( vtkHandleRepresentation * h );
|
|
bool IsPositionOnReslicedPlane( double p[3] );
|
|
//@}
|
|
|
|
// Handles the events; centralized here for all widgets.
|
|
static void ProcessEventsHandler(vtkObject* object, unsigned long event,
|
|
void* clientdata, void* calldata);
|
|
|
|
vtkResliceImageViewer * ResliceImageViewer;
|
|
vtkCollection * WidgetCollection;
|
|
|
|
// Handle the visibility of the measurements.
|
|
vtkCallbackCommand * EventCallbackCommand; //
|
|
|
|
// Flag indicating if we should handle events.
|
|
// On by default.
|
|
int ProcessEvents;
|
|
|
|
// Tolerance for Point-in-plane computation
|
|
double Tolerance;
|
|
|
|
private:
|
|
vtkResliceImageViewerMeasurements(const vtkResliceImageViewerMeasurements&) VTK_DELETE_FUNCTION;
|
|
void operator=(const vtkResliceImageViewerMeasurements&) VTK_DELETE_FUNCTION;
|
|
};
|
|
|
|
#endif
|