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 protected:
00055 vtkGdcmWriter();
00056 ~vtkGdcmWriter();
00057
00058 virtual void RecursiveWrite(int axis, vtkImageData *image, ofstream *file);
00059 virtual void RecursiveWrite(int axis, vtkImageData *image,
00060 vtkImageData *cache, ofstream *file);
00061 void WriteDcmFile(char *fileName, vtkImageData *image);
00062
00063 private:
00064
00065 vtkLookupTable *LookupTable;
00066 int WriteType;
00067 };
00068
00069
00070 #endif