Computer Assited Medical Intervention Tool Kit  version 4.0
DicomParser.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * $CAMITK_LICENCE_BEGIN$
3  *
4  * CamiTK - Computer Assisted Medical Intervention ToolKit
5  * (c) 2001-2016 Univ. Grenoble Alpes, CNRS, TIMC-IMAG UMR 5525 (GMCAO)
6  *
7  * Visit http://camitk.imag.fr for more information
8  *
9  * This file is part of CamiTK.
10  *
11  * CamiTK is free software: you can redistribute it and/or modify
12  * it under the terms of the GNU Lesser General Public License version 3
13  * only, as published by the Free Software Foundation.
14  *
15  * CamiTK is distributed in the hope that it will be useful,
16  * but WITHOUT ANY WARRANTY; without even the implied warranty of
17  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
18  * GNU Lesser General Public License version 3 for more details.
19  *
20  * You should have received a copy of the GNU Lesser General Public License
21  * version 3 along with CamiTK. If not, see <http://www.gnu.org/licenses/>.
22  *
23  * $CAMITK_LICENCE_END$
24  ****************************************************************************/
25 
26 #ifndef DICOMPARSER_H
27 #define DICOMPARSER_H
28 
29 // CamiTK includes
30 #include <DicomSerie.h>
31 
32 // Qt includes
33 #include <QMap>
34 #include <QList>
35 #include <QString>
36 
37 // C++ includes
38 #include <stdlib.h>
39 #include <vector>
40 
41 
50 class DicomParser {
51 
52 public:
53 
55 
57  virtual ~DicomParser() {};
58 
64  static QList<DicomSerie*> parseDirectory(const QString & directory);
65 
71  static double getZSpacing(const std::vector<std::string> & serieFileNames);
72 
73 private:
79  static QList<QString> stdListOfStringToQt(const std::vector< std::string > & inputList);
80 
86  static std::vector< std::string > qtListOfStringToStd(const QList<QString> & inputList);
87 
93  static QDate getAcquisitionDate(const std::vector<std::string> & serieFileNames);
94 
100  static QTime getAcquisitionTime(const std::vector<std::string> & serieFileNames);
101 
107  static QString getPatientName(const std::vector<std::string> & serieFileNames);
108 
114  static QString getSerieName(const std::vector<std::string> & serieFileNames);
115 
121  static QString getSerieDescription(const std::vector<std::string> & serieFileNames);
122 
128  static QString getStudyName(const std::vector<std::string> & serieFileNames);
129 
130 };
131 
132 #endif // DICOMPARSER_H
133 
static QList< DicomSerie * > parseDirectory(const QString &directory)
Parse the input directory for DICOM series.
Definition: DicomParser.cpp:36
static QDate getAcquisitionDate(const std::vector< std::string > &serieFileNames)
Retrieve the SERIES acquisition date.
Definition: DicomParser.cpp:120
static QString getStudyName(const std::vector< std::string > &serieFileNames)
Retrieve the study name.
Definition: DicomParser.cpp:183
static QString getSerieName(const std::vector< std::string > &serieFileNames)
Retrieve the series name.
Definition: DicomParser.cpp:159
static QList< QString > stdListOfStringToQt(const std::vector< std::string > &inputList)
Convert a simple std list of string into a QList of QString.
Definition: DicomParser.cpp:195
static std::vector< std::string > qtListOfStringToStd(const QList< QString > &inputList)
Convert a QList of QString into a std list of string.
Definition: DicomParser.cpp:205
static QString getPatientName(const std::vector< std::string > &serieFileNames)
Retrieve the patient name information from the input files.
Definition: DicomParser.cpp:146
DicomParser()
Definition: DicomParser.h:54
static QTime getAcquisitionTime(const std::vector< std::string > &serieFileNames)
Retrieve the SERIES acquisition time.
Definition: DicomParser.cpp:133
DicomParser allows one to parse a directory of DICOM files looking for studies and series...
Definition: DicomParser.h:50
static QString getSerieDescription(const std::vector< std::string > &serieFileNames)
Retrieve the series description.
Definition: DicomParser.cpp:171
static double getZSpacing(const std::vector< std::string > &serieFileNames)
Retrieve the DICOM image file Z spacing attribute (commonly known as spacing between slices) ...
Definition: DicomParser.cpp:215
virtual ~DicomParser()
Default Destructor.
Definition: DicomParser.h:57