ctkDICOMQueryRetrieveWidget.cpp 6.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182
  1. #include <QDebug>
  2. #include <QTreeView>
  3. #include <QTabBar>
  4. #include <QSettings>
  5. #include <QHBoxLayout>
  6. /// CTK includes
  7. #include <ctkCheckableHeaderView.h>
  8. // ctkDICOMCore includes
  9. #include "ctkDICOMDatabase.h"
  10. #include "ctkDICOMModel.h"
  11. #include "ctkDICOMQuery.h"
  12. #include "ctkDICOMRetrieve.h"
  13. // ctkDICOMWidgets includes
  14. #include "ctkDICOMQueryRetrieveWidget.h"
  15. #include "ctkDICOMQueryResultsTabWidget.h"
  16. #include "ui_ctkDICOMQueryRetrieveWidget.h"
  17. #include <ctkLogger.h>
  18. static ctkLogger logger("org.commontk.DICOM.Widgets.ctkDICOMQueryRetrieveWidget");
  19. //----------------------------------------------------------------------------
  20. class ctkDICOMQueryRetrieveWidgetPrivate: public Ui_ctkDICOMQueryRetrieveWidget
  21. {
  22. public:
  23. ctkDICOMQueryRetrieveWidgetPrivate(){}
  24. QMap<QString, ctkDICOMQuery*> queriesByServer;
  25. QMap<QString, ctkDICOMQuery*> queriesByStudyUID;
  26. QMap<QString, ctkDICOMRetrieve*> retrievalsByStudyUID;
  27. ctkDICOMDatabase queryResultDatabase;
  28. ctkDICOMModel model;
  29. };
  30. //----------------------------------------------------------------------------
  31. // ctkDICOMQueryRetrieveWidgetPrivate methods
  32. //----------------------------------------------------------------------------
  33. // ctkDICOMQueryRetrieveWidget methods
  34. //----------------------------------------------------------------------------
  35. ctkDICOMQueryRetrieveWidget::ctkDICOMQueryRetrieveWidget(QWidget* parentWidget)
  36. : Superclass(parentWidget)
  37. , d_ptr(new ctkDICOMQueryRetrieveWidgetPrivate)
  38. {
  39. Q_D(ctkDICOMQueryRetrieveWidget);
  40. d->setupUi(this);
  41. connect(d->QueryButton, SIGNAL(clicked()), this, SLOT(processQuery()));
  42. connect(d->RetrieveButton, SIGNAL(clicked()), this, SLOT(processRetrieve()));
  43. d->results->setModel(&d->model);
  44. d->model.setHeaderData(0, Qt::Horizontal, Qt::Unchecked, Qt::CheckStateRole);
  45. QHeaderView* previousHeaderView = d->results->header();
  46. ctkCheckableHeaderView* headerView = new ctkCheckableHeaderView(Qt::Horizontal, d->results);
  47. headerView->setClickable(previousHeaderView->isClickable());
  48. headerView->setMovable(previousHeaderView->isMovable());
  49. headerView->setHighlightSections(previousHeaderView->highlightSections());
  50. headerView->setPropagateToItems(true);
  51. d->results->setHeader(headerView);
  52. // headerView is hidden because it was created with a visisble parent widget
  53. headerView->setHidden(false);
  54. }
  55. //----------------------------------------------------------------------------
  56. ctkDICOMQueryRetrieveWidget::~ctkDICOMQueryRetrieveWidget()
  57. {
  58. }
  59. //----------------------------------------------------------------------------
  60. void ctkDICOMQueryRetrieveWidget::setRetrieveDirectory(const QString& directory)
  61. {
  62. QSettings settings;
  63. settings.setValue("RetrieveDirectory", directory);
  64. settings.sync();
  65. }
  66. //----------------------------------------------------------------------------
  67. void ctkDICOMQueryRetrieveWidget::setRetrieveDatabaseFileName(const QString& fileName)
  68. {
  69. QSettings settings;
  70. settings.setValue("RetrieveDatabaseFileName", fileName);
  71. settings.sync();
  72. }
  73. //----------------------------------------------------------------------------
  74. void ctkDICOMQueryRetrieveWidget::processQuery()
  75. {
  76. Q_D(ctkDICOMQueryRetrieveWidget);
  77. d->RetrieveButton->setEnabled(false);
  78. // create a database in memory to hold query results
  79. try { d->queryResultDatabase.openDatabase( ":memory:" ); }
  80. catch (std::exception e)
  81. {
  82. logger.error ( "Database error: " + d->queryResultDatabase.GetLastError() );
  83. d->queryResultDatabase.closeDatabase();
  84. return;
  85. }
  86. // for each of the selected server nodes, send the query
  87. QStringList serverNodes = d->ServerNodeWidget->nodes();
  88. foreach (QString server, serverNodes)
  89. {
  90. QMap<QString, QVariant> parameters = d->ServerNodeWidget->nodeParameters(server);
  91. if ( parameters["CheckState"] == Qt::Checked )
  92. {
  93. // create a query for the current server
  94. d->queriesByServer[server] = new ctkDICOMQuery;
  95. d->queriesByServer[server]->setCallingAETitle(d->ServerNodeWidget->callingAETitle());
  96. d->queriesByServer[server]->setCalledAETitle(parameters["AETitle"].toString());
  97. d->queriesByServer[server]->setHost(parameters["Address"].toString());
  98. d->queriesByServer[server]->setPort(parameters["Port"].toInt());
  99. // populate the query with the current search options
  100. d->queriesByServer[server]->setFilters( d->QueryWidget->parameters() );
  101. try
  102. {
  103. // run the query against the selected server and put results in database
  104. d->queriesByServer[server]->query ( d->queryResultDatabase );
  105. }
  106. catch (std::exception e)
  107. {
  108. logger.error ( "Query error: " + parameters["Name"].toString() );
  109. }
  110. foreach( QString studyUID, d->queriesByServer[server]->studyInstanceUIDQueried() )
  111. {
  112. d->queriesByStudyUID[studyUID] = d->queriesByServer[server];
  113. }
  114. }
  115. }
  116. // checkable headers - allow user to select the patient/studies to retrieve
  117. d->model.setDatabase(d->queryResultDatabase.database());
  118. d->RetrieveButton->setEnabled(d->model.rowCount());
  119. }
  120. //----------------------------------------------------------------------------
  121. void ctkDICOMQueryRetrieveWidget::processRetrieve()
  122. {
  123. Q_D(ctkDICOMQueryRetrieveWidget);
  124. QMap<QString,QVariant> serverParameters = d->ServerNodeWidget->parameters();
  125. foreach( QString studyUID, d->queriesByStudyUID.keys() )
  126. {
  127. logger.debug("need to retrieve " + studyUID + " from " + d->queriesByStudyUID[studyUID]->host());
  128. ctkDICOMQuery *query = d->queriesByStudyUID[studyUID];
  129. ctkDICOMRetrieve *retrieve = new ctkDICOMRetrieve;
  130. d->retrievalsByStudyUID[studyUID] = retrieve;
  131. retrieve->setCallingAETitle( query->callingAETitle() );
  132. retrieve->setCalledAETitle( query->calledAETitle() );
  133. retrieve->setCalledPort( query->port() );
  134. retrieve->setHost( query->host() );
  135. // pull from GUI
  136. retrieve->setMoveDestinationAETitle( serverParameters["StorageAETitle"].toString() );
  137. retrieve->setCallingPort( serverParameters["StoragePort"].toInt() );
  138. logger.info ( "Starting to retrieve" );
  139. try
  140. {
  141. retrieve->retrieveStudy ( studyUID, QDir("/tmp/ctk") );
  142. }
  143. catch (std::exception e)
  144. {
  145. logger.error ( "Retrieve failed" );
  146. return;
  147. }
  148. logger.info ( "Retrieve success" );
  149. }
  150. }