ctkDicomExampleHost.cpp 2.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  1. #include "ctkDicomExampleHost.h"
  2. #include "ctkDicomWG23TypesHelper.h"
  3. #include <QProcess>
  4. #include <QtDebug>
  5. #include <QRect>
  6. #include <iostream>
  7. ctkDicomExampleHost::ctkDicomExampleHost(ctkHostedAppPlaceholderWidget* placeholderWidget, int hostPort, int appPort) :
  8. ctkDicomAbstractHost(hostPort, appPort),
  9. placeholderWidget(placeholderWidget),
  10. applicationState(ctkDicomWG23::IDLE)
  11. {
  12. connect(&this->appProcess,SIGNAL(readyReadStandardOutput()),SLOT(forwardConsoleOutput()));
  13. }
  14. void ctkDicomExampleHost::StartApplication(QString AppPath){
  15. QStringList l;
  16. l.append("--hostURL");
  17. l.append(QString("http://localhost:") + QString::number(this->getHostPort()) + "/HostInterface" );
  18. l.append("--applicationURL");
  19. l.append(QString("http://localhost:") + QString::number(this->getAppPort()) + "/ApplicationInterface" );
  20. l.append("dicomapp"); // the app plugin to use - has to be changed later
  21. //if (!QProcess::startDetached (
  22. //{
  23. // qCritical() << "application failed to start!";
  24. //}
  25. //qDebug() << "starting application: " << AppPath << " " << l;
  26. qDebug() << "starting application: " << AppPath << " " << l;
  27. this->appProcess.setProcessChannelMode(QProcess::MergedChannels);
  28. this->appProcess.start(AppPath,l);
  29. }
  30. QRect ctkDicomExampleHost::getAvailableScreen(const QRect& preferredScreen){
  31. qDebug()<< "Application asked for this area:"<< preferredScreen;
  32. QRect rect (this->placeholderWidget->getAbsolutePosition());
  33. emit giveAvailableScreen(rect);
  34. return rect;
  35. }
  36. void ctkDicomExampleHost::notifyStateChanged(ctkDicomWG23::State state){
  37. qDebug()<< "new state received:"<< static_cast<int>(state);
  38. qDebug()<< "new state received:"<< ctkDicomSoapState::toStringValue(state);
  39. emit stateChangedReceived(state);
  40. }
  41. void ctkDicomExampleHost::notifyStatus(const ctkDicomWG23::Status& status){
  42. qDebug()<< "new status received:"<<status.codeMeaning;
  43. emit statusReceived(status);;
  44. }
  45. ctkDicomExampleHost::~ctkDicomExampleHost()
  46. {
  47. qDebug() << "Exiting host: trying to terminate app";
  48. this->appProcess.terminate();
  49. qDebug() << "Exiting host: trying to kill app";
  50. this->appProcess.kill();
  51. }
  52. void ctkDicomExampleHost::forwardConsoleOutput()
  53. {
  54. while( this->appProcess.bytesAvailable() )
  55. {
  56. QString line( this->appProcess.readLine() );
  57. line.prepend(">>>> ");
  58. std::cout << line.toStdString();
  59. }
  60. }