Computer Assited Medical Intervention Tool Kit  version 5.0
DicomComponentExtension.h
Go to the documentation of this file.
1 /*****************************************************************************
2  * $CAMITK_LICENCE_BEGIN$
3  *
4  * CamiTK - Computer Assisted Medical Intervention ToolKit
5  * (c) 2001-2021 Univ. Grenoble Alpes, CNRS, Grenoble INP, TIMC, 38000 Grenoble, France
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 DICOMCOMPONENTEXTENSION_H
27 #define DICOMCOMPONENTEXTENSION_H
28 
29 #include <QObject>
30 
31 #include<ComponentExtension.h>
32 
33 namespace camitk {
34 class Component;
35 }
36 
37 class DicomDialog;
38 class DicomDialogEntry;
39 
40 #include "DicomSeries.h"
41 
42 
53  Q_OBJECT
54  Q_INTERFACES(camitk::ComponentExtension)
55  Q_PLUGIN_METADATA(IID "fr.imag.camitk.imaging.component.dicom")
56 
57 public:
60 
62  virtual QString getName() const override {
63  return "DICOM";
64  };
65 
67  virtual QString getDescription() const override {
68  return "This extension adds support for DICOM single image file (.dcm) and series thanks to the gdcm library";
69  };
70 
71 
75  virtual QStringList getFileExtensions() const override;
76 
80  virtual camitk::Component* open(const QString&) override;
81 
86  virtual bool save(camitk::Component*) const override;
87 
89  virtual bool hasDataDirectory() const override;
90 
91 protected:
93  virtual ~DicomComponentExtension() = default;
94 
95 private:
99 
102 
104  QList<DicomSeries*> seriesParsed;
105 
107  QList<DicomDialogEntry*> seriesDialogEntries;
108 
109 };
110 
111 #endif // DICOMCOMPONENTEXTENSION
112 
DicomSeries::getPatientName
QString getPatientName() const
Definition: DicomSeries.cpp:53
DicomComponentExtension::seriesDialogEntries
QList< DicomDialogEntry * > seriesDialogEntries
The series dialog entries representation in the VIEW.
Definition: DicomComponentExtension.h:107
DicomSeries::getStudyName
QString getStudyName() const
Definition: DicomSeries.cpp:44
DicomDialogEntry::setSelected
void setSelected(bool value)
Definition: DicomDialogEntry.cpp:61
DicomComponentExtension::dialog
DicomDialog * dialog
The dialog that asks the user which dicom image files he wishes to open.
Definition: DicomComponentExtension.h:101
DicomDialogEntry.h
DicomComponentExtension::open
virtual camitk::Component * open(const QString &) override
Open a single .dcm image or a directory containing files to be read This method may throw an AbortExc...
Definition: DicomComponentExtension.cpp:55
DicomComponentExtension::seriesParsed
QList< DicomSeries * > seriesParsed
The different Dicom SERIES parsed.
Definition: DicomComponentExtension.h:104
DicomDialogEntry::setSeriesName
void setSeriesName(QString name)
Definition: DicomDialogEntry.cpp:73
camitk::ComponentExtension
This class describes what is a generic Component extension. To add a ComponentExtension to CamiTK cor...
Definition: ComponentExtension.h:83
DicomSeries::getSeriesName
QString getSeriesName() const
Definition: DicomSeries.cpp:47
DicomComponent.h
DicomDialogEntry::setSeriesDescription
void setSeriesDescription(QString name)
Definition: DicomDialogEntry.cpp:76
DicomSeries::getSeriesDescription
QString getSeriesDescription() const
Definition: DicomSeries.cpp:50
DicomDialogEntry::getStudyName
QString getStudyName()
Definition: DicomDialogEntry.cpp:47
DicomSeries.h
DicomComponentExtension::getName
virtual QString getName() const override
Method returning the component extension name.
Definition: DicomComponentExtension.h:62
DicomDialogEntry::setAcquisitionDate
void setAcquisitionDate(QDate date)
Definition: DicomDialogEntry.cpp:64
DicomSeries::getAcquisitionDate
QDate getAcquisitionDate() const
Definition: DicomSeries.cpp:38
camitk::ComponentExtension::ComponentExtension
ComponentExtension()
protected constructor,
Definition: ComponentExtension.cpp:58
DicomComponentExtension.h
DicomDialogEntry::setAcquisitionTime
void setAcquisitionTime(QTime time)
Definition: DicomDialogEntry.cpp:67
DicomComponentExtension::hasDataDirectory
virtual bool hasDataDirectory() const override
this method returns true as this component loads images from a directory (not a single file)
Definition: DicomComponentExtension.cpp:112
DicomDialogEntry::getSeriesName
QString getSeriesName()
Definition: DicomDialogEntry.cpp:50
ComponentExtension.h
DicomDialog
Dialog class to select the DICOM series to open, using a GUI.
Definition: DicomDialog.h:46
DicomSeries::getAcquisitionTime
QTime getAcquisitionTime() const
Definition: DicomSeries.cpp:41
DicomDialog.h
DicomComponentExtension::getDescription
virtual QString getDescription() const override
Method returning the component extension description.
Definition: DicomComponentExtension.h:67
DicomComponentExtension
DICOM image Component manager.
Definition: DicomComponentExtension.h:52
DicomComponentExtension::DicomComponentExtension
DicomComponentExtension()
Constructor.
Definition: DicomComponentExtension.h:59
DicomComponent
DICOM Component represents a volumic image of a DICOM SERIES with its corresponding tags information ...
Definition: DicomComponent.h:45
DicomParser.h
DicomParser::parseDirectory
static QList< DicomSeries * > parseDirectory(const QString &directory)
Parse the input directory for DICOM series.
Definition: DicomParser.cpp:36
Component
A component is something that composed something and could also be a part of something.
Definition: modeling/libraries/pml/Component.h:48
DicomComponentExtension::save
virtual bool save(camitk::Component *) const override
Save a given Component (does not have to be top-level) into one of the currently managed format.
Definition: DicomComponentExtension.cpp:102
DicomDialogEntry::setPatientName
void setPatientName(QString name)
Definition: DicomDialogEntry.cpp:79
DicomDialogEntry
This class represents a line in the Dialog box of the DICOM series the user is prompted to open.
Definition: DicomDialogEntry.h:41
DicomDialogEntry::setStudyName
void setStudyName(QString name)
Definition: DicomDialogEntry.cpp:70
DicomComponentExtension::~DicomComponentExtension
virtual ~DicomComponentExtension()=default
Destructor.
DicomSeries
DicomSeries is a CamiTK high level class to represent a DICOM SERIES This class encapsulates GDCM obj...
Definition: DicomSeries.h:49
DicomComponentExtension::getFileExtensions
virtual QStringList getFileExtensions() const override
Get the list of managed extensions (each file with an extension in the list can be loaded by this ext...
Definition: DicomComponentExtension.cpp:47
camitk::Component
A Component represents something that could be included in the explorer view, the interactive 3D view...
Definition: sdk/libraries/core/component/Component.h:302
Application.h
DicomComponentExtension::lastOpenedComponent
camitk::Component * lastOpenedComponent
Last opened component.
Definition: DicomComponentExtension.h:98
camitk
Definition: Action.cpp:35