2 Copyright 2005 Brian Walton
4 This file is part of VOMP.
6 VOMP is free software; you can redistribute it and/or modify
7 it under the terms of the GNU General Public License as published by
8 the Free Software Foundation; either version 2 of the License, or
9 (at your option) any later version.
11 VOMP is distributed in the hope that it will be useful,
12 but WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14 GNU General Public License for more details.
16 You should have received a copy of the GNU General Public License
17 along with VOMP; if not, write to the Free Software
18 Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
29 #include "timerreceiver.h"
32 #include "wselectlist.h"
39 #define WINDOW_WIDTH (150)
40 #define MINUTE_SCALE (3)
44 class VEpg : public Boxx, public TimerReceiver
47 VEpg(void* parent, UINT currentChannel, ULONG streamType);
49 static VEpg* getInstance();
51 int handleCommand(int command); // deal with commands (from remote control)
52 void draw(); // draw epg view
53 void processMessage(Message* m);
54 void timercall(int clientReference);
57 static VEpg* instance;
59 void setInfo(Event* event); // display details of selected programme
60 void drawgrid(); // redraws grid and select programme
62 void setCurrentChannel();
64 WSelectList chanListbox; // listbox to display available channels
65 WTextbox progTitle; // area to display time and title of selected programme
66 WTextbox progInfo; // area to display details of selected programme
67 EventList* eventList; // list of events (programmes) for a channel
68 Event thisEvent; // the selected event
69 time_t selTime; // current selection time
70 UINT e; // temp used to point to an event
71 ChannelList* chanList; // list of available channels
72 tm* epgtime; // selected time within epg
73 tm* Ltime; // time of LHS of epg view
74 time_t ltime; // time of LHS of epg view
75 time_t lastEnd; // end time of last painted cell - used to look for gaps in epg
77 EventList* eventLista[7];
80 void updateChanList();
81 void updateEventList();
82 void paintCell(Event* event, int yOffset, const Colour& bg, const Colour& fg);
83 time_t prevHour(time_t* t);
87 UINT currentChannelIndex;