#ifdef USE_KWWIDGETS #ifndef __vtkKWSlicer_h #define __vtkKWSlicer_h #include "vtkKWFrame.h" class vtkImageData; class vtkKWRenderWidget; class vtkImageViewer2; class vtkKWScale; class vtkKWWindowLevelPresetSelector; class vtkKWSimpleAnimationWidget; namespace bbkw { class vtkKWSlicer : public vtkKWFrame { public: static vtkKWSlicer* New(); vtkTypeRevisionMacro(vtkKWSlicer,vtkKWFrame); void SetImage(vtkImageData*); // Description: // Callbacks virtual void SetSliceFromScaleCallback(double value); virtual void SetSliceCallback(int slice); virtual int GetSliceCallback(); virtual int GetSliceMinCallback(); virtual int GetSliceMaxCallback(); virtual void SetSliceOrientationToXYCallback(); virtual void SetSliceOrientationToXZCallback(); virtual void SetSliceOrientationToYZCallback(); virtual void WindowLevelPresetApplyCallback(int id); virtual int WindowLevelPresetAddCallback(); virtual void WindowLevelPresetUpdateCallback(int id); virtual void WindowLevelPresetHasChangedCallback(int id); protected: vtkKWSlicer(); ~vtkKWSlicer(); // Description: // Create the widget. virtual void CreateWidget(); vtkImageViewer2 *ImageViewer; vtkKWScale *SliceScale; vtkKWWindowLevelPresetSelector *WindowLevelPresetSelector; vtkKWRenderWidget *RenderWidget; vtkKWSimpleAnimationWidget *AnimationWidget; virtual void UpdateSliceRanges(); private: vtkKWSlicer(const vtkKWSlicer&); // Not implemented. void operator=(const vtkKWSlicer&); // Not implemented. }; } #endif #endif