Go to the documentation of this file.00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019
00020
00021
00022
00023
00024
00025
00026
00027
00028
00029
00030
00031
00032
00033 #ifndef __cmtkTransformedVolumeAxes_h_included_
00034 #define __cmtkTransformedVolumeAxes_h_included_
00035
00036 #include <cmtkconfig.h>
00037
00038 #include <Base/cmtkVector3D.h>
00039 #include <Base/cmtkAffineXform.h>
00040 #include <Base/cmtkParametricPlane.h>
00041 #include <Base/cmtkUniformVolume.h>
00042
00043 namespace
00044 cmtk
00045 {
00046
00049
00061 class TransformedVolumeAxes
00062 {
00063 public:
00065 typedef TransformedVolumeAxes Self;
00066
00068 typedef SmartPointer<Self> SmartPtr;
00069
00087 TransformedVolumeAxes( const UniformVolume& volume, const AffineXform* xform = NULL, const Types::Coordinate* deltas = NULL, const Types::Coordinate* otherOrigin = NULL );
00088
00100 TransformedVolumeAxes( const UniformVolume& volume, const ParametricPlane& mirrorPlane, const Types::Coordinate* deltas = NULL );
00101
00103 ~TransformedVolumeAxes();
00104
00106 const Vector3D* operator[]( const size_t index ) const
00107 {
00108 return this->m_Hash[index];
00109 }
00110
00112 const FixedVector<3,int>& Dims() const
00113 {
00114 return this->m_Dims;
00115 }
00116
00117 private:
00119 FixedVector<3,UniformVolume::SpaceVectorType*> m_Hash;
00120
00122 FixedVector<3,int> m_Dims;
00123
00125 void MakeHash( const UniformVolume& volume, const UniformVolume::SpaceVectorType& offset, const UniformVolume::SpaceVectorType& dX, const UniformVolume::SpaceVectorType& dY, const UniformVolume::SpaceVectorType& dZ );
00126
00127 };
00128
00130
00131 }
00132
00133 #endif // #ifndef __cmtkTransformedVolumeAxes_h_included_