]> Creatis software - creaMaracasVisu.git/blobdiff - lib/maracasVisuLib/src/interface/wxWindows/widgets/ThresholdImageView/LayerImageBase.h
#3262 creaMaracasVisu Feature New Normal - Export LookupTable fron ColorLayerImageV...
[creaMaracasVisu.git] / lib / maracasVisuLib / src / interface / wxWindows / widgets / ThresholdImageView / LayerImageBase.h
index fec399ca43a180788f551dee20215bc3f69a024f..ac329685949d6210ac67b99ae89a2ccfb0cea900 100644 (file)
@@ -45,6 +45,8 @@
 #include "vtkScalarBarActor.h"
 
 #include "InteractorStyleMaracas.h"
+#include "vtkImageChangeInformation.h"
+
 
 //----------------------------------------------------------------------------------
 //----------------------------------------------------------------------------------
@@ -63,7 +65,7 @@ public:
        virtual bool OnRightButtonUp();
 
 private:
-    bool                                       _state;
+    bool                               _state;
     bool                               _stateKey;
     LayerImageBase*    _layerImageBase;
 
@@ -83,11 +85,15 @@ class LayerImageBase
   public:
                LayerImageBase();
                virtual ~LayerImageBase();
-               void SetX(int x);
-               void SetY(int y);
-               void SetZ(int z);
-               void SetImage(vtkImageData* image);
-               void SetwxVtkBaseView(wxVtkBaseView *baseview);
+               void                    SetX(int x);
+               void                    SetY(int y);
+               void                    SetZ(int z);
+               void                    SetImage(vtkImageData* image);
+               vtkImageData*   GetImage();
+               void                    SetRangeForColorBar(std::vector<double> &range);
+               void                    GetRangeForColorBar(double &minRange, double &maxRange);
+               void                    SetColorBarPosition(std::vector<int> &colorbarposition);
+               void                    SetwxVtkBaseView(wxVtkBaseView *baseview);
 
                void onThreshold();
                void onThresholdChange();
@@ -102,28 +108,47 @@ class LayerImageBase
                virtual int GetY();
                virtual int GetZ();
                bool GetActorPresent();
+               void GetImageScalarRange();
+
+               void SetDimensionOriginalLayer(int dim[3]);
+               void SetDimensionBase(int dim[3]);
+               void SetSpcOriginalLayer(double spc[3]);
+               void SetNewSpacingLayer(double spc[3]);
+               void SetSpcBase(double spc[3]);
+               void GetDimensionOriginalLayer(int *dim);
+               void GetDimensionBase(int *dim);
+               void GetSpcOriginalLayer(double *spc);
+               void GetSpcBase(double *spc);
+               vtkScalarsToColors* GetLookupTable();
 
   private:
-               int                                             _X;
-               int                                             _Y;
-               int                                             _Z;
+               int                                                     _X;
+               int                                                     _Y;
+               int                                                     _Z;
                bool                                            _actorPresent;
-               vtkImageData                    *_image;
-               vtkImageReslice         *_imageReslicer;
-               vtkLookupTable                  *_thresholdTable;
-               vtkImageMapToColors     *_thresholdMapper;
-               vtkImageActor                   *_thresholdActor;
-               wxVtkBaseView                   *_baseView;
-
-               vtkScalarBarActor               *_scalarbarActor;
-
-               virtual void ConfigLookupTable() = 0;           
-               void CleanXYZ(double &x, double &y, double &z);
-
+               int                                             _dimOriginalLayer[3];
+               double                                          _spcOriginalLayer[3];
+               double                                          _newSpcLayer[3];
+               int                                             _dimBase[3];
+               double                                          _spcBase[3];
+               double                                          _opacity;
+
+               vtkImageData                            *_image;
+               vtkImageChangeInformation       *_imageChangeInformation;
+               vtkImageReslice                         *_imageReslicer;
+               vtkLookupTable                          *_thresholdTable;
+               vtkImageMapToColors                     *_thresholdMapper;
+               vtkImageActor                           *_thresholdActor;
+               wxVtkBaseView                           *_baseView;
+               vtkScalarBarActor                       *_scalarbarActor;
+               virtual void                            ConfigLookupTable() = 0;                
+               void                                            CleanXYZ(double &x, double &y, double &z);
 
   protected:
-               vtkLookupTable* GetThresholdTable();
-               vtkImageData* GetImage();
+               vtkLookupTable                          *GetThresholdTable();
+               double                                          _range[2];
+               std::vector<double>             _rangeForColorBar;
+               std::vector<int>                        _colorBarPosition;
  };