123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209 |
- /*=========================================================================
- 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 <QSqlQueryModel>
- #include <QSortFilterProxyModel>
- class ctkDICOMTableViewPrivate : public Ui_ctkDICOMTableView
- {
- Q_DECLARE_PUBLIC (ctkDICOMTableView)
- protected:
- ctkDICOMTableView* const q_ptr;
- public:
- ctkDICOMTableViewPrivate(ctkDICOMTableView& obj);
- ctkDICOMTableViewPrivate(ctkDICOMTableView& obj, QSharedPointer<ctkDICOMDatabase> db);
- ~ctkDICOMTableViewPrivate();
- // Initialize UI
- void init();
- // Setup tableview with tablemodel if database is available
- void setUpTableView();
- QSharedPointer<ctkDICOMDatabase> DICOMDatabase;
- QSqlQueryModel DICOMSQLModel;
- QSortFilterProxyModel* DICOMSQLFilterModel;
- QString queryTableName;
- QString queryForeignKey;
- QString queryPrimaryKey;
- };
- ctkDICOMTableViewPrivate::ctkDICOMTableViewPrivate(ctkDICOMTableView &obj)
- : q_ptr(&obj)
- {
- this->DICOMSQLFilterModel = new QSortFilterProxyModel();
- }
- ctkDICOMTableViewPrivate::ctkDICOMTableViewPrivate(ctkDICOMTableView &obj, QSharedPointer<ctkDICOMDatabase> db)
- : q_ptr(&obj)
- , DICOMDatabase(db)
- {
- this->DICOMSQLFilterModel = new QSortFilterProxyModel();
- }
- ctkDICOMTableViewPrivate::~ctkDICOMTableViewPrivate()
- {
- delete this->DICOMSQLFilterModel;
- }
- void ctkDICOMTableViewPrivate::init()
- {
- Q_Q(ctkDICOMTableView);
- this->setupUi(q);
- this->tblDicomDatabaseView->setSelectionBehavior(QAbstractItemView::SelectRows);
- this->tblDicomDatabaseView->setSelectionMode(QAbstractItemView::ExtendedSelection);
- this->tblDicomDatabaseView->verticalHeader()->setHidden(true);
- // this->tblDicomDatabaseView->horizontalHeader()->setResizeMode(QHeaderView::ResizeToContents);
- this->tblDicomDatabaseView->horizontalHeader()->adjustSize();
- if (this->DICOMDatabase)
- {
- this->setUpTableView();
- }
- }
- void ctkDICOMTableViewPrivate::setUpTableView()
- {
- Q_Q(ctkDICOMTableView);
- if (this->DICOMDatabase)
- {
- this->DICOMSQLModel.setQuery("select * from Patients", this->DICOMDatabase->database());
- this->DICOMSQLFilterModel->setSourceModel(&this->DICOMSQLModel);
- this->DICOMSQLFilterModel->setFilterKeyColumn(-1);
- this->DICOMSQLFilterModel->setFilterCaseSensitivity(Qt::CaseInsensitive);
- this->tblDicomDatabaseView->setModel(this->DICOMSQLFilterModel);
- this->tblDicomDatabaseView->setColumnHidden(0, true);
- QObject::connect(this->tblDicomDatabaseView->selectionModel(), SIGNAL(selectionChanged(QItemSelection,QItemSelection)),
- q, SLOT(onSelectionChanged()));
- QObject::connect(this->leSearchBox, SIGNAL(textChanged(QString)), this->DICOMSQLFilterModel, SLOT(setFilterWildcard(QString)));
- QObject::connect(this->DICOMDatabase.data(), SIGNAL(databaseChanged()), q, SLOT(onDatabaseChanged()));
- }
- }
- //----------------------------------------------------------------------------
- // ctkDICOMTableView methods
- //----------------------------------------------------------------------------
- ctkDICOMTableView::ctkDICOMTableView(QWidget *parent)
- :Superclass(parent)
- , d_ptr(new ctkDICOMTableViewPrivate(*this))
- {
- Q_D(ctkDICOMTableView);
- d->init();
- }
- ctkDICOMTableView::ctkDICOMTableView(QWidget *parent, QSharedPointer<ctkDICOMDatabase> ctkDicomDataBase)
- : Superclass(parent)
- , d_ptr(new ctkDICOMTableViewPrivate(*this))
- {
- this->setCTKDicomDataBase(ctkDicomDataBase);
- Q_D(ctkDICOMTableView);
- d->init();
- }
- ctkDICOMTableView::~ctkDICOMTableView()
- {
- }
- void ctkDICOMTableView::setCTKDicomDataBase(QSharedPointer<ctkDICOMDatabase> dicomDataBase)
- {
- Q_D(ctkDICOMTableView);
- d->DICOMDatabase = dicomDataBase;
- d->setUpTableView();
- }
- void ctkDICOMTableView::setQueryTableName(const QString &tableName)
- {
- Q_D(ctkDICOMTableView);
- d->queryTableName = tableName;
- }
- void ctkDICOMTableView::setQueryForeignKey(const QString &foreignKey)
- {
- Q_D(ctkDICOMTableView);
- d->queryForeignKey = foreignKey;
- }
- void ctkDICOMTableView::setQueryPrimaryKey(const QString &primaryKey)
- {
- Q_D(ctkDICOMTableView);
- d->queryPrimaryKey = primaryKey;
- }
- void ctkDICOMTableView::onSelectionChanged()
- {
- Q_D(ctkDICOMTableView);
- QModelIndexList currentSelection = d->tblDicomDatabaseView->selectionModel()->selectedRows(0);
- // QString query;
- QStringList uids;
- if (currentSelection.empty())
- {
- emit signalSelectionChanged(uids);
- }
- else
- {
- foreach(QModelIndex i, currentSelection)
- {
- qDebug() << i.data();
- uids << (QString("'") + i.data().toString() +"'");
- }
- // query.append(inExpression.join(",")).append(");");
- emit signalSelectionChanged(uids);
- }
- foreach(QString s, uids)
- {
- qDebug() << s;
- }
- }
- void ctkDICOMTableView::onDatabaseChanged()
- {
- Q_D(ctkDICOMTableView);
- d->DICOMSQLModel.setQuery("select * from Patients", d->DICOMDatabase->database());
- }
- void ctkDICOMTableView::onQueryChanged(const QStringList& uids)
- {
- Q_D(ctkDICOMTableView);
- QString query;
- if (uids.empty())
- {
- query = "select * from " + d->queryTableName;
- }
- else
- {
- query = "select * from "+d->queryTableName+" where "+d->queryForeignKey+" in ( ";
- query.append(uids.join(",")).append(");");
- }
- qDebug() << query;
- d->DICOMSQLModel.setQuery(query, d->DICOMDatabase->database());
- }
|