00001
00002
00003
00004
00005
00006
00007
00008
00009
00010
00011
00012
00013
00014
00015
00016
00017
00018
00019 #ifndef __vtkGdcmWriter_h
00020 #define __vtkGdcmWriter_h
00021
00022 #include "gdcmCommon.h"
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
00072 vtkLookupTable *LookupTable;
00073 int WriteType;
00074
00075
00076 std::string UIDPrefix;
00077 std::string StudyInstanceUID;
00078 std::string SeriesInstanceUID;
00079 std::string FrameOfReferenceInstanceUID;
00080
00081 };
00082
00083
00084 #endif