X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=vv%2FvvImageContour.h;h=d2be5129a6e00d6bb1d7c63dbe7f5b1ff1815b56;hb=2300716104b55267692efc2c0e506b3c5c45df38;hp=d7cf62cc4db8eb6578996168f16bee03502b7cc6;hpb=cb4f548b5df0172cc7fad02345d7eb3d7a4fa3aa;p=clitk.git diff --git a/vv/vvImageContour.h b/vv/vvImageContour.h index d7cf62c..d2be512 100644 --- a/vv/vvImageContour.h +++ b/vv/vvImageContour.h @@ -3,7 +3,7 @@ Authors belong to: - University of LYON http://www.universite-lyon.fr/ - - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr + - Léon Bérard cancer center http://www.centreleonberard.fr - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr This software is distributed WITHOUT ANY WARRANTY; without even @@ -14,7 +14,7 @@ - BSD See included LICENSE.txt file - CeCILL-B http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html -======================================================================-====*/ +===========================================================================**/ #ifndef VVIMAGECONTOUR_H #define VVIMAGECONTOUR_H @@ -27,22 +27,24 @@ class vtkActor; class vvImage; //------------------------------------------------------------------------------ -class vvImageContour +class vvImageContour: public itk::LightObject { // Q_OBJECT - public: - vvImageContour(); - ~vvImageContour(); +public: + typedef vvImageContour Self; + typedef itk::SmartPointer Pointer; + itkNewMacro(Self); - void setSlicer(vvSlicer * slicer); - void update(double value); - void hideActors(); - void showActors(); - void setColor(double r, double g, double b); - void setImage(vvImage::Pointer image); - void setPreserveMemoryModeEnabled(bool b); + void SetSlicer(vvSlicer * slicer); + void Update(double value); + void HideActors(); + void ShowActors(); + void SetColor(double r, double g, double b); + void SetLineWidth(double w); + void SetImage(vvImage * image); + void SetPreserveMemoryModeEnabled(bool b); - protected: +protected: vvSlicer * mSlicer; int mSlice; int mTSlice; @@ -50,13 +52,14 @@ class vvImageContour int mPreviousTSlice; double mPreviousValue; bool mHiddenImageIsUsed; - vvImage::Pointer mHiddenImage; + vvImage * mHiddenImage; bool mDisplayModeIsPreserveMemory; // For preserveMemory mode - std::vector mClipperList; - std::vector mSquaresList; - std::vector mSquaresActorList; + std::vector > mSquaresActorList; + std::vector > mClipperList; + std::vector > mSquaresList; + std::vector > mSquaresMapperList; // For fast cache mode int mPreviousSlice; @@ -64,19 +67,19 @@ class vvImageContour std::vector > mListOfCachedContourActors; // Functions - void initializeCacheMode(); - void updateWithPreserveMemoryMode(); - void updateWithFastCacheMode(); - void createNewActor(vtkActor ** actor, - vtkMarchingSquares ** squares, - vtkImageClip ** clipper, int numImage); - void updateActor(vtkActor * actor, - vtkMarchingSquares * squares, - vtkImageClip * clipper, - double threshold, int orientation, int slice); - void createActor(int orientation, int slice); - int computeCurrentOrientation(); - + void InitializeCacheMode(); + void UpdateWithPreserveMemoryMode(); + void UpdateWithFastCacheMode(); + void CreateNewActor(int numImage); + void UpdateActor(vtkActor * actor, vtkPolyDataMapper * mapper, vtkMarchingSquares * squares, vtkImageClip * clipper, + double threshold, int orientation, int slice); + void CreateActor(int orientation, int slice); + int ComputeCurrentOrientation(); + +private: + vvImageContour(); + ~vvImageContour(); + int mPreviousTslice; }; // end class vvImageContour //------------------------------------------------------------------------------