123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171 |
- /*=========================================================================
- Library: CTK
-
- Copyright (c) 2010 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.commontk.org/LICENSE
- 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.
-
- =========================================================================*/
- // Qt includes
- #include <QSqlQuery>
- #include <QSqlRecord>
- #include <QVariant>
- #include <QDate>
- #include <QStringList>
- #include <QSet>
- #include <QFile>
- #include <QDirIterator>
- #include <QFileInfo>
- #include <QDebug>
- // ctkDICOM includes
- #include "ctkDICOMQuery.h"
- // DCMTK includes
- #ifndef WIN32
- #define HAVE_CONFIG_H
- #endif
- #include "dcmtk/dcmnet/dimse.h"
- #include "dcmtk/dcmnet/diutil.h"
- #include <dcmtk/dcmdata/dcfilefo.h>
- #include <dcmtk/dcmdata/dcfilefo.h>
- #include <dcmtk/dcmdata/dcdeftag.h>
- #include <dcmtk/dcmdata/dcdatset.h>
- #include <dcmtk/ofstd/ofcond.h>
- #include <dcmtk/ofstd/ofstring.h>
- #include <dcmtk/ofstd/ofstd.h> /* for class OFStandard */
- #include <dcmtk/dcmdata/dcddirif.h> /* for class DicomDirInterface */
- #include <dcmtk/dcmnet/scu.h>
- //------------------------------------------------------------------------------
- class ctkDICOMQueryPrivate: public ctkPrivate<ctkDICOMQuery>
- {
- public:
- ctkDICOMQueryPrivate();
- ~ctkDICOMQueryPrivate();
- QString CallingAETitle;
- QString CalledAETitle;
- QString Host;
- int Port;
- DcmSCU SCU;
- };
- //------------------------------------------------------------------------------
- // ctkDICOMQueryPrivate methods
- //------------------------------------------------------------------------------
- ctkDICOMQueryPrivate::ctkDICOMQueryPrivate()
- {
- }
- //------------------------------------------------------------------------------
- ctkDICOMQueryPrivate::~ctkDICOMQueryPrivate()
- {
- }
- //------------------------------------------------------------------------------
- // ctkDICOMQuery methods
- //------------------------------------------------------------------------------
- ctkDICOMQuery::ctkDICOMQuery()
- {
- }
- //------------------------------------------------------------------------------
- ctkDICOMQuery::~ctkDICOMQuery()
- {
- }
- /// Set methods for connectivity
- void ctkDICOMQuery::setCallingAETitle ( QString callingAETitle )
- {
- CTK_D(ctkDICOMQuery);
- d->CallingAETitle = callingAETitle;
- }
- const QString& ctkDICOMQuery::callingAETitle()
- {
- CTK_D(ctkDICOMQuery);
- return d->CallingAETitle;
- }
- void ctkDICOMQuery::setCalledAETitle ( QString calledAETitle )
- {
- CTK_D(ctkDICOMQuery);
- d->CalledAETitle = calledAETitle;
- }
- const QString& ctkDICOMQuery::calledAETitle()
- {
- CTK_D(ctkDICOMQuery);
- return d->CalledAETitle;
- }
- void ctkDICOMQuery::setHost ( QString host )
- {
- CTK_D(ctkDICOMQuery);
- d->Host = host;
- }
- const QString& ctkDICOMQuery::host()
- {
- CTK_D(ctkDICOMQuery);
- return d->Host;
- }
- void ctkDICOMQuery::setPort ( int port )
- {
- CTK_D(ctkDICOMQuery);
- d->Port = port;
- }
- int ctkDICOMQuery::port()
- {
- CTK_D(ctkDICOMQuery);
- return d->Port;
- }
- //------------------------------------------------------------------------------
- void ctkDICOMQuery::query(QSqlDatabase database )
- {
- CTK_D(ctkDICOMQuery);
- QSqlDatabase db = database;
-
- OFList<OFString> transferSyntaxes;
- transferSyntaxes.push_back ( UID_LittleEndianExplicitTransferSyntax );
- transferSyntaxes.push_back ( UID_BigEndianExplicitTransferSyntax );
- transferSyntaxes.push_back ( UID_LittleEndianImplicitTransferSyntax );
- d->SCU.addPresentationContext ( UID_FINDStudyRootQueryRetrieveInformationModel, transferSyntaxes );
- d->SCU.setAETitle ( this->callingAETitle().toStdString() );
- d->SCU.setPeerAETitle ( this->calledAETitle().toStdString() );
- d->SCU.setPeerHostName ( this->host().toStdString() );
- if ( !d->SCU.initNetwork().good() )
- {
- std::cerr << "Error initializing the network" << std::endl;
- }
- d->SCU.negotiateAssociation();
- OFString abstractSyntax;
- OFString transferSyntax;
- if ( d->SCU.sendECHORequest ( 0 ).good() )
- {
- std::cout << "ECHO Sucessful" << std::endl;
- }
- else
- {
- std::cerr << "ECHO Failed" << std::endl;
- }
- d->SCU.closeAssociation ( DUL_PEERREQUESTEDRELEASE );
- }
|