Main Page | Namespace List | Class Hierarchy | Alphabetical List | Class List | File List | Namespace Members | Class Members | File Members | Related Pages

vtkGdcmWriter.h

Go to the documentation of this file.
00001 /*=========================================================================
00002                                                                                 
00003   Program:   gdcm
00004   Module:    $RCSfile: vtkGdcmWriter.h,v $
00005   Language:  C++
00006   Date:      $Date: 2005/01/28 10:07:35 $
00007   Version:   $Revision: 1.5 $
00008                                                                                 
00009   Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
00010   l'Image). All rights reserved. See Doc/License.txt or
00011   http://www.creatis.insa-lyon.fr/Public/Gdcm/License.html for details.
00012                                                                                 
00013      This software is distributed WITHOUT ANY WARRANTY; without even
00014      the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
00015      PURPOSE.  See the above copyright notices for more information.
00016                                                                                 
00017 =========================================================================*/
00018                                                                                 
00019 #ifndef __vtkGdcmWriter_h
00020 #define __vtkGdcmWriter_h
00021 
00022 #include "gdcmCommon.h" // To avoid warnings concerning the std
00023 
00024 #include <vtkImageWriter.h>
00025 #include <vtkLookupTable.h>
00026 #include <string>
00027 
00028 //-----------------------------------------------------------------------------
00029 #define VTK_GDCM_WRITE_TYPE_EXPLICIT_VR 1
00030 #define VTK_GDCM_WRITE_TYPE_IMPLICIT_VR 2
00031 #define VTK_GDCM_WRITE_TYPE_ACR         3
00032 #define VTK_GDCM_WRITE_TYPE_ACR_LIBIDO  4
00033 
00034 //-----------------------------------------------------------------------------
00035 class VTK_EXPORT vtkGdcmWriter : public vtkImageWriter
00036 {
00037 public:
00038    static vtkGdcmWriter *New();
00039    vtkTypeRevisionMacro(vtkGdcmWriter, vtkImageWriter);
00040 
00041    void PrintSelf(ostream& os, vtkIndent indent);
00042 
00043    vtkSetObjectMacro(LookupTable,vtkLookupTable);
00044    vtkGetObjectMacro(LookupTable,vtkLookupTable);
00045 
00046    void SetWriteTypeToDcmImplVR()     { SetWriteType(VTK_GDCM_WRITE_TYPE_EXPLICIT_VR); };
00047    void SetWriteTypeToDcmExplVR()     { SetWriteType(VTK_GDCM_WRITE_TYPE_IMPLICIT_VR); };
00048    void SetWriteTypeToAcr()           { SetWriteType(VTK_GDCM_WRITE_TYPE_ACR); };
00049    void SetWriteTypeToAcrLibido()     { SetWriteType(VTK_GDCM_WRITE_TYPE_ACR_LIBIDO); };
00050    vtkSetMacro(WriteType,int);
00051    vtkGetMacro(WriteType,int);
00052    const char *GetWriteTypeAsString();
00053 
00054    void SetUIDPrefix(const char *prefix);
00055    const char *GetUIDPrefix();
00056 
00057    void NewStudyInstanceUID();
00058    void NewSeriesInstanceUID();
00059    void NewFrameOfReferenceInstanceUID();
00060 
00061 protected:
00062    vtkGdcmWriter();
00063    ~vtkGdcmWriter();
00064 
00065   virtual void RecursiveWrite(int axis, vtkImageData *image, ofstream *file);
00066   virtual void RecursiveWrite(int axis, vtkImageData *image, 
00067                               vtkImageData *cache, ofstream *file);
00068   void WriteDcmFile(char *fileName,vtkImageData *image);
00069 
00070 private:
00071 // Variables
00072    vtkLookupTable *LookupTable;
00073    int WriteType;
00074 
00075    //BTX
00076    std::string UIDPrefix;
00077    std::string StudyInstanceUID;
00078    std::string SeriesInstanceUID;
00079    std::string FrameOfReferenceInstanceUID;
00080    //ETX
00081 };
00082 
00083 //-----------------------------------------------------------------------------
00084 #endif

Generated on Thu Feb 10 22:18:01 2005 for gdcm by doxygen 1.3.6