/[projects]/infoscreen/mainview.cpp
ViewVC logotype

Annotation of /infoscreen/mainview.cpp

Parent Directory Parent Directory | Revision Log Revision Log


Revision 874 - (hide annotations) (download)
Tue Jun 22 20:30:17 2010 UTC (13 years, 10 months ago) by torben
Original Path: infoscreen/MainView.cpp
File size: 7719 byte(s)
remove debug output
1 torben 509 #include "MainView.h"
2 torben 512 #include <QApplication>
3 torben 510 #include <QPushButton>
4 torben 512 #include <QLabel>
5 torben 870 #include <QStackedLayout>
6 torben 867 #include <QSvgWidget>
7 torben 509
8 torben 510 #include <QTimer>
9 torben 533 #include <QKeyEvent>
10 torben 535 #include <QSettings>
11     #include <QMessageBox>
12 torben 510
13 torben 512 #include "MyWebView.h"
14 torben 515 #include "clientsiderender.h"
15 torben 524 #include "pictureview.h"
16 torben 527 #include "videoview.h"
17 torben 511
18 torben 528 #include "httpwrapper.h"
19    
20    
21 torben 870
22 torben 509 MainView::MainView(QWidget* parent)
23 torben 537 : QWidget(parent), timer(0)
24 torben 509 {
25 torben 638 loadSettings();
26 torben 535
27 torben 638 if ( currentMode == ModeXml) {
28     xmlUrl = url + "?screen_id=" + screenid;
29     qDebug() << "Starting XML mode";
30     qDebug() << "xmlUrl" << xmlUrl;
31     }
32 torben 535
33 torben 638 if (currentMode == ModeSimpleWeb){
34     qDebug() << "Starting plain browser mode";
35 torben 535 }
36    
37 torben 638 if (currentMode == ModeLocal ) {
38     qDebug() << "Starting local mode";
39     qDebug() << "path" << path;
40 torben 535
41 torben 638 readLocalFiles();
42     }
43 torben 535
44 torben 534 this->resize(400,400);
45     this->setWindowState( Qt::WindowFullScreen );
46     this->grabKeyboard();
47 torben 516
48 torben 534 qApp->setOverrideCursor( QCursor( Qt::BlankCursor) );
49 torben 510
50 torben 534 render = new ClientSideRender(this);
51 torben 524
52 torben 534 web = new MyWebView(this);
53 torben 511
54 torben 534 picture = new PictureView(this);
55 torben 517
56 torben 534 video = new VideoView(this);
57 torben 517
58 torben 867 svg = new QSvgWidget(this);
59    
60 torben 870 layout = new QStackedLayout();
61     layout->addWidget(web);
62     layout->addWidget(render);
63     layout->addWidget(picture);
64     layout->addWidget(video);
65     layout->addWidget(svg);
66 torben 534 layout->setContentsMargins(0,0,0,0);
67     setLayout(layout);
68 torben 510
69 torben 872 if (currentMode == ModeSimpleWeb) {
70     web->setVisible(true);
71     web->start(url,screenid);
72     }
73 torben 528
74 torben 873
75     qDebug() << "Starting timer...";
76     timer = new QTimer(this);
77     connect(timer, SIGNAL(timeout() ), this, SLOT(onTimer() ));
78     timer->start(100);
79 torben 537 }
80 torben 535
81 torben 638 void MainView::loadSettings()
82     {
83     settings = new QSettings("Caddi", "infoscreen");
84    
85     qDebug() << "Loading settings" << settings->fileName();
86    
87     QString mode = settings->value("mode").toString().toLower();
88     if (mode == "simpleweb") {
89     currentMode = ModeSimpleWeb;
90     } else if (mode == "xml") {
91     currentMode = ModeXml;
92     } else if (mode == "local") {
93     currentMode = ModeLocal;
94     } else {
95     currentMode = ModeNone;
96     QMessageBox::warning(this, "infoscreen", "no operation mode set or mode given an invalid value");
97     exit(1);
98     }
99    
100    
101     if (currentMode == ModeSimpleWeb || currentMode == ModeXml) {
102     url = settings->value("url").toString();
103     screenid = settings->value("screenid").toString();
104     if (url == "" || screenid == "") {
105     QMessageBox::warning(this,"infoscreen","Could not find url or screenid in config file " + settings->fileName());
106    
107     exit(1); //Normal qApp->exit() doesn't terminate the init sequence so use std C exit function
108     }
109     }
110    
111     if (currentMode == ModeLocal) {
112     path = settings->value("path").toString();
113    
114     if (path == "") {
115     QMessageBox::warning(this,"infoscreen","Could not find path in config file " + settings->fileName());
116     exit(1);
117     }
118     }
119     }
120    
121 torben 537 void MainView::closeEvent ( QCloseEvent * event )
122     {
123     Q_UNUSED(event);
124     exit(0); //force application shutdown
125 torben 509 }
126    
127 torben 532 void MainView::keyPressEvent ( QKeyEvent* event )
128     {
129 torben 533 int key = event->key();
130     if (key == ' ' || key == Qt::Key_Return || key == Qt::Key_Enter) {
131 torben 537 close();
132 torben 533 }
133 torben 532 }
134 torben 509
135     void MainView::onTimer()
136     {
137 torben 512 screenManager.timerTick();
138 torben 524
139 torben 638 if (currentMode == ModeXml) {
140     readXml();
141     }
142 torben 527
143 torben 873 if (currentMode == ModeXml || currentMode == ModeLocal) {
144     switchScreens();
145     }
146 torben 528 }
147 torben 527
148 torben 524
149 torben 638 void MainView::readLocalFiles()
150     {
151     QDir dir(path);
152     if (! dir.exists()) {
153     QMessageBox::warning(this,"infoscreen","Local Source directory not found: " + path);
154     exit(1);
155     }
156     QFileInfoList files = dir.entryInfoList(QDir::Files, QDir::Name); //only files, sort by name
157    
158     for (int i=0; i<files.size(); ++i) {
159     QFileInfo file = files[i];
160     qDebug() << "Found" << file.fileName();
161    
162     ScreenItem item;
163     item.url = file.filePath();
164     item.module = ModuleUnknown;
165    
166     QString ext = file.suffix().toLower();
167 torben 708 if (ext == "avi" || ext == "mpg" || ext == "mpeg") {
168 torben 638 item.module = ModuleVideo;
169     item.runtime = 1;
170     }
171    
172 torben 708 if (ext == "jpg" || ext == "jpeg" || ext == "png" ) {
173 torben 638 item.module = ModuleImage;
174     item.runtime = 10;
175     }
176    
177 torben 867 if (ext == "svg") {
178     item.module = ModuleSvg;
179     item.runtime = 10;
180     }
181 torben 869
182     if (ext == "htm" || ext == "html") {
183     item.module = ModuleWeb;
184     item.runtime = 10;
185     }
186 torben 867
187 torben 638 if (item.module != ModuleUnknown) { //no need to enqueue unknown modules
188     screenItems.push_back( item );
189     }
190    
191     }
192    
193     qDebug() << "Found " << screenItems.size() << " playable items";
194     }
195    
196    
197 torben 528 bool MainView::readXml()
198     {
199     const int TIMEOUT = 30*60*1000; // 30 minutter
200     if ( lastXml.isNull() || lastXml.elapsed() > TIMEOUT) {
201 torben 529
202 torben 527
203 torben 537 bool res = xmlHandler.readXml( xmlUrl );
204 torben 535
205 torben 528 lastXml = QTime::currentTime();
206    
207     screenItems = xmlHandler.getScreenSet();
208    
209     if ( currentItemIdx >= screenItems.size() )
210     currentItemIdx = screenItems.size()-1; //avoid overflow
211    
212    
213     return true;
214     } else {
215     return false;
216 torben 524 }
217 torben 509 }
218 torben 528
219     void MainView::switchScreens()
220     {
221 torben 537 if (video->isVisible() && video->isPlaying() ) {
222     return; //wait until current clip has finished
223     }
224 torben 528
225     if (lastScreenSwitch.isNull() || lastScreenSwitch.elapsed() > (currentItem.runtime*1000)) {
226    
227 torben 529 QTime now = QTime::currentTime();
228 torben 528 if (lastScreenSwitch.isNull())
229 torben 529 currentItemIdx = -1;
230    
231     bool found = false;
232     int tries = 0;
233    
234 torben 534 if (screenItems.size() > 0) { //only try if we have a any screens
235     while (found == false && tries <= screenItems.size()) { //find next with valid display time
236     tries++;
237     currentItemIdx = (currentItemIdx+1) % screenItems.size();
238     currentItem = screenItems.at(currentItemIdx);
239 torben 529
240 torben 638 if (currentItem.start.isValid() && currentItem.stop.isValid()) {
241     if (currentItem.start <= now && now <= currentItem.stop )
242     found = true;
243     } else { // if start or stop time was invalid - show them always
244 torben 534 found = true;
245 torben 638 }
246 torben 534 }
247 torben 529 }
248    
249     if (found) {
250 torben 867 switch(currentItem.module) {
251     case ModuleImage:
252 torben 529 ensureVisible(picture);
253     picture->loadFromUrl( currentItem.url );
254 torben 867 break;
255     case ModuleWeb:
256 torben 537 ensureVisible(web);
257     web->load(currentItem.url);
258 torben 867 break;
259     case ModuleVideo:
260 torben 537 ensureVisible(video);
261     video->loadUrl(currentItem.url);
262 torben 867 break;
263     case ModuleSvg:
264     ensureVisible(svg);
265     svg->load(currentItem.url);
266     break;
267     default:
268 torben 638 // ModuleUnknown - what should we do??
269 torben 867 break;
270 torben 537 }
271 torben 529
272     } else {
273     qDebug() << "no screen";
274 torben 542 errorInfoScreen("Der er ingen information at vise");
275 torben 529 }
276 torben 528 lastScreenSwitch = QTime::currentTime();
277 torben 529
278 torben 528 }
279     }
280 torben 529
281 torben 542 void MainView::errorInfoScreen(QString msg)
282 torben 537 {
283     ensureVisible(web);
284     web->setHtml("<html>\
285     <body text='#505050' bgcolor='#000000'>\
286 torben 542 <table width='100%' height='100%'><tr><td align='center' valign='middel'><h1>" + msg+ "</h1></td></tr></table>\
287 torben 537 </body></html>");
288     }
289    
290 torben 529 void MainView::ensureVisible(QWidget* widget)
291     {
292 torben 870 layout->setCurrentWidget(widget);
293 torben 529 }

  ViewVC Help
Powered by ViewVC 1.1.20