Program: gdcm
Module: $RCSfile: gdcmDicomDirSerie.h,v $
Language: C++
- Date: $Date: 2005/02/07 14:48:34 $
- Version: $Revision: 1.28 $
+ Date: $Date: 2007/08/22 16:14:03 $
+ Version: $Revision: 1.37 $
Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de
l'Image). All rights reserved. See Doc/License.txt or
=========================================================================*/
-#ifndef GDCMDICOMDIRSERIE_H
-#define GDCMDICOMDIRSERIE_H
+#ifndef _GDCMDICOMDIRSERIE_H_
+#define _GDCMDICOMDIRSERIE_H_
#include "gdcmDicomDirObject.h"
-namespace gdcm
+namespace GDCM_NAME_SPACE
{
class DicomDirImage;
+class DicomDirPrivate;
+
//-----------------------------------------------------------------------------
typedef std::list<DicomDirImage *> ListDicomDirImage;
-
+typedef std::list<DicomDirPrivate *> ListDicomDirPrivate;
//-----------------------------------------------------------------------------
/**
* \brief describes a SERIE within a within a STUDY
*/
class GDCM_EXPORT DicomDirSerie : public DicomDirObject
{
+ gdcmTypeMacro(DicomDirSerie);
+
public:
- DicomDirSerie(bool empty=false);
- ~DicomDirSerie();
+/// \brief Constructs a DicomDirSerie with a RefCounter
+ static DicomDirSerie *New(bool empty=false) {return new DicomDirSerie(empty);}
void Print( std::ostream &os = std::cout, std::string const &indent = "" );
- void WriteContent( std::ofstream *fp, FileType t );
+ void WriteContent( std::ofstream *fp, FileType t, bool insideMetaElements );
- // Image methods
+ // 'Image' methods
DicomDirImage *NewImage();
/// Add a new gdcm::DicomDirImage to the Serie
- void AddImage(DicomDirImage *obj) { Images.push_back(obj); };
+ void AddImage(DicomDirImage *obj) { Images.push_back(obj); }
void ClearImage();
DicomDirImage *GetFirstImage();
DicomDirImage *GetNextImage();
+ /// returns the number of Images currently held in the gdcm::DicomDirSerie
+ int GetNumberOfImages() { return Images.size();}
+
+ // 'Private' methods (For SIEMENS 'CSA non image')
+ DicomDirPrivate *NewPrivate();
+ /// Add a new gdcm::DicomDirPrivate to the Serie
+ void AddPrivate(DicomDirPrivate *obj) { Privates.push_back(obj); }
+ void ClearPrivate();
+
+ DicomDirPrivate *GetFirstPrivate();
+ DicomDirPrivate *GetNextPrivate();
+ /// returns the number of 'Privates' currently held in the gdcm::DicomDirSerie
+ int GetNumberOfPrivates() { return Privates.size();}
+
+ virtual void Copy(DocEntrySet *set);
+
+protected:
+ DicomDirSerie(bool empty=false);
+ ~DicomDirSerie();
private:
-
///chained list of DicomDirImages (to be exploited recursively)
ListDicomDirImage Images;
/// iterator on the DicomDirImages of the current DicomDirSerie
ListDicomDirImage::iterator ItImage;
+ ///chained list of DicomDirPrivates (to be exploited recursively)
+ ListDicomDirPrivate Privates;
+ /// iterator on the DicomDirPrivates of the current DicomDirSerie
+ ListDicomDirPrivate::iterator ItPrivate;
/*
-// for future use :
+// for future use (Full DICOMDIR):
/// chained list of DicomDirOverlays(single level)
ListDicomDirOverlay Overlays;
/// iterator on the DicomDirOverlays of the current DicomDirSerie
ListDicomDirOverlay::iterator ItOverlay;
- /// chained list of DicomDirModalityLuts(single level)
- ListDicomDirModalityLut ModalityLuts;
- /// iterator on the DicomDirModalityLuts of the current DicomDirSerie
- ListDicomDirModalityLut::iterator ItModalityLut;
-
/// chained list of DicomDirModalityLuts(single level)
ListDicomDirModalityLut ModalityLuts;
/// iterator on the DicomDirModalityLuts of the current DicomDirSerie