/*========================================================================= Library: CTK Copyright (c) Brigham and Women's Hospital (BWH). Licensed under the Apache License, Version 2.0 (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at http://www.apache.org/licenses/LICENSE-2.0.txt Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. =========================================================================*/ // ctkDICOMWidgets includes #include "ctkDICOMObjectListWidget.h" #include "ui_ctkDICOMObjectListWidget.h" // Qt includes #include #include #include #include #include #include //CTK includes #include #include static ctkLogger logger("org.commontk.DICOM.Widgets.ctkDICOMObjectListWidget"); //---------------------------------------------------------------------------- class ctkDICOMObjectListWidgetPrivate: public Ui_ctkDICOMObjectListWidget { public: ctkDICOMObjectListWidgetPrivate(); ~ctkDICOMObjectListWidgetPrivate(); void populateDICOMObjectTreeView(const QString& fileName); void setPathLabel(const QString& currentFile); QString dicomObjectModelAsString(QModelIndex parent = QModelIndex(), int indent = 0); QString currentFile; QStringList fileList; ctkDICOMObjectModel* dicomObjectModel; }; //---------------------------------------------------------------------------- // ctkDICOMObjectListWidgetPrivate methods //---------------------------------------------------------------------------- ctkDICOMObjectListWidgetPrivate::ctkDICOMObjectListWidgetPrivate() { } //---------------------------------------------------------------------------- ctkDICOMObjectListWidgetPrivate::~ctkDICOMObjectListWidgetPrivate() { } //---------------------------------------------------------------------------- void ctkDICOMObjectListWidgetPrivate::populateDICOMObjectTreeView(const QString& fileName) { this->dicomObjectModel->setFile(fileName); this->dcmObjectTreeView->setModel(this->dicomObjectModel); this->dcmObjectTreeView->expandAll(); } // -------------------------------------------------------------------------- void ctkDICOMObjectListWidgetPrivate::setPathLabel(const QString& currentFile) { currentPathLabel->setText(currentFile); } // -------------------------------------------------------------------------- QString ctkDICOMObjectListWidgetPrivate::dicomObjectModelAsString(QModelIndex parent /*=QModelIndex()*/, int indent /*=0*/) { QString dump; QString indentString(indent, '\t'); // add tab characters, (indent) number of times #ifdef WIN32 QString newLine = "\r\n"; #else QString newLine = "\n"; #endif for (int r = 0; r < this->dicomObjectModel->rowCount(parent); ++r) { dump += indentString; for (int c = 0; c < this->dicomObjectModel->columnCount(); ++c) { QModelIndex index = this->dicomObjectModel->index(r, c, parent); QString name = this->dicomObjectModel->data(index).toString(); if (c == 0) { // Replace round brackets by square brackets. // If the text is copied into Excel, Excel would recognize tag (0008,0012) // as a negative number (-80,012). Instead, [0008,0012] is displayed fine. name.replace('(', '['); name.replace(')', ']'); dump += name; } else { dump += "\t" + name; } } dump += newLine; // here is your applicable code QModelIndex index0 = this->dicomObjectModel->index(r, 0, parent); if (this->dicomObjectModel->hasChildren(index0)) { dump += dicomObjectModelAsString(index0, indent+1); } } return dump; } //---------------------------------------------------------------------------- // ctkDICOMObjectListWidget methods //---------------------------------------------------------------------------- ctkDICOMObjectListWidget::ctkDICOMObjectListWidget(QWidget* _parent):Superclass(_parent), d_ptr(new ctkDICOMObjectListWidgetPrivate) { Q_D(ctkDICOMObjectListWidget); d->setupUi(this); d->dicomObjectModel = new ctkDICOMObjectModel(this); d->fileSliderWidget->setPageStep(1); d->currentPathLabel->setTextInteractionFlags(Qt::TextSelectableByMouse); connect(d->fileSliderWidget, SIGNAL(valueChanged(double)), this, SLOT(updateWidget())); connect(d->dcmObjectTreeView, SIGNAL(doubleClicked(const QModelIndex&)) ,this, SLOT(openLookupUrl(const QModelIndex&))); connect(d->copyPathPushButton , SIGNAL(clicked(bool)),this, SLOT(copyPath())); connect(d->copyMetadataPushButton, SIGNAL(clicked(bool)), this, SLOT(copyMetadata())); } //---------------------------------------------------------------------------- ctkDICOMObjectListWidget::~ctkDICOMObjectListWidget() { Q_D(ctkDICOMObjectListWidget); d->dicomObjectModel->deleteLater(); } //---------------------------------------------------------------------------- void ctkDICOMObjectListWidget::setCurrentFile(const QString& newFileName) { Q_D(ctkDICOMObjectListWidget); d->setPathLabel(newFileName); } // -------------------------------------------------------------------------- void ctkDICOMObjectListWidget::setFileList(const QStringList& fileList) { Q_D(ctkDICOMObjectListWidget); d->fileList = fileList; if (d->fileList.size() > 0) { d->currentFile = d->fileList[0]; d->setPathLabel(d->currentFile ); d->populateDICOMObjectTreeView(d->currentFile ); d->fileSliderWidget->setMaximum(fileList.size()-1); } } // -------------------------------------------------------------------------- QString ctkDICOMObjectListWidget::currentFile() { Q_D(ctkDICOMObjectListWidget); return d->currentFile; } // -------------------------------------------------------------------------- QStringList ctkDICOMObjectListWidget::fileList() { Q_D(ctkDICOMObjectListWidget); return d->fileList; } // -------------------------------------------------------------------------- void ctkDICOMObjectListWidget::openLookupUrl(const QModelIndex& index) { if (index.column() == 0) { QVariant data = index.data(); QString lookupUrl = "http://dicomlookup.com/lookup.asp?sw=Tnumber&q="+data.toString(); QUrl url(lookupUrl); QDesktopServices::openUrl(url); } } // -------------------------------------------------------------------------- void ctkDICOMObjectListWidget::updateWidget() { Q_D(ctkDICOMObjectListWidget); d->currentFile = d->fileList[static_cast(d->fileSliderWidget->value())]; d->setPathLabel(d->currentFile); d->populateDICOMObjectTreeView(d->currentFile); } // -------------------------------------------------------------------------- void ctkDICOMObjectListWidget::copyPath() { Q_D(ctkDICOMObjectListWidget); QClipboard *clipboard = QApplication::clipboard(); clipboard->setText(d->currentFile); } // -------------------------------------------------------------------------- QString ctkDICOMObjectListWidget::metadataAsText() { Q_D(ctkDICOMObjectListWidget); return d->dicomObjectModelAsString(); } // -------------------------------------------------------------------------- void ctkDICOMObjectListWidget::copyMetadata() { Q_D(ctkDICOMObjectListWidget); QClipboard *clipboard = QApplication::clipboard(); clipboard->setText(metadataAsText()); }