--- infoscreen/MainView.cpp 2010/01/10 10:56:34 543 +++ infoscreen/MainView.cpp 2010/06/24 10:00:51 885 @@ -2,37 +2,46 @@ #include #include #include -#include +#include +#include #include #include #include #include -#include "MyWebView.h" +#include "webview.h" #include "clientsiderender.h" #include "pictureview.h" #include "videoview.h" - +#include "clockoverlay.h" #include "httpwrapper.h" +#include "screenmanager.h" + MainView::MainView(QWidget* parent) : QWidget(parent), timer(0) { + loadSettings(); - settings = new QSettings("Caddi", "infoscreen"); - url = settings->value("url").toString(); - bool xmlMode = settings->value("xml").toBool(); - screenid = settings->value("screenid").toString(); - - if (url == "" || screenid == "") { - QMessageBox::warning(this,"infoscreen","Could not find url or screenid in config file " + settings->fileName()); + if ( currentMode == ModeXml) { + xmlUrl = url + "?screen_id=" + screenid; + qDebug() << "Starting XML mode"; + qDebug() << "xmlUrl" << xmlUrl; + qDebug() << "xmlInterval" << xmlInterval/(60*1000); + } - exit(1); //Normal qApp->exit() doesn't terminate the init sequence so use std C exit function + if (currentMode == ModeSimpleWeb){ + qDebug() << "Starting plain browser mode"; } + if (currentMode == ModeLocal ) { + qDebug() << "Starting local mode"; + qDebug() << "path" << path; + readLocalFiles(); + } this->resize(400,400); this->setWindowState( Qt::WindowFullScreen ); @@ -41,42 +50,95 @@ qApp->setOverrideCursor( QCursor( Qt::BlankCursor) ); render = new ClientSideRender(this); - render->setVisible( false ); - web = new MyWebView(this); - web->setVisible( false); + web = new WebView(this); picture = new PictureView(this); - picture->setVisible( false ); video = new VideoView(this); - video->setVisible(false); - QVBoxLayout* layout = new QVBoxLayout(); - layout->addWidget(web,1); - layout->addWidget(render,1); - layout->addWidget(picture,1); - layout->addWidget(video,1); - layout->addStretch(); + svg = new QSvgWidget(this); + + layout = new QStackedLayout(); + layout->addWidget(web); + layout->addWidget(render); + layout->addWidget(picture); + layout->addWidget(video); + layout->addWidget(svg); layout->setContentsMargins(0,0,0,0); setLayout(layout); + clockOverlay = new ClockOverlay(this); + clockOverlay->move(10,10); + clockOverlay->resize(100,50); + - - if (xmlMode == true) { - xmlUrl = url + "?screen_id=" + screenid; - qDebug() << "Starting XML mode"; - qDebug() << "xmlUrl" << xmlUrl; - - timer = new QTimer(this); - connect(timer, SIGNAL(timeout() ), this, SLOT(onTimer() )); - timer->start(100); - } else { - qDebug() << "Starting plain browser mode"; + if (currentMode == ModeSimpleWeb) { web->setVisible(true); web->start(url,screenid); } + + if (enableScreenManager) { + screenManager = new ScreenManager(screenManagerOn, screenManagerOff); + } else { + qDebug() << "ScreenManager is disabled"; + } + + + qDebug() << "Starting timer..."; + timer = new QTimer(this); + connect(timer, SIGNAL(timeout() ), this, SLOT(onTimer() )); + timer->start(100); +} + +void MainView::loadSettings() +{ + settings = new QSettings("Caddi", "infoscreen"); + + qDebug() << "Loading settings" << settings->fileName(); + + QString mode = settings->value("mode").toString().toLower(); + if (mode == "simpleweb") { + currentMode = ModeSimpleWeb; + } else if (mode == "xml") { + currentMode = ModeXml; + } else if (mode == "local") { + currentMode = ModeLocal; + } else { + currentMode = ModeNone; + QMessageBox::warning(this, "infoscreen", "no operation mode set or mode given an invalid value"); + exit(1); + } + + enableScreenManager = settings->value("enablescreenmanager").toBool(); + if (enableScreenManager) { + screenManagerOn = settings->value("screenmanager_on").toTime(); + screenManagerOff = settings->value("screenmanager_off").toTime(); + } + + xmlInterval = settings->value("xmlinterval", 30).toInt(); + xmlInterval = (xmlInterval * 60 * 1000); //convert to milliseconds + + + if (currentMode == ModeSimpleWeb || currentMode == ModeXml) { + url = settings->value("url").toString(); + screenid = settings->value("screenid").toString(); + if (url == "" || screenid == "") { + QMessageBox::warning(this,"infoscreen","Could not find url or screenid in config file " + settings->fileName()); + + exit(1); //Normal qApp->exit() doesn't terminate the init sequence so use std C exit function + } + } + + if (currentMode == ModeLocal) { + path = settings->value("path").toString(); + + if (path == "") { + QMessageBox::warning(this,"infoscreen","Could not find path in config file " + settings->fileName()); + exit(1); + } + } } void MainView::closeEvent ( QCloseEvent * event ) @@ -95,18 +157,73 @@ void MainView::onTimer() { - screenManager.timerTick(); + if (enableScreenManager == true) { + screenManager->timerTick(); + } + + if (currentMode == ModeXml) { + readXml(); + } + + if (currentMode == ModeXml || currentMode == ModeLocal) { + switchScreens(); + } + clockOverlay->timerTick(); +} + + +void MainView::readLocalFiles() +{ + QDir dir(path); + if (! dir.exists()) { + QMessageBox::warning(this,"infoscreen","Local Source directory not found: " + path); + exit(1); + } + QFileInfoList files = dir.entryInfoList(QDir::Files, QDir::Name); //only files, sort by name - readXml(); + for (int i=0; i TIMEOUT) { + if ( lastXml.isNull() || lastXml.elapsed() > xmlInterval) { + qDebug() << "Reading XML"; bool res = xmlHandler.readXml( xmlUrl ); @@ -132,7 +249,6 @@ } if (lastScreenSwitch.isNull() || lastScreenSwitch.elapsed() > (currentItem.runtime*1000)) { - QTime now = QTime::currentTime(); if (lastScreenSwitch.isNull()) currentItemIdx = -1; @@ -146,31 +262,42 @@ currentItemIdx = (currentItemIdx+1) % screenItems.size(); currentItem = screenItems.at(currentItemIdx); - if (currentItem.start <= now && now <= currentItem.stop ) + if (currentItem.start.isValid() && currentItem.stop.isValid()) { + if (currentItem.start <= now && now <= currentItem.stop ) + found = true; + } else { // if start or stop time was invalid - show them always found = true; + } } } if (found) { - - if (currentItem.module == "info_image") { + switch(currentItem.module) { + case ModuleImage: ensureVisible(picture); - picture->loadFromUrl( currentItem.url ); - - } else if (currentItem.module == "info_web") { + break; + case ModuleWeb: ensureVisible(web); web->load(currentItem.url); - } else if (currentItem.module == "info_video") { + break; + case ModuleVideo: ensureVisible(video); video->loadUrl(currentItem.url); - } else { - errorInfoScreen("Unknown module: " + currentItem.module ); + break; + case ModuleSvg: + ensureVisible(svg); + svg->load(currentItem.url); + break; + default: + // ModuleUnknown - what should we do?? + break; } } else { - qDebug() << "no screen"; errorInfoScreen("Der er ingen information at vise"); + currentItem = ScreenItem(); + currentItem.runtime = 60; //switch screens again in 1 minute } lastScreenSwitch = QTime::currentTime(); @@ -188,16 +315,6 @@ void MainView::ensureVisible(QWidget* widget) { - if (! widget->isVisible()) { - hideAll(); - widget->setVisible(true); - } + layout->setCurrentWidget(widget); } -void MainView::hideAll() -{ - render->setVisible( false ); - web->setVisible( false); - picture->setVisible( false ); - video->setVisible(false); -}