--- infoscreen/MainView.cpp 2010/06/21 13:32:45 869 +++ infoscreen/MainView.cpp 2010/06/22 20:29:40 873 @@ -2,7 +2,7 @@ #include #include #include -#include +#include #include #include @@ -18,6 +18,7 @@ #include "httpwrapper.h" + MainView::MainView(QWidget* parent) : QWidget(parent), timer(0) { @@ -31,8 +32,6 @@ if (currentMode == ModeSimpleWeb){ qDebug() << "Starting plain browser mode"; - web->setVisible(true); - web->start(url,screenid); } if (currentMode == ModeLocal ) { @@ -49,37 +48,34 @@ qApp->setOverrideCursor( QCursor( Qt::BlankCursor) ); render = new ClientSideRender(this); - render->setVisible( false ); web = new MyWebView(this); - web->setVisible( false); picture = new PictureView(this); - picture->setVisible( false ); video = new VideoView(this); - video->setVisible(false); svg = new QSvgWidget(this); - svg->setVisible(false); - QVBoxLayout* layout = new QVBoxLayout(); - layout->addWidget(web,1); - layout->addWidget(render,1); - layout->addWidget(picture,1); - layout->addWidget(video,1); - layout->addWidget(svg,1); - layout->addStretch(); + 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); - - if (currentMode == ModeXml || currentMode == ModeLocal) { - qDebug() << "Starting timer..."; - timer = new QTimer(this); - connect(timer, SIGNAL(timeout() ), this, SLOT(onTimer() )); - timer->start(100); + if (currentMode == ModeSimpleWeb) { + web->setVisible(true); + web->start(url,screenid); } + + + qDebug() << "Starting timer..."; + timer = new QTimer(this); + connect(timer, SIGNAL(timeout() ), this, SLOT(onTimer() )); + timer->start(100); } void MainView::loadSettings() @@ -138,13 +134,16 @@ void MainView::onTimer() { + qDebug() << "onTimer()"; screenManager.timerTick(); if (currentMode == ModeXml) { readXml(); } - switchScreens(); + if (currentMode == ModeXml || currentMode == ModeLocal) { + switchScreens(); + } } @@ -291,17 +290,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); - svg->setVisible(false); -}