]> git.sesse.net Git - ccbs/blobdiff - bigscreen/ccbs_bigscreen.cpp
Added split screen functionality, for showing up to four groups at a time.
[ccbs] / bigscreen / ccbs_bigscreen.cpp
index fbbc0aaed7a06baf1640f63781dd814c19660382..2114093f36c8164f44d4afabba97145d5799dd13 100644 (file)
 #include "fetch_group.h"
 #include "fonts.h"
 #include "groupscreen.h"
+#include "splitscreen.h"
 
 Tournament active_tournament;
 std::vector<SkeletonGroup> active_groups;
 std::vector<GenericScreen *> screens;
+SplitScreen *mainscreen = NULL;
 unsigned char framebuf[800 * 600 * 4], screenbuf[800 * 600 * 4];
 
 void init(pqxx::connection &conn)
@@ -24,6 +26,8 @@ void init(pqxx::connection &conn)
        }
        screens.erase(screens.begin(), screens.end());
        
+       delete mainscreen;
+       
        conn.perform(FetchCurrentTournament(&active_tournament));
        conn.perform(FetchListOfActiveGroups(&active_groups));
 
@@ -39,6 +43,14 @@ void init(pqxx::connection &conn)
                        screens.push_back(new GroupScreen(conn, i->tournament, i->round, i->parallel));
                }
        }
+
+       // hack
+       screens.push_back(NULL);
+       screens.push_back(NULL);
+       screens.push_back(NULL);
+       screens.push_back(NULL);
+
+       mainscreen = new SplitScreen(screens[0], screens[1], screens[2], screens[3]);
 }
 
 void main_loop(pqxx::connection &conn)
@@ -49,17 +61,11 @@ void main_loop(pqxx::connection &conn)
                return;
        }
 
-       memset(framebuf, 0, 800*600*4);
-       
-       if (screens.size() > 0) {
-               if (screens[0]->check_invalidated()) {
-                       screens[0]->draw(screenbuf);
-               }
-
-               memcpy(framebuf, screenbuf, 800*600*4);
+       if (mainscreen->check_invalidated()) {
+               mainscreen->draw(framebuf);
        }
-
        ptc_update(framebuf);
+
        conn.await_notification(0, 50000);
 }