X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=vv%2FvvImageContour.h;h=ad1143dd963399ca01319dbc382e78da529fe1e2;hb=2dad4a649b5e61f450b47047f379fcc351b50215;hp=0e9a9436f91fe0647f32747b08b7444e05dde35f;hpb=26bbfd8756d07eb73acbfe2fcfd77b3a4f3b52a9;p=clitk.git diff --git a/vv/vvImageContour.h b/vv/vvImageContour.h index 0e9a943..ad1143d 100644 --- a/vv/vvImageContour.h +++ b/vv/vvImageContour.h @@ -1,65 +1,80 @@ /*========================================================================= + Program: vv http://www.creatis.insa-lyon.fr/rio/vv - Program: vv - Module: $RCSfile: vvImageContour.h,v $ - Language: C++ - Date: $Date: 2010/02/07 12:00:59 $ - Version: $Revision: 1.2 $ - 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 update(double value); + void hideActors(); + void showActors(); + void setColor(double r, double g, double b); + void setImage(vvImage::Pointer image); + void setPreserveModeEnabled(bool b); protected: vvSlicer * mSlicer; int mSlice; int mTSlice; + double mValue; + 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); + void updateActor(vtkActor * actor, + vtkMarchingSquares * squares, + vtkImageClip * clipper, + int threshold, int orientation, int slice); + void createActor(int orientation, int slice); + int computeCurrentOrientation(); + }; // end class vvImageContour //------------------------------------------------------------------------------