]> Creatis software - clitk.git/blobdiff - common/vvImage.h
Remove vcl_math calls
[clitk.git] / common / vvImage.h
index 84aeae528673481156dbbf86e0236e6edb8587fe..cbb0284ce0e925f706032825c7e8888da7744987 100644 (file)
@@ -1,72 +1,97 @@
 /*=========================================================================
+  Program:   vv                     http://www.creatis.insa-lyon.fr/rio/vv
 
- Program:   vv
- Module:    $RCSfile: vvImage.h,v $
- Language:  C++
- Date:      $Date: 2010/01/06 13:32:01 $
- Version:   $Revision: 1.1 $
- Author :   Pierre Seroul (pierre.seroul@gmail.com)
+  Authors belong to:
+  - University of LYON              http://www.universite-lyon.fr/
+  - Léon Bérard cancer center       http://www.centreleonberard.fr
+  - CREATIS CNRS laboratory         http://www.creatis.insa-lyon.fr
 
-Copyright (C) 2008
-Léon Bérard cancer center http://oncora1.lyon.fnclcc.fr
-CREATIS-LRMN 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.
+  It is distributed under dual licence
 
-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 <http://www.gnu.org/licenses/>.
-
-=========================================================================*/
-#ifndef vvImage_h
-#define vvImage_h
+  - BSD        See included LICENSE.txt file
+  - CeCILL-B   http://www.cecill.info/licences/Licence_CeCILL-B_V1-en.html
+===========================================================================**/
+#ifndef VVIMAGE_H
+#define VVIMAGE_H
 
 #include <iostream>
 #include <vector>
 #include <itkObjectFactory.h>
+#include <itkProcessObject.h>
+#include <itkMinimumMaximumImageCalculator.h>
+#include <itkCastImageFilter.h>
+
+#define VTK_EXCLUDE_STRSTREAM_HEADERS
+#include <vtkSmartPointer.h>
+#include <vtkTransform.h>
 
 class vtkImageData;
 
+//------------------------------------------------------------------------------
 class vvImage : public itk::LightObject
 {
 public :
-    typedef vvImage Self;
-    typedef itk::SmartPointer<Self> Pointer;
-    itkNewMacro(Self);
+  typedef vvImage Self;
+  typedef itk::SmartPointer<Self> Pointer;
+  typedef itk::ProcessObject::Pointer ConverterPointer;
+  itkNewMacro(Self);
+  
+  struct DimensionDispatchBase {};
+  template< unsigned int VDimension >
+  struct DimensionDispatch:public DimensionDispatchBase {};
 
-    void Init();
-    void SetImage(std::vector<vtkImageData*> images);
-    void AddImage(vtkImageData* image);
-    const std::vector<vtkImageData*>& GetVTKImages() {
-        return mVtkImages;
-    }
-
-    int GetNumberOfDimensions() const;
-    int GetNumberOfSpatialDimensions();
-    ///Writes the scalar range to the provided array, which must have room for two doubles
-    void GetScalarRange(double* range);
-    unsigned long GetActualMemorySize();
-    std::vector<double> GetSpacing();
-    std::vector<double> GetOrigin() const;
-    std::vector<int> GetSize();
-    std::string GetScalarTypeAsString();
-    int GetNumberOfScalarComponents();
-    int GetScalarSize();
-    bool IsTimeSequence() {
-        return mVtkImages.size()>1;
-    }
+  void Init();
+  void Reset();
+  template<class TItkImageType> void AddItkImage(TItkImageType *input);
+  void AddVtkImage(vtkImageData* input);
+  const std::vector<vtkImageData*>& GetVTKImages();
+  vtkImageData* GetFirstVTKImageData();
+  int GetNumberOfDimensions() const;
+  int GetNumberOfSpatialDimensions();
+  void GetScalarRange(double* range);
+  template<class TPixelType, unsigned int VImageDimension> void ComputeScalarRangeBase(itk::Image<TPixelType,VImageDimension> *input);
+  template<class TPixelType, unsigned int VImageDimension> void ComputeScalarRange(DimensionDispatchBase, itk::Image<TPixelType,VImageDimension> *input);
+  template<class TPixelType, unsigned int VImageDimension> void ComputeScalarRange(DimensionDispatch< 1 >, itk::Image<TPixelType,VImageDimension> *input);
+  unsigned long GetActualMemorySize();
+  std::vector<double> GetSpacing();
+  std::vector<double> GetOrigin() const;
+  std::vector<int> GetSize();
+  std::vector< std::vector<double> > GetDirection();
+  std::string GetScalarTypeAsITKString();
+  int GetNumberOfScalarComponents();
+  int GetScalarSize();
+  bool IsTimeSequence() const;
+  bool IsScalarTypeInteger();
+  bool IsScalarTypeInteger(int t);
+  const std::vector< vtkSmartPointer<vtkTransform> >& GetTransform();
+  void InitializeTransform();
+  void SetTimeSpacing(double s) { mTimeSpacing = s; }
+  void SetTimeOrigin(double o) { mTimeOrigin = o; }
+  bool HaveSameSizeAndSpacingThan(vvImage * other);
+  //META DATA
+  itk::MetaDataDictionary* GetFirstMetaDataDictionary();
 
 private:
-    vvImage();
-    ~vvImage();
-    std::vector<vtkImageData*> mVtkImages;
+  vvImage();
+  ~vvImage();
+
+  std::vector< ConverterPointer > mItkToVtkConverters;
+  std::vector< vtkImageData* > mVtkImages;
+  std::vector< vtkSmartPointer<vtkTransform> > mTransform;
+  //META DATA
+  std::vector< itk::MetaDataDictionary* > mDictionary;
 
+  double mTimeOrigin;
+  double mTimeSpacing;
+  unsigned int mImageDimension;
+  double mrange[2];
 };
+//------------------------------------------------------------------------------
+
+#include "vvImage.txx"
 
 #endif