X-Git-Url: https://git.creatis.insa-lyon.fr/pubgit/?a=blobdiff_plain;ds=sidebyside;f=src%2FgdcmDicomDirElement.h;h=28d0e44a4333edc0a53d22ff307a7e3400316899;hb=46afb30d2d016a9b1581c7ee4ca96d614a35203c;hp=2e0b9c410c466842caa31b8671389f48f094ddb2;hpb=93748f382dadb5c9240c4156ce7bbe9dcc8da44f;p=gdcm.git diff --git a/src/gdcmDicomDirElement.h b/src/gdcmDicomDirElement.h index 2e0b9c41..28d0e44a 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/20 17:15:54 $ - Version: $Revision: 1.21 $ + Date: $Date: 2005/11/28 15:20:32 $ + Version: $Revision: 1.36 $ 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,7 @@ #ifndef GDCMDICOMDIRELEMENT_H #define GDCMDICOMDIRELEMENT_H -#include "gdcmCommon.h" +#include "gdcmCommandManager.h" #include @@ -27,82 +27,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 CommandManager { + 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 AddNewEntry(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); + +protected: + DicomDirElement(); + ~DicomDirElement(); private: /// Elements chained list, related to the MetaElements of DICOMDIR @@ -111,6 +138,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