]> Creatis software - creaImageIO.git/blob - src/creaImageIODicomImageReader2.h
08b01f3a8ca925d8504f60eca270c75f073be2ac
[creaImageIO.git] / src / creaImageIODicomImageReader2.h
1 #ifndef __creaImageIODicomImageReader_h_INCLUDED__
2 #define __creaImageIODicomImageReader_h_INCLUDED__
3
4
5 #include <creaImageIOAbstractImageReader.h>
6 #if defined(USE_GDCM2)
7 #include <gdcmReader.h>
8 #include <vtkGDCMImageReader.h>
9 #include <gdcmScanner.h>
10 #endif
11
12 class vtkGDCMImageReader;
13
14 namespace creaImageIO
15 {
16
17
18   /**
19    * \ingroup IO
20    */
21   
22   //=====================================================================
23   /// Concrete image reader for DICOM images 
24   class DicomImageReader : virtual public AbstractImageReader
25   {
26   public:
27     DicomImageReader();
28     virtual ~DicomImageReader();
29
30         /// Add file extensions read by the reader
31     virtual void PushBackExtensions(std::vector<std::string>&);
32         /// Test if file is read by this reader
33     virtual bool CanRead(const std::string& filename);
34         /// return for a file a 2D VTkImage
35     virtual vtkImageData* ReadImage(const std::string& filename);
36         /// Read the attributes for a file
37     virtual void ReadAttributes(const std::string& filename, 
38                                 tree::AttributeMapType& attr);
39         void ReadAttributes2(const std::string& filename, 
40                                 tree::AttributeMapType& attr);
41
42   private:
43           const std::string GetStringValueFromTag( const gdcm::DataElement& ds);
44           vtkGDCMImageReader *mReader;
45           gdcm::Scanner mscan;
46           bool b_loaded;
47         struct deleter
48         {
49                 void operator()(gdcm::File* p)
50                 {
51                         delete p;
52                 }
53         };
54         friend struct deleter;
55   };
56   //=====================================================================
57
58
59
60 } // namespace creaImageIO
61
62
63
64 #endif // #ifndef __creaImageIODicomImageReader_h_INCLUDED__