X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=lib%2FcpExtensions%2FVisualization%2FImageSliceActors.h;h=8fff84881d01249d7283f281382366de4a7a510d;hb=106a56bfe6a48067380089ffd61a518e40d77933;hp=4708e07f7bcb588cad04d52d84cf922154fb37b3;hpb=a4bc3b8e36e91e45f37a3b7eecb5789c635aa5c0;p=cpPlugins.git diff --git a/lib/cpExtensions/Visualization/ImageSliceActors.h b/lib/cpExtensions/Visualization/ImageSliceActors.h index 4708e07..8fff848 100644 --- a/lib/cpExtensions/Visualization/ImageSliceActors.h +++ b/lib/cpExtensions/Visualization/ImageSliceActors.h @@ -3,13 +3,9 @@ #include -#include -#include - #include #include #include -#include #include #include #include @@ -17,11 +13,14 @@ #include #include -#include +#include +#include // ------------------------------------------------------------------------- class vtkAlgorithmOutput; class vtkImageData; +class vtkLookupTable; +class vtkRenderer; // ------------------------------------------------------------------------- namespace cpExtensions @@ -36,39 +35,54 @@ namespace cpExtensions public: typedef ImageSliceActors Self; + typedef cpExtensions::Interaction::ImageInteractorStyle TStyle; + typedef TStyle::TMouseCommand TMouseCommand; + typedef TStyle::TMouseWheelCommand TMouseWheelCommand; + typedef TStyle::TKeyCommand TKeyCommand; + typedef TStyle::TVoidCommand TVoidCommand; + typedef TStyle::TMouseMoveCommand TMouseMoveCommand; + typedef TStyle::TMouseClickCommand TMouseClickCommand; + typedef TStyle::TMouseDoubleClickCommand TMouseDoubleClickCommand; + typedef TStyle::TExposeCommand TExposeCommand; + typedef TStyle::TConfigureCommand TConfigureCommand; + typedef TStyle::TEnterCommand TEnterCommand; + typedef TStyle::TLeaveCommand TLeaveCommand; + typedef void ( *TSlicesCommand )( double*, int, void* ); + typedef void ( *TWindowLevelCommand )( double, double, void* ); + typedef TVoidCommand TRenderCommand; + public: vtkTypeMacro( ImageSliceActors, vtkPropCollection ); - enum LUTType - { - LUTType_None = 0, - LUTType_WindowLevel, - LUTType_Colors - }; + cpExtensions_BaseInteractorStyle_Commands( Slices ); + cpExtensions_BaseInteractorStyle_Commands( WindowLevel ); + cpExtensions_BaseInteractorStyle_Commands( Render ); public: // Creation static ImageSliceActors* New( ); - void AddInputConnection( - vtkAlgorithmOutput* aout, - int axis = 2, - LUTType lut = Self::LUTType_None - ); - void AddInputData( - vtkImageData* data, - int axis = 2, - LUTType lut = Self::LUTType_None ); + ImageBlender* GetBlender( ); + const ImageBlender* GetBlender( ) const; + void SetBlender( ImageBlender* blender ); + void SetAxis( int axis ); + void AddInputConnection( vtkAlgorithmOutput* aout ); + void AddInputData( vtkImageData* data ); void Clear( ); + void AssociateSlice( Self* slice ); + + vtkImageData* GetInputImage( unsigned int id ); + const vtkImageData* GetInputImage( unsigned int id ) const; + 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; + unsigned int GetNumberOfImages( ) const; + vtkImageActor* GetImageActor( ); + const vtkImageActor* GetImageActor( ) const; vtkTextActor* GetTextActor( ); const vtkTextActor* GetTextActor( ) const; vtkActor* GetPlaneActor( ); @@ -76,9 +90,6 @@ namespace cpExtensions vtkPlane* GetPlaneFunction( ); const vtkPlane* GetPlaneFunction( ) const; - void AddActor( vtkAlgorithm* algorithm, vtkActor* actor ); - void AddActor( vtkActor* actor ); - void SetInterpolate( bool v ); void InterpolateOn( ); void InterpolateOff( ); @@ -89,46 +100,47 @@ namespace cpExtensions void ResetCursor( ); void SetCursor( double pos[ 3 ] ); - vtkImageMapToColors* GetImageMap( unsigned int id ); - const vtkImageMapToColors* GetImageMap( unsigned int id ) const; - - double GetWindow( unsigned int id ) const; - double GetLevel( unsigned int id ) const; - void SetWindow( unsigned int id, double w ); - void SetLevel( unsigned int id, double l ); - void SetWindowLevel( unsigned int id, double w, double l ); - void ResetWindowLevel( unsigned int id ); + double GetMinWindow( ) const; + double GetMaxWindow( ) const; + double GetMinLevel( ) const; + double GetMaxLevel( ) const; + double GetWindow( ) const; + double GetLevel( ) const; + void SetWindow( double w ); + void SetLevel( double l ); + void SetWindowLevel( double w, double l ); + void ResetWindowLevel( ); int GetAxis( ) 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 ); + void Render( const double& t ); + void ResetCamera( ); + protected: ImageSliceActors( ); virtual ~ImageSliceActors( ); - void _ConfigureNewLUT( vtkImageData* data, LUTType lut_t ); - void _ConfigureNewInput( int axis ); + void _ConfigureStyle( ); // Events static void _MouseMoveCommand( void* data, - const ImageInteractorStyle::ButtonID& btn, double* pos, + const TStyle::ButtonID& btn, + int* idx, 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, + const TStyle::ButtonID& btn, + int* idx, double* pos, bool alt, bool ctr, bool sft ); static void _MouseWheelCommand( @@ -139,6 +151,8 @@ namespace cpExtensions void* data, const char& key ); + static void _EnterCommand( void* data ); + static void _LeaveCommand( void* data ); private: // Purposely not implemented @@ -146,32 +160,43 @@ namespace cpExtensions Self& operator=( const Self& ); protected: - vtkSmartPointer< ImageInteractorStyle > Style; + vtkSmartPointer< TStyle > m_Style; + vtkRenderWindow* m_Window; // Multiple actors - std::vector< vtkSmartPointer< vtkImageMapToColors > > ImageMaps; - std::vector< vtkSmartPointer< vtkImageSliceMapper > > SliceMappers; - std::vector< vtkSmartPointer< vtkImageActor > > ImageActors; - bool Interpolate; + vtkSmartPointer< ImageBlender > m_ImageBlender; + vtkSmartPointer< vtkImageSliceMapper > m_ImageMapper; + vtkSmartPointer< vtkImageActor > m_ImageActor; + bool m_Interpolate; - // Other associated actors - typedef std::pair< vtkAlgorithm*, vtkActor* > TAssociatedActor; - typedef std::vector< TAssociatedActor > TAssociatedActors; - TAssociatedActors AssociatedActors; + int m_VisibleExtent[ 6 ]; + double m_VisibleBounds[ 6 ]; + + // Associated slices + std::vector< Self* > m_AssociatedSlices; // Unique objects - vtkSmartPointer< vtkPolyData > Cursor; - vtkSmartPointer< vtkPolyDataMapper > CursorMapper; - vtkSmartPointer< vtkActor > CursorActor; - vtkSmartPointer< vtkPlane > PlaneFunction; - vtkSmartPointer< vtkPolyData > PlaneSource; - vtkSmartPointer< vtkPolyDataMapper > PlaneMapper; - char TextBuffer[ 1024 ]; - vtkSmartPointer< vtkTextActor > TextActor; - vtkSmartPointer< vtkActor > PlaneActor; - - double StartWindowLevelPos[ 3 ]; - double StartWindowLevel[ 2 ]; + vtkSmartPointer< vtkPolyData > m_Cursor; + vtkSmartPointer< vtkPolyDataMapper > m_CursorMapper; + vtkSmartPointer< vtkActor > m_CursorActor; + + vtkSmartPointer< vtkPolyData > m_HorizontalLine; + vtkSmartPointer< vtkPolyDataMapper > m_HorizontalLineMapper; + vtkSmartPointer< vtkActor > m_HorizontalLineActor; + + vtkSmartPointer< vtkPolyData > m_VerticalLine; + vtkSmartPointer< vtkPolyDataMapper > m_VerticalLineMapper; + vtkSmartPointer< vtkActor > m_VerticalLineActor; + + vtkSmartPointer< vtkPolyData > m_Plane; + vtkSmartPointer< vtkPolyDataMapper > m_PlaneMapper; + vtkSmartPointer< vtkActor > m_PlaneActor; + + char m_TextBuffer[ 1024 ]; + vtkSmartPointer< vtkTextActor > m_TextActor; + + double m_StartWindowLevelPos[ 3 ]; + double m_StartWindowLevel[ 2 ]; }; } // ecapseman