]> Creatis software - cpPlugins.git/blobdiff - lib/cpExtensions/Visualization/ImageSliceActors.h
Cast image filter added. ROI filter modified.
[cpPlugins.git] / lib / cpExtensions / Visualization / ImageSliceActors.h
index 6c97448f48c5c0cfcec9192ccc49642225da77f4..25f81f6fae52a849e86019fe9a2b2c84e6b1dfcd 100644 (file)
@@ -1,34 +1,22 @@
-#ifndef __CPEXTENSIONS__VISUALIZATION__IMAGESLICEACTORS__H__
-#define __CPEXTENSIONS__VISUALIZATION__IMAGESLICEACTORS__H__
+#ifndef __cpExtensions__Visualization__ImageSliceActors__h__
+#define __cpExtensions__Visualization__ImageSliceActors__h__
 
-#include <cpExtensions/cpExtensions_Export.h>
-
-#include <utility>
-#include <vector>
-
-#include <vtkSmartPointer.h>
-#include <vtkActor.h>
-#include <vtkImageActor.h>
-#include <vtkImageMapToColors.h>
-#include <vtkImageSliceMapper.h>
-#include <vtkPlane.h>
-#include <vtkPolyData.h>
-#include <vtkPolyDataMapper.h>
+#include <cpExtensions/Config.h>
 #include <vtkPropCollection.h>
-#include <vtkTextActor.h>
-
-#include <cpExtensions/Visualization/ImageInteractorStyle.h>
+#include <vtkSmartPointer.h>
 
 // -------------------------------------------------------------------------
-class vtkAlgorithmOutput;
 class vtkImageData;
-class vtkLookupTable;
 
 // -------------------------------------------------------------------------
 namespace cpExtensions
 {
   namespace Visualization
   {
+    class ImageOutlineActor;
+    class LUTImageActor;
+    class WindowLevelImageActor;
+
     /**
      */
     class cpExtensions_EXPORT ImageSliceActors
@@ -37,179 +25,50 @@ namespace cpExtensions
     public:
       typedef ImageSliceActors Self;
 
-      typedef void ( *TCursorCommand )( double*, int, void* );
-      typedef ImageInteractorStyle::TMouseCommand      TMouseCommand;
-      typedef ImageInteractorStyle::TMouseWheelCommand TMouseWheelCommand;
-      typedef ImageInteractorStyle::TKeyCommand        TKeyCommand;
-
     public:
       vtkTypeMacro( ImageSliceActors, vtkPropCollection );
 
-      vtkGetMacro( MinWindow, double );
-      vtkGetMacro( MaxWindow, double );
-      vtkGetMacro( MinLevel, double );
-      vtkGetMacro( MaxLevel, double );
-
     public:
-      // Creation
-      static ImageSliceActors* New( );
-
-      void AddCursorCommand( TCursorCommand command, void* data )
-      {
-        this->CursorCommands.push_back(
-          std::pair< TCursorCommand, void* >(
-            command, data
-            )
-          );
-      }
-
-      void AddInputConnection( vtkAlgorithmOutput* aout, int axis = 2 );
-      void AddInputData( vtkImageData* data, int axis = 2 );
-      void Clear( );
-
-      void AssociateSlice( Self* other );
-      void SetSlicesCommand( TCursorCommand cmd, void* data );
-
-      vtkInteractorStyle* GetStyle( );
-      const vtkInteractorStyle* GetStyle( ) const;
-
-      void PushActorsInto( vtkRenderWindow* window, bool force_style = true );
-      void PopActorsFrom( vtkRenderWindow* window );
-      unsigned int GetNumberOfImageActors( ) const;
-      vtkImageActor* GetImageActor( unsigned int id );
-      const vtkImageActor* GetImageActor( unsigned int id ) const;
-      vtkTextActor* GetTextActor( );
-      const vtkTextActor* GetTextActor( ) const;
-      vtkActor* GetPlaneActor( );
-      const vtkActor* GetPlaneActor( ) const;
-      vtkPlane* GetPlaneFunction( );
-      const vtkPlane* GetPlaneFunction( ) const;
-
-      void AddActor( vtkAlgorithm* algorithm, vtkActor* actor );
-      void AddActor( vtkActor* actor );
-
-      void SetInterpolate( bool v );
-      void InterpolateOn( );
-      void InterpolateOff( );
-
-      double* GetDisplayBounds( ) const;
-      void GetDisplayBounds( double bounds[ 6 ] ) const;
-
-      void ResetCursor( );
-      void SetCursor( double pos[ 3 ] );
-
-      vtkImageMapToColors* GetImageMap( unsigned int id );
-      const vtkImageMapToColors* GetImageMap( unsigned int id ) const;
-
-      double GetWindow( ) const;
-      double GetLevel( ) const;
-      void SetWindow( double w );
-      void SetLevel( double l );
-      void SetWindowLevel( double w, double l );
-      void ResetWindowLevel( );
-
-      void SetLookupTable( unsigned int id, vtkLookupTable* lut );
-      void SetLookupTableAsColor(
-        unsigned int id, double r, double g, double b
-        );
-
-      int GetAxis( ) const;
+      static Self* New( );
+
+      vtkImageData* GetImage( );
+      const vtkImageData* GetImage( ) const;
+
+      WindowLevelImageActor* GetWindowLevelImageActor( );
+      const WindowLevelImageActor* GetWindowLevelImageActor( ) const;
+
+      LUTImageActor* GetLUTImageActor( );
+      const LUTImageActor* GetLUTImageActor( ) const;
+
+      ImageOutlineActor* GetImageOutlineActor( );
+      const ImageOutlineActor* GetImageOutlineActor( ) const;
+
+      int GetOrientation( ) const;
+
       int GetSliceNumber( ) const;
-      int GetSliceNumberMinValue( ) const;
-      int GetSliceNumberMaxValue( ) const;
-      void SetSliceNumber( const int& slice );
-      void SetSlice( double* pos );
-      void UpdateText( );
-      void UpdateText( double pos[ 3 ] );
-      void UpdateText( const double& w, const double& l );
+      virtual void SetImage( vtkImageData* image, int orientation );
+      virtual unsigned int AddLUTImage( vtkImageData* image );
+      virtual void SetSliceNumber( int slice );
 
     protected:
       ImageSliceActors( );
       virtual ~ImageSliceActors( );
 
-      void _ConfigureNewLUT( vtkImageData* data );
-      void _ConfigureNewInput( int axis );
-
-      // Events
-      static void _MouseMoveCommand(
-        void* data,
-        const ImageInteractorStyle::ButtonID& btn, double* pos,
-        bool alt, bool ctr, bool sft
-        );
-      static void _MouseClickCommand(
-        void* data,
-        const ImageInteractorStyle::ButtonID& btn, double* pos,
-        bool alt, bool ctr, bool sft
-        );
-      static void _MouseDoubleClickCommand(
-        void* data,
-        const ImageInteractorStyle::ButtonID& btn, double* pos,
-        bool alt, bool ctr, bool sft
-        );
-      static void _MouseWheelCommand(
-        void* data,
-        const int& dir, bool alt, bool ctr, bool sft
-        );
-      static void _KeyCommand(
-        void* data,
-        const char& key
-        );
-
     private:
       // Purposely not implemented
       ImageSliceActors( const Self& );
       Self& operator=( const Self& );
 
     protected:
-      vtkSmartPointer< ImageInteractorStyle > Style;
-
-      // Multiple actors
-      std::vector< vtkSmartPointer< vtkImageMapToColors > > ImageMaps;
-      std::vector< vtkSmartPointer< vtkImageSliceMapper > > SliceMappers;
-      std::vector< vtkSmartPointer< vtkImageActor > >       ImageActors;
-      bool Interpolate;
-
-      // Window-Level values
-      double MinWindow, MaxWindow;
-      double MinLevel, MaxLevel;
-
-      // Other associated slices
-      std::vector< vtkSmartPointer< Self > > AssociatedSlices;
-      TCursorCommand SlicesCommand;
-      void* SlicesData;
-
-      // Associated commands
-      std::vector< std::pair< TCursorCommand, void* > > CursorCommands;
-      std::vector< TMouseCommand >      MouseCommands;
-      std::vector< TMouseCommand >      MouseClickCommands;
-      std::vector< TMouseCommand >      MouseDoubleClickCommands;
-      std::vector< TMouseWheelCommand > MouseWheelCommands;
-      std::vector< TKeyCommand >        KeyCommands;
-
-      // Other associated actors
-      typedef std::pair< vtkAlgorithm*, vtkActor* > TAssociatedActor;
-      typedef std::vector< TAssociatedActor >       TAssociatedActors;
-      TAssociatedActors AssociatedActors;
-
-      // Unique objects
-      vtkSmartPointer< vtkPolyData >       Cursor;
-      vtkSmartPointer< vtkPolyDataMapper > CursorMapper;
-      vtkSmartPointer< vtkActor >          CursorActor;
-      vtkSmartPointer< vtkPlane >          PlaneFunction;
-      vtkSmartPointer< vtkPolyData >       Plane;
-      vtkSmartPointer< vtkPolyDataMapper > PlaneMapper;
-      char                                 TextBuffer[ 1024 ];
-      vtkSmartPointer< vtkTextActor >      TextActor;
-      vtkSmartPointer< vtkActor >          PlaneActor;
-
-      double StartWindowLevelPos[ 3 ];
-      double StartWindowLevel[ 2 ];
+      vtkSmartPointer< ImageOutlineActor >     m_ImageOutlineActor;
+      vtkSmartPointer< LUTImageActor >         m_LUTImageActor;
+      vtkSmartPointer< WindowLevelImageActor > m_WindowLevelImageActor;
     };
 
   } // ecapseman
 
 } // ecapseman
 
-#endif //  __CPEXTENSIONS__VISUALIZATION__IMAGESLICEACTORS__H__
+#endif // __cpExtensions__Visualization__ImageSliceActors__h__
 
 // eof - $RCSfile$