]> git.vomp.tv Git - vompclient.git/blob - vlivebanner.cc
Prebuffering
[vompclient.git] / vlivebanner.cc
1 /*
2     Copyright 2004-2005 Chris Tallon
3
4     This file is part of VOMP.
5
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.
10
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.
15
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., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA
19 */
20
21 #include "vlivebanner.h"
22
23 VLiveBanner* VLiveBanner::instance = NULL;
24
25 VLiveBanner::VLiveBanner(VVideoLive* tvvideoLive, Channel* channel, bool bannerTakesCommands)
26 {
27   instance = this;
28   eventList = NULL;
29   vvideoLive = tvvideoLive;
30   takeCommands = bannerTakesCommands;
31
32   clockRegion.x = 440;
33   clockRegion.y = 0;
34   clockRegion.w = 60;
35   clockRegion.h = 30;
36
37   create(500, 120);
38   if (Video::getInstance()->getFormat() == Video::PAL)
39   {
40     setScreenPos(124, 410);
41   }
42   else
43   {
44     setScreenPos(114, 320);
45   }
46
47
48   setBackgroundColour(Colour::VIEWBACKGROUND);
49   setTitleBarOn(1);
50   setTitleBarColour(Colour::TITLEBARBACKGROUND);
51
52   sl.setSurface(surface);
53   sl.setSurfaceOffset(0, 30);
54   sl.setDimensions(area.w, area.h - 60);
55   sl.setNoLoop();
56
57   setChannel(channel);
58 }
59
60 VLiveBanner::~VLiveBanner()
61 {
62   instance = NULL;
63   Timers::getInstance()->cancelTimer(this, 1);
64   Timers::getInstance()->cancelTimer(this, 2);
65   delData();
66 }
67
68 VLiveBanner* VLiveBanner::getInstance()
69 {
70   return instance;
71 }
72
73 void VLiveBanner::delData()
74 {
75   if (eventList)
76   {
77     int eventListSize = eventList->size();
78     for(int i = 0; i < eventListSize; i++)
79     {
80       delete (*eventList)[i];
81     }
82     eventList->clear();
83     delete eventList;
84
85   }
86   sl.clear();
87 }
88
89 void VLiveBanner::setChannel(Channel* tChannel)
90 {
91   delData();
92   currentChannel = tChannel;
93   // get the data
94
95   char ttitleText[100];
96   SNPRINTF(ttitleText, 99, "%03lu - %s", currentChannel->number, currentChannel->name);
97
98   setTitleText(ttitleText);
99   eventList = VDR::getInstance()->getChannelSchedule(currentChannel->number);
100
101   if (!eventList)
102   {
103     sl.addOption(tr("No channel data available"), 1);
104   }
105   else
106   {
107     sort(eventList->begin(), eventList->end(), EventSorter());
108
109     char tempString[300];
110     char tempString2[300];
111     struct tm* btime;
112     Event* event;
113     int first = 1;
114     int eventListSize = eventList->size();
115     for(int i = 0; i < eventListSize; i++)
116     {
117       event = (*eventList)[i];
118
119       btime = localtime((time_t*)&event->time);
120 #ifndef _MSC_VER
121       strftime(tempString2, 299, "%0H:%0M ", btime);
122 #else
123     strftime(tempString2, 299, "%H:%M ", btime);
124 #endif
125       SNPRINTF(tempString, 299, "%s %s", tempString2, event->title);
126       event->index = sl.addOption(tempString, first);
127       first = 0;
128     }
129   }
130
131   // Reset the timer as it probably took 1-2 seconds to change the channel
132   Timers::getInstance()->setTimerD(this, 1, 4);
133 }
134
135 void VLiveBanner::draw()
136 {
137   View::draw();
138   sl.draw();
139   rectangle(0, area.h - 30, area.w, 30, titleBarColour);
140
141   rectangle(7, area.h - 24, 18, 16, Colour::RED);
142   drawText(tr("EPG"), 32, area.h - 25, Colour::LIGHTTEXT);
143
144   rectangle(110, area.h - 24, 18, 16, Colour::GREEN);
145   drawText(tr("info"), 135, area.h - 25, Colour::LIGHTTEXT);
146
147   drawClock();
148 }
149
150 int VLiveBanner::handleCommand(int command)
151 {
152   switch (command)
153   {
154     case Remote::OK:
155     case Remote::BACK:
156     {
157       Timers::getInstance()->cancelTimer(this, 1); // if it exists
158       return 4;
159     }
160     case Remote::DF_UP:
161     {
162       if (!takeCommands) return 0; // banner was auto, old remote
163     } // else drop through
164     case Remote::UP:
165     {
166       sl.up();
167       sl.draw();
168
169       ViewMan::getInstance()->updateView(this);
170
171       // Arrows pressed, go to an 8s timer
172       Timers::getInstance()->setTimerD(this, 1, 8);
173
174       return 2;
175     }
176     case Remote::DF_DOWN:
177     {
178       if (!takeCommands) return 0; // banner was auto, old remote
179     } // else drop through
180     case Remote::DOWN:
181     {
182       sl.down();
183       sl.draw();
184
185       ViewMan::getInstance()->updateView(this);
186
187       // Arrows pressed, go to an 8s timer
188       Timers::getInstance()->setTimerD(this, 1, 8);
189
190       return 2;
191     }
192     case Remote::CHANNELUP:
193     {
194       // cancel timer so this view is still here later
195       Timers::getInstance()->cancelTimer(this, 1); // if it exists
196       vvideoLive->channelChange(VVideoLive::OFFSET, VVideoLive::UP);
197       return 2;
198     }
199     case Remote::CHANNELDOWN:
200     {
201       // cancel timer so this view is still here later
202       Timers::getInstance()->cancelTimer(this, 1); // if it exists
203       vvideoLive->channelChange(VVideoLive::OFFSET, VVideoLive::DOWN);
204       return 2;
205     }
206     case Remote::GREEN:
207     case Remote::MENU:
208     {
209       if (!eventList) return 2;
210       Event* event;
211       int eventListSize = eventList->size();
212       for(int i = 0; i < eventListSize; i++)
213       {
214         event = (*eventList)[i];
215         if (event->index == sl.getCurrentOption())
216         {
217           Log::getInstance()->log("VLiveBanner", Log::DEBUG, "Found the option you pointed at. %s", event->title);
218           // First, cancel my delete timer
219           Timers::getInstance()->cancelTimer(this, 1); // if it exists
220
221           VInfo* vi = new VInfo();
222           vi->setTitleText(event->title);
223           vi->setBorderOn(1);
224           vi->setExitable();
225           if (event->description) vi->setMainText(event->description);
226           else vi->setMainText(tr("Summary unavailable"));
227           if (Video::getInstance()->getFormat() == Video::PAL)
228           {
229             vi->setScreenPos(120, 130);
230           }
231           else
232           {
233             vi->setScreenPos(110, 90);
234           }
235           vi->create(510, 270);
236           vi->draw();
237
238           ViewMan::getInstance()->add(vi);
239           ViewMan::getInstance()->updateView(vi);
240
241           return 2;
242
243         }
244       }
245       return 2; // should not get here
246     }
247     case Remote::GUIDE:
248     case Remote::RED:
249     {
250       // full epg
251       Timers::getInstance()->cancelTimer(this, 1); // if it exists
252       Message* m = new Message(); // Must be done after this view deleted
253       m->message = Message::EPG;
254       m->to = vvideoLive;
255       m->from = this;
256       ViewMan::getInstance()->postMessage(m);
257       return 4;
258     }
259   }
260
261   return 1;
262 }
263
264 void VLiveBanner::timercall(int clientReference)
265 {
266   if (clientReference == 1)
267   {
268     // delete me!
269     Message* m = new Message();  // Delete self
270     m->message = Message::CLOSE_ME;
271     m->to = ViewMan::getInstance();
272     m->from = this;
273     ViewMan::getInstance()->postMessage(m);
274   }
275   else if (clientReference == 2)
276   {
277     // redraw clock
278     drawClock();
279     ViewMan::getInstance()->updateView(this, &clockRegion);
280   }
281 }
282
283 void VLiveBanner::drawClock()
284 {
285   // Blank the area first
286   rectangle(area.w - 60, 0, 60, 30, titleBarColour);
287
288   char timeString[20];
289   time_t t;
290   time(&t);
291   struct tm* tms = localtime(&t);
292   strftime(timeString, 19, "%H:%M", tms);
293   drawTextRJ(timeString, 490, 5, Colour::LIGHTTEXT);
294
295   time_t dt = 60 - (t % 60);  // seconds to the next minute
296   if (dt == 0) dt = 60; // advance a whole minute if necessary
297   dt += t;  // get a time_t value for it rather than using duration
298   // (so it will occur at the actual second and not second and a half)
299
300   Timers::getInstance()->setTimerT(this, 2, dt);
301 }