ctkDICOMQueryRetrieveWidget.cpp 5.6 KB

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