]> Creatis software - clitk.git/blob - vv/vvQPacsConnection.h
simplify query/retrieve calls
[clitk.git] / vv / vvQPacsConnection.h
1 #ifndef __vvQPacsConnection_h_INCLUDED__
2 #define __vvQPacsConnection_h_INCLUDED__
3
4 #include <QTGUI/QWidget>
5 #include "ui_vvPacsConnection.h"
6 #include "gdcmCompositeNetworkFunctions.h"
7 #include <QtGui/QStandardItemModel.h>
8 #include <QtGui/QStringListModel.h>
9 #include <QFileDialog>
10 #include "vvDicomServerQueryFactory.h"
11
12   /**
13    * \ingroup GUI
14    */
15   //=====================================================================
16  //======================================================================
17
18 struct vvQuery{
19         gdcm::ERootType theRoot;
20         gdcm::EQueryLevel theLevel;
21         std::vector< std::pair<gdcm::Tag, std::string> > keys;
22 };
23
24   class vvQPacsConnection : public QDialog 
25   {
26           Q_OBJECT
27   public:
28           //vvQPacsConnection(){}    
29           vvQPacsConnection(QWidget *parent=0);
30     
31           ~vvQPacsConnection(){}
32         void refreshNetworks();
33         std::vector <std::string> getFileNames();
34
35 public slots:
36         void selectStudies(const QModelIndex &index);
37         void selectSeries(const QModelIndex &index);
38         void selectImages(const QModelIndex &index);
39   private slots:
40     void on_scanButton_clicked();
41         void on_clearButton_clicked();
42         void on_optionsButton_clicked();
43         void on_check_ModAll_clicked(bool state);
44         void on_importButton_clicked();
45  void chooseServer(int index);
46  void removeServer();
47  void modifyServer();
48
49   private :
50
51                  vvQuery getQueryPatient(const std::string i_patname, const std::string i_patid);
52
53
54           Ui::vvPacsConnection ui;
55         std::vector< std::pair<gdcm::Tag, std::string> > getKeys();
56         std::vector< std::pair<gdcm::Tag, std::string> > getPatientKeys(const std::string , const std::string );
57         std::vector< std::pair<gdcm::Tag, std::string> > getStudyKeys(const std::string);
58         std::vector< std::pair<gdcm::Tag, std::string> > getSeriesKeys(const std::string i_val);
59         std::vector< std::pair<gdcm::Tag, std::string> > getImageKeys(const std::string i_val);
60         void manageStudiesFilter(bool i_enable);
61         void createTreeView();
62         void cleanTree();
63         void setNewPacs();
64         QStandardItemModel *Patientmodel;
65         QStandardItemModel *Studymodel;
66         QStandardItemModel *Seriesmodel;
67         QStandardItemModel *Imagesmodel;
68         void convertDataSet(std::vector<gdcm::DataSet> i_ds, QStandardItemModel *i_model, std::vector< std::pair<gdcm::Tag, std::string> > keys);
69         void manageSeriesFilter(bool i_enable);
70         std::vector< std::pair<gdcm::Tag, std::string> > fillMoveKeys();
71         std::string m_patient;
72         std::string m_study;
73         std::string m_series;
74         gdcm::EQueryLevel m_level;
75         std::string m_port;
76         std::string m_aetitle;
77         std::string m_adress;
78         std::string m_nickname;
79         vvDicomServerQueryFactory mquery;
80         vvQuery m_query;
81         vvQuery f_query;
82          gdcm::Directory::FilenamesType m_files;
83
84          vvQuery getQueryforSeries(const std::string study_id);
85
86          vvQuery getQueryforStudy(const std::string patient_id);
87          std::vector< std::pair<gdcm::Tag, std::string> > getQueryKeysforStudy(const std::string patient_id);
88         
89   }; // class vvQPacsConnection
90   //=====================================================================
91
92   
93
94 #endif // __vvQPacsConnection_h_INCLUDED__
95
96