Program: gdcm
Module: $RCSfile: gdcmDicomDirStudy.h,v $
Language: C++
- Date: $Date: 2005/07/08 19:07:12 $
- Version: $Revision: 1.27 $
+ Date: $Date: 2007/08/29 15:30:49 $
+ 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 GDCMDICOMDIRSTUDY_H
-#define GDCMDICOMDIRSTUDY_H
+#ifndef _GDCMDICOMDIRSTUDY_H_
+#define _GDCMDICOMDIRSTUDY_H_
#include "gdcmDicomDirObject.h"
-namespace gdcm
+namespace GDCM_NAME_SPACE
{
class DicomDirSerie;
class DicomDirVisit;
*/
class GDCM_EXPORT DicomDirStudy : public DicomDirObject
{
+ gdcmTypeMacro(DicomDirStudy);
+
public:
- DicomDirStudy(bool empty=false);
- ~DicomDirStudy();
+/// \brief Constructs a DicomDirStudy with a RefCounter
+ static DicomDirStudy *New(bool empty=false) {return new DicomDirStudy(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,bool insideSequence );
- // Serie methods
+ // 'Serie' methods
DicomDirSerie *NewSerie();
- /// Adds a gdcm::DicomDirSerie to a Study
- void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); };
+ /// Adds a gdcm::DicomDirSerie to a gdcm::DicomDirStudy
+ void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); }
void ClearSerie();
-
DicomDirSerie *GetFirstSerie();
DicomDirSerie *GetNextSerie();
DicomDirSerie *GetLastSerie();
-
-
- // for future use (Full DICOMDIR)
-
+ /// returns the number of Series currently held in the gdcm::DicomDirStudy
+ int GetNumberOfSeries() { return Series.size();}
+
+ // 'Visit' methods
DicomDirVisit *NewVisit();
- void AddVisit(DicomDirVisit *obj) { Visits.push_back(obj); };
+ /// Adds a gdcm::DicomDirVisit to a gdcm::DicomDirStudy
+ void AddVisit(DicomDirVisit *obj) { Visits.push_back(obj); }
void ClearVisit();
DicomDirVisit *GetFirstVisit();
DicomDirVisit *GetNextVisit();
DicomDirVisit *GetLastVisit();
+ /// returns the number of Visit currently held in the gdcm::DicomDirStudy
+ int GetNumberOfVisits() { return Visits.size();}
+
+ // for future use (Full DICOMDIR)
/*
DicomDirResult *GetFirstResult();
DicomDirResult *GetNextResult();
DicomDirStudyComponent *GetNextStudyComponent();
DicomDirStudyComponent *GetLastStudyComponent();
*/
-private:
+ virtual void Copy(DocEntrySet *set);
+
+protected:
+ DicomDirStudy(bool empty=false);
+ ~DicomDirStudy();
+
+private:
/// chained list of DicomDirSeries (to be exploited hierarchicaly)
ListDicomDirSerie Series;
/// iterator on the DicomDirSeries of the current DicomDirStudy
ListDicomDirSerie::iterator ItSerie;
-
- // for future use (Full DICOMDIR)
-
/// chained list of DicomDirVisits(single level)
ListDicomDirVisit Visits;
/// iterator on the DicomDirVisits of the current DicomDirStudy
ListDicomDirVisit::iterator ItVisit;
+
+
+ // for future use (Full DICOMDIR)
/*
/// chained list of DicomDirResults(single level)
ListDicomDirResult Results;