X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;f=src%2FgdcmDicomDirElement.h;h=7ed69983be83857689f6fdb1e9b19333370d7d5c;hb=f540ed5835e7b89478e6048a577d494c0e156f2a;hp=33b3a34f29e6826d12a67f36622a389038715960;hpb=0a9f25290006bdee6be492179f8b0dae7ba1c598;p=gdcm.git diff --git a/src/gdcmDicomDirElement.h b/src/gdcmDicomDirElement.h index 33b3a34f..7ed69983 100644 --- a/src/gdcmDicomDirElement.h +++ b/src/gdcmDicomDirElement.h @@ -3,8 +3,8 @@ Program: gdcm Module: $RCSfile: gdcmDicomDirElement.h,v $ Language: C++ - Date: $Date: 2005/01/24 14:14:11 $ - Version: $Revision: 1.22 $ + Date: $Date: 2006/04/11 16:03:26 $ + Version: $Revision: 1.38 $ Copyright (c) CREATIS (Centre de Recherche et d'Applications en Traitement de l'Image). All rights reserved. See Doc/License.txt or @@ -19,7 +19,8 @@ #ifndef GDCMDICOMDIRELEMENT_H #define GDCMDICOMDIRELEMENT_H -#include "gdcmCommon.h" +#include "gdcmRefCounter.h" +#include "gdcmVRKey.h" #include @@ -27,82 +28,109 @@ namespace gdcm { //----------------------------------------------------------------------------- -GDCM_EXPORT typedef struct -{ - /// DicomGroup number - unsigned short int Group; - /// DicomElement number - unsigned short int Elem; - /// value (coded as a std::string) of the Element - std::string Value; -} Element; - -typedef std::list ListDicomDirElem; -typedef std::list ListDicomDirMetaElem; -typedef std::list ListDicomDirPatientElem; -typedef std::list ListDicomDirStudyElem; -typedef std::list ListDicomDirSerieElem; -typedef std::list ListDicomDirImageElem; + +typedef std::list ListDicomDirElem; +typedef std::list ListDicomDirMetaElem; +typedef std::list ListDicomDirPatientElem; +typedef std::list ListDicomDirStudyElem; +typedef std::list ListDicomDirVisitElem; +typedef std::list ListDicomDirSerieElem; +typedef std::list ListDicomDirImageElem; + +// For future use (Full DICOMDIR) + +/* +typedef std::list ListDicomDirResultElem; +typedef std::list ListDicomDirStudyComponentElem; + +typedef std::list ListDicomDirOverlayElem; +typedef std::list ListDicomDirModalityLutElem; +typedef std::list ListDicomDirModalityLutElem; +typedef std::list ListDicomDirCurveElem; +typedef std::list ListDicomDirStoredPrintElem; +typedef std::list ListDicomDirRtDoseElem; +typedef std::list ListDicomDirRtStructureSetElem; +typedef std::list ListDicomDirRtPlanElem; +typedef std::list ListDicomDirRtTreatRecordElem; +typedef std::list ListDicomDirPresentationElem; +typedef std::list ListDicomDirSrDocumentElem; +typedef std::list ListDicomDirKeyObjectDocElem; +typedef std::list ListDicomDirSpectroscopyElem; +typedef std::list ListDicomDirRawDataElem; +typedef std::list ListDicomDirRegistrationElem; +typedef std::list ListDicomDirFiducialElem; +*/ //----------------------------------------------------------------------------- /** - * \ingroup DicomDirElement - * \brief Represents elements contained in a DicomDir - * class for the chained lists from the file 'Dicts/DicomDir.dic' + * \brief Represents elements contained in a DicomDir class + * for the chained lists from the file 'Dicts/DicomDir.dic' */ -class GDCM_EXPORT DicomDirElement +class GDCM_EXPORT DicomDirElement : public RefCounter { + gdcmTypeMacro(DicomDirElement); + public: - DicomDirElement(); - ~DicomDirElement(); +/// \brief Contructs a DicomDirElement with a RefCounter + static DicomDirElement *New() {return new DicomDirElement();} - /** + /** * \brief canonical Printer */ - void Print(std::ostream &os); + virtual void Print(std::ostream &os = std::cout, + std::string const &indent = "" ); /** - * \ingroup DicomDirElement * \brief returns a reference to the chained List * related to the META Elements of a DICOMDIR. */ ListDicomDirMetaElem const &GetDicomDirMetaElements() const - { return DicomDirMetaList; }; + { return DicomDirMetaList; } /** - * \ingroup DicomDirElement * \brief returns a reference to the chained List * related to the PATIENT Elements of a DICOMDIR. */ ListDicomDirPatientElem const &GetDicomDirPatientElements() const - { return DicomDirPatientList; }; + { return DicomDirPatientList; } /** - * \ingroup DicomDirElement * \brief returns a reference to the chained List * related to the STUDY Elements of a DICOMDIR. */ ListDicomDirStudyElem const &GetDicomDirStudyElements() const - { return DicomDirStudyList; }; + { return DicomDirStudyList; } /** - * \ingroup DicomDirElement + * \brief returns a reference to the chained List + * related to the VISIT Elements of a DICOMDIR. + */ + ListDicomDirVisitElem const &GetDicomDirVisitElements() const + { return DicomDirVisitList; } + /** * \brief returns a reference to the chained List * related to the SERIE Elements of a DICOMDIR. */ ListDicomDirSerieElem const &GetDicomDirSerieElements() const - { return DicomDirSerieList; }; + { return DicomDirSerieList; } /** - * \ingroup DicomDirElement * \brief returns a reference to the chained List * related to the IMAGE Elements of a DICOMDIR. */ ListDicomDirImageElem const &GetDicomDirImageElements() const - { return DicomDirImageList; }; + { return DicomDirImageList; } // Public method to add an element - bool AddEntry(DicomDirType type, Element const &elem); + bool AddEntry(DicomDirType type, DicomElement const &elem); + + // Only one instance of ddElem + void AddDicomDirElement(DicomDirType type, + uint16_t group, uint16_t elem, VRKey vr); + +protected: + DicomDirElement(); + ~DicomDirElement(); private: /// Elements chained list, related to the MetaElements of DICOMDIR @@ -111,6 +139,8 @@ private: ListDicomDirPatientElem DicomDirPatientList; /// Elements chained list, related to the StudyElements of DICOMDIR ListDicomDirStudyElem DicomDirStudyList; + /// Elements chained list, related to the VisitElements of DICOMDIR + ListDicomDirVisitElem DicomDirVisitList; /// Elements chained list, related to the SerieElements of DICOMDIR ListDicomDirSerieElem DicomDirSerieList; /// Elements chained list, related to the ImageElements of DICOMDIR