+/*=========================================================================
+ Program: vv http://www.creatis.insa-lyon.fr/rio/vv
+
+ 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
+
+ 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.
+
+ 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 __vvSlicer_h
#define __vvSlicer_h
#include <iostream>
class vtkCutter;
class vtkAssignAttribute;
class vtkScalarBarActor;
-
+class vtkTransform;
+class vtkImageReslice;
class vvSlicer: public vtkImageViewer2
{
vtkImageMapToWindowLevelColors* GetFusionMapper() ;
vtkImageActor* GetFusionActor() ;
vtkActor* GetVFActor() ;
- vtkCornerAnnotation* GetAnnotation() ;
-
+ vtkCornerAnnotation* GetAnnotation();
+
void SetFusion(vvImage::Pointer inputFusion);
vvImage::Pointer GetFusion() {
return mFusion;
return mSubSampling;
}
void SetVFScale(int scale);
+ void SetVFWidth(int width);
int GetVFScale() {
return mScale;
}
void EnableReducedExtent(bool b);
void SetReducedExtent(int * ext);
+ void ClipDisplayedExtent(int extent[6], int refExtent[6]);
+ int GetOrientation();
+ int * GetExtent();
+
protected:
vvSlicer();
~vvSlicer();
vtkSmartPointer<vtkActor> mLandActor;
vtkSmartPointer<vtkBox> mClipBox;
vtkSmartPointer<vtkScalarBarActor> legend;
-
std::vector<vvMeshActor*> mSurfaceCutActors;
int mCurrentTSlice;
int mSubSampling;
int mScale;
int mVFLog;
+ int mVFWidth;
bool mUseReducedExtent;
int * mReducedExtent;
int * mInitialExtent;
void ComputeVFDisplayedExtent(int x1,int x2,int y1,int y2,int z1,int z2,int extent[6]);
void ComputeOverlayDisplayedExtent(int x1,int x2,int y1,int y2,int z1,int z2,int overExtent[6]);
void ComputeFusionDisplayedExtent(int x1,int x2,int y1,int y2,int z1,int z2,int overExtent[6]);
- void ClipDisplayedExtent(int extent[6], int refExtent[6]);
///Sets the surfaces to be cut on the image slice: update the vtkCutter
void SetContourSlice();