--- infoscreen/MainView.cpp 2010/05/05 08:43:40 708 +++ infoscreen/MainView.cpp 2010/06/22 07:24:14 872 @@ -2,7 +2,8 @@ #include #include #include -#include +#include +#include #include #include @@ -17,6 +18,7 @@ #include "httpwrapper.h" + MainView::MainView(QWidget* parent) : QWidget(parent), timer(0) { @@ -30,8 +32,6 @@ if (currentMode == ModeSimpleWeb){ qDebug() << "Starting plain browser mode"; - web->setVisible(true); - web->start(url,screenid); } if (currentMode == ModeLocal ) { @@ -48,26 +48,28 @@ 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); - 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); + if (currentMode == ModeSimpleWeb) { + web->setVisible(true); + web->start(url,screenid); + } if (currentMode == ModeXml || currentMode == ModeLocal) { qDebug() << "Starting timer..."; @@ -171,6 +173,16 @@ item.runtime = 10; } + if (ext == "svg") { + item.module = ModuleSvg; + item.runtime = 10; + } + + if (ext == "htm" || ext == "html") { + item.module = ModuleWeb; + item.runtime = 10; + } + if (item.module != ModuleUnknown) { //no need to enqueue unknown modules screenItems.push_back( item ); } @@ -234,20 +246,26 @@ } if (found) { - - if (currentItem.module == ModuleImage) { + switch(currentItem.module) { + case ModuleImage: ensureVisible(picture); - picture->loadFromUrl( currentItem.url ); - - } else if (currentItem.module == ModuleWeb) { + break; + case ModuleWeb: ensureVisible(web); web->load(currentItem.url); - } else if (currentItem.module == ModuleVideo) { + break; + case ModuleVideo: ensureVisible(video); video->loadUrl(currentItem.url); - } else { + break; + case ModuleSvg: + ensureVisible(svg); + svg->load(currentItem.url); + break; + default: // ModuleUnknown - what should we do?? + break; } } else { @@ -270,16 +288,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); -}