X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDicomDirStudy.h;h=4b4d12e6f9a1a993ce2eb7617ec2b8c9a912fc3e;hb=56ad78cdf3b5de32f0a94a38cd32ddc9f403ffc3;hp=5a083f28ff76d39f7dd20f9e189371da621cbd1d;hpb=1bae8d2ba47d1b9cc8acfb7b5ab82026e48275dd;p=gdcm.git diff --git a/src/gdcmDicomDirStudy.h b/src/gdcmDicomDirStudy.h index 5a083f28..4b4d12e6 100644 --- a/src/gdcmDicomDirStudy.h +++ b/src/gdcmDicomDirStudy.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDicomDirStudy.h,v $ Language: C++ - Date: $Date: 2004/11/25 15:46:11 $ - Version: $Revision: 1.13 $ + 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 @@ -16,52 +16,104 @@ =========================================================================*/ -#ifndef GDCMDICOMDIRSTUDY_H -#define GDCMDICOMDIRSTUDY_H +#ifndef _GDCMDICOMDIRSTUDY_H_ +#define _GDCMDICOMDIRSTUDY_H_ #include "gdcmDicomDirObject.h" -#include "gdcmDicomDirSerie.h" -namespace gdcm -{ +namespace GDCM_NAME_SPACE +{ +class DicomDirSerie; +class DicomDirVisit; //----------------------------------------------------------------------------- typedef std::list ListDicomDirSerie; + +// For future use (Full DICOMDIR) +typedef std::list ListDicomDirVisit; +/* +typedef std::list ListDicomDirResult; +typedef std::list ListDicomDirStudyComponent; +*/ //----------------------------------------------------------------------------- +/** + * \brief describes a STUDY within a within a PATIENT + * (DicomDirPatient) of a given DICOMDIR (DicomDir) + */ class GDCM_EXPORT DicomDirStudy : public DicomDirObject { + gdcmTypeMacro(DicomDirStudy); + public: - DicomDirStudy(SQItem *s, TagDocEntryHT *ptagHT); - DicomDirStudy(TagDocEntryHT *ptagHT); +/// \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, bool insideMetaElements,bool insideSequence ); + + // 'Serie' methods + DicomDirSerie *NewSerie(); + /// Adds a gdcm::DicomDirSerie to a gdcm::DicomDirStudy + void AddSerie(DicomDirSerie *obj) { Series.push_back(obj); } + void ClearSerie(); + DicomDirSerie *GetFirstSerie(); + DicomDirSerie *GetNextSerie(); + DicomDirSerie *GetLastSerie(); + /// returns the number of Series currently held in the gdcm::DicomDirStudy + int GetNumberOfSeries() { return Series.size();} + + // 'Visit' methods + DicomDirVisit *NewVisit(); + /// 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(); + DicomDirResult *GetLastResult(); + DicomDirStudyComponent *GetFirstStudyComponent(); + DicomDirStudyComponent *GetNextStudyComponent(); + DicomDirStudyComponent *GetLastStudyComponent(); +*/ + + virtual void Copy(DocEntrySet *set); + +protected: + DicomDirStudy(bool empty=false); ~DicomDirStudy(); - void Print(std::ostream &os = std::cout); - void WriteContent(std::ofstream *fp, FileType t); - - /** - * \ingroup DicomDirStudy - * \brief returns the SERIE chained List for this STUDY. - */ - ListDicomDirSerie const &GetDicomDirSeries() const { return Series; }; - - /** - * \ingroup DicomDirStudy - * \brief adds the passed SERIE to the SERIE chained List for this STUDY. - */ - void AddDicomDirSerie(DicomDirSerie *obj) { Series.push_back(obj); }; - - /** - * \ingroup DicomDirStudy - * \brief TODO - */ - DicomDirSerie* NewSerie(); - private: -/** -* \brief chained list of DicomDirSeries (to be exploited recursively) -*/ + /// chained list of DicomDirSeries (to be exploited hierarchicaly) ListDicomDirSerie Series; + /// iterator on the DicomDirSeries of the current DicomDirStudy + ListDicomDirSerie::iterator ItSerie; + + /// 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; + /// iterator on the DicomDirResults of the current DicomDirStudy + ListDicomDirResult::iterator ItResult; + + /// chained list of DicomDirStudyComponents(single level) + ListDicomDirStudyComponent StudyComponents; + /// iterator on the DicomDirStudyComponents of the current DicomDirStudy + ListDicomDirStudyComponent::iterator ItStudyComponents; +*/ }; } // end namespace gdcm