X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=vv%2FvvImageContour.h;h=d93a3f343b29ffbe1e0339903b935fc30984a1fd;hb=d3682a4b4db6ce9090a38c37d124ee9c24f6fd5f;hp=be96b05e8665a26d383d0ed16632274663636427;hpb=0a85e47a06c7d046d06a4645b724c4e81b19998d;p=clitk.git
diff --git a/vv/vvImageContour.h b/vv/vvImageContour.h
index be96b05..d93a3f3 100644
--- a/vv/vvImageContour.h
+++ b/vv/vvImageContour.h
@@ -1,66 +1,83 @@
/*=========================================================================
+ Program: vv http://www.creatis.insa-lyon.fr/rio/vv
- Program: vv
- Module: $RCSfile: vvImageContour.h,v $
- Language: C++
- Date: $Date: 2010/02/24 11:42:42 $
- Version: $Revision: 1.3 $
- Author : David Sarrut (david.sarrut@creatis.insa-lyon.fr)
+ Authors belong to:
+ - University of LYON http://www.universite-lyon.fr/
+ - Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
+ - CREATIS CNRS laboratory http://www.creatis.insa-lyon.fr
- Copyright (C) 2010
- Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
- CREATIS http://www.creatis.insa-lyon.fr
+ This software is distributed WITHOUT ANY WARRANTY; without even
+ the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
+ PURPOSE. See the copyright notices for more information.
- This program is free software: you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation, version 3 of the License.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program. If not, see .
-
- =========================================================================*/
+ It is distributed under dual licence
+ - 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
-#include
-#include
-#include
-#include
-#include
-#include
-#include
-
#include "clitkCommon.h"
#include "vvSlicer.h"
+class vtkImageClip;
+class vtkMarchingSquares;
+class vtkActor;
+class vvImage;
+
//------------------------------------------------------------------------------
class vvImageContour
{
// Q_OBJECT
- public:
+ public:
vvImageContour();
~vvImageContour();
- void setSlicer(vvSlicer * slicer);
- // vtkActor * getActor() { return mSquaresActor;}
- void update(int value);
- void removeActors();
+ 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::Pointer image);
+ void SetPreserveMemoryModeEnabled(bool b);
protected:
vvSlicer * mSlicer;
int mSlice;
int mTSlice;
-
+ double mValue;
+ int mPreviousTSlice;
+ double mPreviousValue;
+ bool mHiddenImageIsUsed;
+ vvImage::Pointer mHiddenImage;
+ bool mDisplayModeIsPreserveMemory;
+
+ // For preserveMemory mode
std::vector mClipperList;
std::vector mSquaresList;
std::vector mSquaresActorList;
+ // For fast cache mode
+ int mPreviousSlice;
+ int mPreviousOrientation;
+ 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();
+
}; // end class vvImageContour
//------------------------------------------------------------------------------