123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368 |
- /*=========================================================================
- Library: CTK
- Copyright (c) Kitware Inc.
- 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.
- =========================================================================*/
- // ctkDICOMWidget includes
- #include "ctkDICOMTableView.h"
- #include "ui_ctkDICOMTableView.h"
- // Qt includes
- #include <QSortFilterProxyModel>
- #include <QSqlQueryModel>
- //------------------------------------------------------------------------------
- class ctkDICOMTableViewPrivate : public Ui_ctkDICOMTableView
- {
- Q_DECLARE_PUBLIC (ctkDICOMTableView)
- protected:
- ctkDICOMTableView* const q_ptr;
- public:
- ctkDICOMTableViewPrivate(ctkDICOMTableView& obj);
- ctkDICOMTableViewPrivate(ctkDICOMTableView& obj, ctkDICOMDatabase* db);
- ~ctkDICOMTableViewPrivate();
- // Initialize UI
- void init();
- // Setup tableview with tablemodel if database is available
- void setUpTableView();
- //Temporay solution to hide UID columns
- void hideUIDColumns();
- void showFilterActiveWarning(bool);
- QString queryTableName() const;
- ctkDICOMDatabase* dicomDatabase;
- QSqlQueryModel dicomSQLModel;
- QSortFilterProxyModel* dicomSQLFilterModel;
- QString queryForeignKey;
- QStringList currentSelection;
- //Key = QString for columns, Values = QStringList
- QHash<QString, QStringList> sqlWhereConditions;
- };
- //------------------------------------------------------------------------------
- ctkDICOMTableViewPrivate::ctkDICOMTableViewPrivate(ctkDICOMTableView &obj)
- : q_ptr(&obj)
- {
- this->dicomSQLFilterModel = new QSortFilterProxyModel(&obj);
- this->dicomDatabase = new ctkDICOMDatabase(&obj);
- }
- //------------------------------------------------------------------------------
- ctkDICOMTableViewPrivate::ctkDICOMTableViewPrivate(ctkDICOMTableView &obj, ctkDICOMDatabase* db)
- : q_ptr(&obj)
- , dicomDatabase(db)
- {
- this->dicomSQLFilterModel = new QSortFilterProxyModel(&obj);
- }
- //------------------------------------------------------------------------------
- ctkDICOMTableViewPrivate::~ctkDICOMTableViewPrivate()
- {
- }
- void ctkDICOMTableViewPrivate::init()
- {
- Q_Q(ctkDICOMTableView);
- this->setupUi(q);
- this->leSearchBox->setAlwaysShowClearIcon(true);
- this->leSearchBox->setShowSearchIcon(true);
- if (this->dicomDatabase != 0)
- {
- this->setUpTableView();
- }
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableViewPrivate::setUpTableView()
- {
- Q_Q(ctkDICOMTableView);
- if (this->dicomDatabase != 0)
- {
- q->setQuery();
- this->dicomSQLFilterModel->setSourceModel(&this->dicomSQLModel);
- this->dicomSQLFilterModel->setFilterKeyColumn(-1);
- this->dicomSQLFilterModel->setFilterCaseSensitivity(Qt::CaseInsensitive);
- this->tblDicomDatabaseView->setModel(this->dicomSQLFilterModel);
- this->tblDicomDatabaseView->setColumnHidden(0, true);
- this->tblDicomDatabaseView->setSortingEnabled(true);
- this->tblDicomDatabaseView->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
- this->hideUIDColumns();
- QObject::connect(this->tblDicomDatabaseView->selectionModel(),
- SIGNAL(selectionChanged(const QItemSelection&,const QItemSelection&)),
- q, SLOT(onSelectionChanged()));
- QObject::connect(this->tblDicomDatabaseView->selectionModel(),
- SIGNAL(selectionChanged(const QItemSelection&,const QItemSelection&)),
- q, SIGNAL(selectionChanged(const QItemSelection&,const QItemSelection&)));
- QObject::connect(this->tblDicomDatabaseView, SIGNAL(doubleClicked(const QModelIndex&)),
- q, SIGNAL(doubleClicked(const QModelIndex&)));
- QObject::connect(this->leSearchBox, SIGNAL(textChanged(QString)),
- this->dicomSQLFilterModel, SLOT(setFilterWildcard(QString)));
- QObject::connect(this->leSearchBox, SIGNAL(textChanged(QString)), q, SLOT(onFilterChanged()));
- QObject::connect(this->dicomDatabase, SIGNAL(databaseChanged()), q, SLOT(onDatabaseChanged()));
- QObject::connect(this->dicomDatabase, SIGNAL(instanceAdded(const QString&)),
- q, SLOT(onInstanceAdded()));
- }
- }
- //------------------------------------------------------------------------------
- //Temporay solution to hide UID columns
- void ctkDICOMTableViewPrivate::hideUIDColumns()
- {
- const int numberOfColumns = this->tblDicomDatabaseView->model()->columnCount();
- for (int i = 0; i < numberOfColumns; ++i)
- {
- QString columnName = this->tblDicomDatabaseView->model()->headerData(i, Qt::Horizontal).toString();
- if (columnName.contains("UID"))
- {
- this->tblDicomDatabaseView->hideColumn(i);
- }
- }
- }
- //----------------------------------------------------------------------------
- QString ctkDICOMTableViewPrivate::queryTableName() const
- {
- return this->lblTableName->text();
- }
- //----------------------------------------------------------------------------
- void ctkDICOMTableViewPrivate::showFilterActiveWarning(bool showWarning)
- {
- QPalette palette;
- if (showWarning)
- {
- palette.setColor(QPalette::Base,Qt::yellow);
- }
- else
- {
- palette.setColor(QPalette::Base,Qt::white);
- }
- this->leSearchBox->setPalette(palette);
- }
- //----------------------------------------------------------------------------
- // ctkDICOMTableView methods
- //----------------------------------------------------------------------------
- ctkDICOMTableView::ctkDICOMTableView(QWidget *parent)
- : Superclass(parent)
- , d_ptr(new ctkDICOMTableViewPrivate(*this))
- {
- Q_D(ctkDICOMTableView);
- d->init();
- }
- //----------------------------------------------------------------------------
- ctkDICOMTableView::ctkDICOMTableView(QString queryTableName, QWidget *parent)
- : Superclass(parent)
- , d_ptr(new ctkDICOMTableViewPrivate(*this))
- {
- Q_D(ctkDICOMTableView);
- d->init();
- this->setQueryTableName(queryTableName);
- d->lblTableName->setText(queryTableName);
- }
- //------------------------------------------------------------------------------
- ctkDICOMTableView::ctkDICOMTableView (ctkDICOMDatabase* dicomDataBase, QString queryTableName, QWidget* parent)
- : Superclass(parent)
- , d_ptr(new ctkDICOMTableViewPrivate(*this))
- {
- this->setDicomDataBase(dicomDataBase);
- Q_D(ctkDICOMTableView);
- this->setQueryTableName(queryTableName);
- d->init();
- }
- //------------------------------------------------------------------------------
- ctkDICOMTableView::~ctkDICOMTableView()
- {
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::setDicomDataBase(ctkDICOMDatabase *dicomDatabase)
- {
- Q_D(ctkDICOMTableView);
- d->dicomDatabase = dicomDatabase;
- //Create connections for new database
- QObject::connect(d->dicomDatabase, SIGNAL(instanceAdded(const QString&)),
- this, SLOT(onInstanceAdded()));
- QObject::connect(d->dicomDatabase, SIGNAL(databaseChanged()), this, SLOT(onDatabaseChanged()));
- this->setQuery();
- d->hideUIDColumns();
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::setQueryTableName(const QString &tableName)
- {
- Q_D(ctkDICOMTableView);
- d->lblTableName->setText(tableName);
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::setQueryForeignKey(const QString &foreignKey)
- {
- Q_D(ctkDICOMTableView);
- d->queryForeignKey = foreignKey;
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::onSelectionChanged()
- {
- emit selectionChanged(currentSelection());
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::onDatabaseChanged()
- {
- Q_D(ctkDICOMTableView);
- setQuery();
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::onUpdateQuery(const QStringList& uids)
- {
- Q_D(ctkDICOMTableView);
- setQuery(uids);
- d->showFilterActiveWarning( d->dicomSQLFilterModel->rowCount() == 0 &&
- d->leSearchBox->text().length() != 0 );
- const QStringList& newUIDS = this->uidsForAllRows();
- emit queryChanged(newUIDS);
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::onFilterChanged()
- {
- Q_D(ctkDICOMTableView);
- const QStringList uids = this->uidsForAllRows();
- d->showFilterActiveWarning( d->dicomSQLFilterModel->rowCount() == 0 &&
- d->dicomSQLModel.rowCount() != 0);
- d->tblDicomDatabaseView->clearSelection();
- emit queryChanged(uids);
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::onInstanceAdded()
- {
- Q_D(ctkDICOMTableView);
- d->sqlWhereConditions.clear();
- d->tblDicomDatabaseView->clearSelection();
- d->leSearchBox->clear();
- }
- //------------------------------------------------------------------------------
- void ctkDICOMTableView::setQuery(const QStringList &uids)
- {
- Q_D(ctkDICOMTableView);
- QString query = ("select distinct %1.* from Patients, Series, Studies where "
- "Patients.UID = Studies.PatientsUID and Studies.StudyInstanceUID = Series.StudyInstanceUID");
- if (!uids.empty() && d->queryForeignKey.length() != 0)
- {
- query += " and %1."+d->queryForeignKey+" in ( '";
- query.append(uids.join("','")).append("')");
- }
- if (!d->sqlWhereConditions.empty())
- {
- QHash<QString, QStringList>::const_iterator i = d->sqlWhereConditions.begin();
- while (i != d->sqlWhereConditions.end())
- {
- if (!i.value().empty())
- {
- query += " and "+i.key()+" in ( '";
- query.append(i.value().join("','")).append("')");
- }
- ++i;
- }
- }
- if (d->dicomDatabase != 0)
- d->dicomSQLModel.setQuery(query.arg(d->queryTableName()), d->dicomDatabase->database());
- }
- void ctkDICOMTableView::addSqlWhereCondition(const std::pair<QString, QStringList> &condition)
- {
- Q_D(ctkDICOMTableView);
- d->sqlWhereConditions.insert(condition.first, condition.second);
- }
- //------------------------------------------------------------------------------
- QStringList ctkDICOMTableView::uidsForAllRows() const
- {
- Q_D(const ctkDICOMTableView);
- QAbstractItemModel* tableModel = d->tblDicomDatabaseView->model();
- int numberOfRows = tableModel->rowCount();
- QStringList uids;
- if (numberOfRows == 0)
- {
- //Return invalid UID if there are no rows
- uids << QString("#");
- }
- else
- {
- for(int i = 0; i < numberOfRows; ++i)
- {
- uids << QString("%1").arg(tableModel->index(i,0).data().toString());
- }
- }
- return uids;
- }
- //------------------------------------------------------------------------------
- QStringList ctkDICOMTableView::currentSelection() const
- {
- Q_D(const ctkDICOMTableView);
- QModelIndexList currentSelection = d->tblDicomDatabaseView->selectionModel()->selectedRows(0);
- QStringList uids;
- foreach(QModelIndex i, currentSelection)
- {
- uids<< i.data().toString();
- }
- return uids;
- }
- //------------------------------------------------------------------------------
- bool ctkDICOMTableView::filterActive()
- {
- Q_D(ctkDICOMTableView);
- return (d->leSearchBox->text().length() != 0);
- }
|