ctkDICOMThumbnailListWidget.cpp 7.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203
  1. // Qt include
  2. #include <QGridLayout>
  3. #include <QResizeEvent>
  4. #include <QPushButton>
  5. #include <QPixmap>
  6. #include <QFile>
  7. // ctk includes
  8. #include "ctkLogger.h"
  9. // ctkWidgets includes
  10. #include "ctkFlowLayout.h"
  11. //ctkDICOMCore includes
  12. #include "ctkDICOMModel.h"
  13. #include "ctkDICOMDatabase.h"
  14. // ctkDICOMWidgets includes
  15. #include "ctkDICOMThumbnailListWidget.h"
  16. #include "ui_ctkDICOMThumbnailListWidget.h"
  17. #include "ctkDICOMThumbnailWidget.h"
  18. // STD includes
  19. #include <iostream>
  20. static ctkLogger logger("org.commontk.DICOM.Widgets.ctkDICOMThumbnailListWidget");
  21. //----------------------------------------------------------------------------
  22. class ctkDICOMThumbnailListWidgetPrivate: public Ui_ctkDICOMThumbnailListWidget
  23. {
  24. public:
  25. ctkDICOMThumbnailListWidgetPrivate(ctkDICOMThumbnailListWidget* parent): q_ptr(parent){
  26. }
  27. QString databaseDirectory;
  28. void onPatientModelSelected(const QModelIndex &index);
  29. void onStudyModelSelected(const QModelIndex &index);
  30. void onSeriesModelSelected(const QModelIndex &index);
  31. ctkDICOMThumbnailListWidget* const q_ptr;
  32. Q_DECLARE_PUBLIC(ctkDICOMThumbnailListWidget);
  33. };
  34. //----------------------------------------------------------------------------
  35. // ctkDICOMThumbnailListWidgetPrivate methods
  36. void ctkDICOMThumbnailListWidgetPrivate::onPatientModelSelected(const QModelIndex &index){
  37. QModelIndex patientIndex = index;
  38. ctkDICOMModel* model = const_cast<ctkDICOMModel*>(qobject_cast<const ctkDICOMModel*>(index.model()));
  39. if(model){
  40. model->fetchMore(patientIndex);
  41. int studyCount = model->rowCount(patientIndex);
  42. for(int i=0; i<studyCount; i++){
  43. QModelIndex studyIndex = patientIndex.child(i, 0);
  44. QModelIndex seriesIndex = studyIndex.child(0, 0);
  45. QModelIndex imageIndex = seriesIndex.child(0, 0);
  46. QString thumbnail = this->databaseDirectory +
  47. "/thumbs/" + model->data(studyIndex ,ctkDICOMModel::UIDRole).toString() + "/" +
  48. model->data(seriesIndex ,ctkDICOMModel::UIDRole).toString() + "/" +
  49. model->data(imageIndex, ctkDICOMModel::UIDRole).toString() + ".png";
  50. if (QFile(thumbnail).exists()){
  51. ctkDICOMThumbnailWidget* widget = new ctkDICOMThumbnailWidget(this->scrollAreaContentWidget);
  52. QString widgetLabel = QString("Image %1").arg(i);
  53. widget->setText( model->data(studyIndex, Qt::DisplayRole).toString() );
  54. QPixmap pix(thumbnail);
  55. logger.debug("Setting pixmap to " + thumbnail);
  56. widget->setPixmap(pix);
  57. this->scrollAreaContentWidget->layout()->addWidget(widget);
  58. }else{
  59. logger.error("No thumbnail file " + thumbnail);
  60. }
  61. }
  62. }
  63. }
  64. void ctkDICOMThumbnailListWidgetPrivate::onStudyModelSelected(const QModelIndex &index){
  65. QModelIndex studyIndex = index;
  66. ctkDICOMModel* model = const_cast<ctkDICOMModel*>(qobject_cast<const ctkDICOMModel*>(index.model()));
  67. if(model){
  68. model->fetchMore(studyIndex);
  69. int seriesCount = model->rowCount(studyIndex);
  70. for(int i=0; i<seriesCount; i++){
  71. QModelIndex seriesIndex = studyIndex.child(i, 0);
  72. QModelIndex imageIndex = seriesIndex.child(0, 0);
  73. QString thumbnail = this->databaseDirectory +
  74. "/thumbs/" + model->data(studyIndex ,ctkDICOMModel::UIDRole).toString() + "/" +
  75. model->data(seriesIndex ,ctkDICOMModel::UIDRole).toString() + "/" +
  76. model->data(imageIndex, ctkDICOMModel::UIDRole).toString() + ".png";
  77. if (QFile(thumbnail).exists()){
  78. ctkDICOMThumbnailWidget* widget = new ctkDICOMThumbnailWidget(this->scrollAreaContentWidget);
  79. QString widgetLabel = QString("Image %1").arg(i);
  80. widget->setText( model->data(seriesIndex, Qt::DisplayRole).toString() );
  81. QPixmap pix(thumbnail);
  82. logger.debug("Setting pixmap to " + thumbnail);
  83. widget->setPixmap(pix);
  84. this->scrollAreaContentWidget->layout()->addWidget(widget);
  85. }else{
  86. logger.error("No thumbnail file " + thumbnail);
  87. }
  88. }
  89. }
  90. }
  91. void ctkDICOMThumbnailListWidgetPrivate::onSeriesModelSelected(const QModelIndex &index){
  92. QModelIndex studyIndex = index.parent();
  93. QModelIndex seriesIndex = index;
  94. ctkDICOMModel* model = const_cast<ctkDICOMModel*>(qobject_cast<const ctkDICOMModel*>(index.model()));
  95. if(model){
  96. model->fetchMore(seriesIndex);
  97. QString thumbnailPath = this->databaseDirectory +
  98. "/thumbs/" + model->data(studyIndex ,ctkDICOMModel::UIDRole).toString() + "/" +
  99. model->data(seriesIndex ,ctkDICOMModel::UIDRole).toString() + "/";
  100. int imageCount = model->rowCount(seriesIndex);
  101. logger.debug(QString("Thumbs: %1").arg(imageCount));
  102. for (int i = 0 ; i < imageCount ; i++ )
  103. {
  104. QModelIndex imageIndex = seriesIndex.child(i,0);
  105. QString thumbnail = thumbnailPath + model->data(imageIndex, ctkDICOMModel::UIDRole).toString() + ".png";
  106. if (QFile(thumbnail).exists())
  107. {
  108. ctkDICOMThumbnailWidget* widget = new ctkDICOMThumbnailWidget(this->scrollAreaContentWidget);
  109. QString widgetLabel = QString("Image %1").arg(i);
  110. widget->setText( widgetLabel );
  111. QPixmap pix(thumbnail);
  112. logger.debug("Setting pixmap to " + thumbnail);
  113. widget->setPixmap(pix);
  114. this->scrollAreaContentWidget->layout()->addWidget(widget);
  115. }
  116. else
  117. {
  118. logger.error("No thumbnail file " + thumbnail);
  119. }
  120. }
  121. }
  122. }
  123. //----------------------------------------------------------------------------
  124. // ctkDICOMThumbnailListWidget methods
  125. //----------------------------------------------------------------------------
  126. ctkDICOMThumbnailListWidget::ctkDICOMThumbnailListWidget(QWidget* _parent):Superclass(_parent),
  127. d_ptr(new ctkDICOMThumbnailListWidgetPrivate(this))
  128. {
  129. Q_D(ctkDICOMThumbnailListWidget);
  130. d->setupUi(this);
  131. d->scrollAreaContentWidget->setLayout(new ctkFlowLayout);
  132. }
  133. //----------------------------------------------------------------------------
  134. ctkDICOMThumbnailListWidget::~ctkDICOMThumbnailListWidget()
  135. {
  136. }
  137. void ctkDICOMThumbnailListWidget::setDatabaseDirectory(const QString &directory){
  138. Q_D(ctkDICOMThumbnailListWidget);
  139. d->databaseDirectory = directory;
  140. }
  141. void ctkDICOMThumbnailListWidget::onModelSelected(const QModelIndex &index){
  142. Q_D(ctkDICOMThumbnailListWidget);
  143. // Remove previous displayed thumbnails
  144. QLayoutItem* item;
  145. while(item = d->scrollAreaContentWidget->layout()->takeAt(0)){
  146. item->widget()->deleteLater();
  147. }
  148. ctkDICOMModel* model = const_cast<ctkDICOMModel*>(qobject_cast<const ctkDICOMModel*>(index.model()));
  149. if(model){
  150. QModelIndex index0 = index.sibling(index.row(), 0);
  151. if ( model->data(index0,ctkDICOMModel::TypeRole) == ctkDICOMModel::PatientType ){
  152. d->onPatientModelSelected(index0);
  153. }else if ( model->data(index0,ctkDICOMModel::TypeRole) == ctkDICOMModel::StudyType ){
  154. d->onStudyModelSelected(index0);
  155. }else if ( model->data(index0,ctkDICOMModel::TypeRole) == ctkDICOMModel::SeriesType ){
  156. d->onSeriesModelSelected(index0);
  157. }
  158. }
  159. }