]> git.vomp.tv Git - vompclient.git/blob - vepglistadvanced.cc
Added basic skinning support and a new different looking skin, additionally some...
[vompclient.git] / vepglistadvanced.cc
1 /*
2     Copyright 2004-2007 Chris Tallon, 2014 Marten Richter
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., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
19 */
20
21 #include "vepglistadvanced.h"
22
23 #include "boxstack.h"
24 #include "remote.h"
25 #include "wsymbol.h"
26 #include "boxstack.h"
27 #include "vdr.h"
28 #include "colour.h"
29 #include "video.h"
30 #include "i18n.h"
31 #include "command.h"
32 #include "log.h"
33 #include "movieinfo.h"
34 #include "seriesinfo.h"
35 #include "event.h"
36 #include "channel.h"
37 #include "vepgsummary.h"
38 #include "vepgsettimer.h"
39 #include "vepg.h"
40
41 #include <sstream>
42
43
44 VEpgListAdvanced::VEpgListAdvanced(VVideoLiveTV *tvideolive, ChannelList* tchanList,ULONG initialChannelNumber)
45 {
46         channelNumber = initialChannelNumber;
47         chanList = tchanList;
48         videolive = tvideolive;
49         boxstack = BoxStack::getInstance();
50
51         mode = OneChannel;
52
53         setSize(640+40, 500+40); //old   setSize(570, 420);
54         createBuffer();
55
56         setPosition(20, 20);
57
58         setTitleBarOn(1);
59         setTitleBarColour(DrawStyle::TITLEBARBACKGROUND);
60
61         sl.setPosition(10, 30 + 5);
62         sl.setSize(area.w*42/100 - 20, area.h - 30 - 15 - 30);
63         sl.setLinesPerOption(2.4f);
64         add(&sl);
65
66         Region slarea=sl.getRegionR();
67
68         epg.setParaMode(true);
69         epg.setPosition(slarea.x  +slarea.w+10 ,30+5);
70         epg.setSize(area.w -slarea.x -slarea.w -10, area.h - 30 - 15 - 30);
71         add(&epg);
72         epg.setText("");
73         epg.setVideoBackground();
74         epg.setBackgroundColour(DrawStyle::VIEWTRANSPARENTBACKGROUND);
75
76         epgTVmedia.setPosition(epg.getRegionR().w-100-10,10);
77         epgTVmedia.setSize(100,150/Osd::getInstance()->getPixelAspect());
78         epg.add(&epgTVmedia);
79
80         boxRed.setBackgroundColour(DrawStyle::RED);
81         boxRed.setPosition(165 /*54*/, sl.getY2()+8);
82         boxRed.setSize(18, 16);
83         add(&boxRed);
84
85         textRed.setPosition(boxRed.getX2(), sl.getY2()+4);
86         textRed.setSize(116, 30);
87
88         add(&textRed);
89
90         boxGreen.setBackgroundColour(DrawStyle::GREEN);
91         boxGreen.setPosition(165 +1*110, sl.getY2()+8);
92         boxGreen.setSize(18, 16);
93         add(&boxGreen);
94
95         textGreen.setPosition(boxGreen.getX2(), sl.getY2()+4);
96         textGreen.setSize(116, 30);
97         add(&textGreen);
98
99         boxYellow.setBackgroundColour(DrawStyle::YELLOW);
100         boxYellow.setPosition(165 +2*110, sl.getY2()+8);
101         boxYellow.setSize(18, 16);
102         add(&boxYellow);
103
104         textYellow.setPosition(boxYellow.getX2(), sl.getY2()+4);
105         textYellow.setSize(116, 30);
106         add(&textYellow);
107
108         boxBlue.setBackgroundColour(DrawStyle::BLUE);
109         boxBlue.setPosition(165 +3*110, sl.getY2()+8);
110         boxBlue.setSize(18, 16);
111         add(&boxBlue);
112
113         textBlue.setPosition(boxBlue.getX2(), sl.getY2()+4);
114         textBlue.setSize(116, 30);
115         add(&textBlue);
116
117         setButtonText();
118
119
120         updateEpgDataChannel();
121 }
122
123 VEpgListAdvanced::~VEpgListAdvanced()
124 {
125         clearEventList();
126 }
127
128
129 void VEpgListAdvanced::setButtonText()
130 {
131         switch (mode)
132         {
133         case OneChannel: {
134                 textRed.setText(tr("Record"));
135                 textGreen.setText(tr("Now"));
136                 textYellow.setText(tr("Next"));
137                 textBlue.setText(tr("Guide"));
138
139         } break;
140         case Now: {
141                 textRed.setText(tr("Record"));
142                 textGreen.setText(tr("Next"));
143                 textYellow.setText(tr("Schedule"));
144                 textBlue.setText(tr("Switch"));
145         } break;
146         case Next: {
147                 textRed.setText(tr("Record"));
148                 textGreen.setText(tr("Now"));
149                 textYellow.setText(tr("Schedule"));
150                 textBlue.setText(tr("Switch"));
151         } break;
152
153         };
154 }
155
156 void VEpgListAdvanced::doRed()
157 {
158         doRecord();
159 }
160
161 void VEpgListAdvanced::doGreen()
162 {
163         switch (mode)
164         {
165         case Now: {
166                 doNext();
167         } break;
168         case OneChannel:
169         case Next: {
170                 doNow();
171         } break;
172         };
173 }
174
175 void VEpgListAdvanced::doYellow()
176 {
177         switch (mode)
178         {
179         case OneChannel: {
180                 doNext();
181         } break;
182         case Next:
183         case Now: {
184                 doProgramm();
185         } break;
186         };
187 }
188
189 void VEpgListAdvanced::doBlue()
190 {
191         switch (mode)
192         {
193         case OneChannel: {
194                 doGrid();
195         } break;
196         case Next:
197         case Now: {
198                 doSwitch();
199         } break;
200         };
201 }
202
203 void VEpgListAdvanced::doNext()
204 {
205         Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "doNext");
206         if (mode!=OneChannel) {
207                 Channel * chan=(*chanList)[ sl.getCurrentOptionData()];
208                 channelNumber = chan->number;
209         }
210         mode=Next;
211         updateEpgDataNowNext(true);
212         setButtonText();
213         draw(true);
214         boxstack->update(this);
215 }
216 void VEpgListAdvanced::doNow()
217 {
218         Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "doNow");
219         if (mode!=OneChannel) {
220                 Channel * chan=(*chanList)[ sl.getCurrentOptionData()];
221                 channelNumber = chan->number;
222         }
223         mode=Now;
224         updateEpgDataNowNext(true);
225         setButtonText();
226         draw(true);
227         boxstack->update(this);
228 }
229
230 void VEpgListAdvanced::doProgramm()
231 {
232         Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "doProgram");
233         mode=OneChannel;
234
235         Channel * chan=(*chanList)[ sl.getCurrentOptionData()];
236         channelNumber = chan->number;
237         updateEpgDataChannel();
238         setButtonText();
239         draw(true);
240         boxstack->update(this);
241 }
242
243 void VEpgListAdvanced::doSwitch()
244 {
245
246         if (videolive)
247         {
248                 if (mode!=OneChannel) {
249                         Channel * chan=(*chanList)[ sl.getCurrentOptionData()];
250                         channelNumber = chan->number;
251                 }
252                 Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "doSwitch %d", channelNumber);
253                 Message* m = new Message(); // Must be done after this view deleted
254                 m->from = this;
255                 m->to = videolive;
256                 m->message = Message::CHANNEL_CHANGE;
257                 m->parameter = channelNumber;
258                 m->tag = 0;
259                 Command::getInstance()->postMessageNoLock(m);
260         }
261 }
262
263 void VEpgListAdvanced::doRecord()
264 {
265         int channel;
266         Event* current = getCurrentOptionEvent(channel);
267         if (current)
268         {
269                 Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "Found the option you pointed at. %s %d", current->title, current->id);
270                 unsigned int chanlistsize=chanList->size();
271                 Channel * chan;
272                 UINT listIndex;
273                 for(listIndex = 0; listIndex < chanlistsize; listIndex++)
274                 {
275                         chan = (*chanList)[listIndex];
276                         if (chan->number == channel) break;
277                 }
278
279                 Log::getInstance()->log("VEpgSummary", Log::DEBUG, "ID %lu TIME %lu DURATION %lu TITLE %s", current->id, current->time,
280                                 current->duration, current->title);
281                 VEpgSetTimer* vs = new VEpgSetTimer(current, chan);
282                 vs->draw();
283                 boxstack->add(vs);
284                 boxstack->update(vs);
285         }
286
287 }
288
289 void VEpgListAdvanced::doGrid()
290 {
291
292         if (mode!=OneChannel) {
293                 Channel * chan=(*chanList)[ sl.getCurrentOptionData()];
294                 channelNumber = chan->number;
295         }
296         UINT listIndex;
297         unsigned int chanlistsize=chanList->size();
298         Channel *chan;
299         for(listIndex = 0; listIndex < chanlistsize; listIndex++)
300         {
301                 chan = (*chanList)[listIndex];
302                 if (chan->number == channelNumber) break;
303         }
304
305         VEpg* vepg = new VEpg(videolive, listIndex, chanList);
306         vepg->draw();
307         boxstack->add(vepg);
308         boxstack->update(vepg);
309
310 }
311
312 void VEpgListAdvanced::clearEventList()
313 {
314         std::vector<EventList*>::iterator itty = eventLista.begin();
315         while (itty!= eventLista.end()) {
316                 if (*itty) {
317                         (*itty)->clear();
318                         delete (*itty);
319                 }
320                 itty++;
321         }
322         eventLista.clear();
323
324 }
325
326
327 /* Prototype
328  *
329  *   if (!chanList) return;
330   Channel* chan;
331   for(UINT listIndex = 0; listIndex < gridRows; listIndex++)
332   {
333     if(listTop + listIndex >= UINT(chanListbox.getBottomOption()))
334       continue;
335     chan = (*chanList)[listTop + listIndex];
336     eventLista[listIndex] = VDR::getInstance()->getChannelSchedule(chan->number, ltime - 1, window_width * 60 + 2); // ltime - 1 to get prog before window (allows cursor left past ltime). + 2 to get prog after window
337   }
338
339  */
340
341 void VEpgListAdvanced::updateEpgData()
342 {
343         switch (mode)
344         {
345         case OneChannel: {
346                 //updateEpgDataChannel();
347         } break;
348         case Next:
349         case Now: {
350                 updateEpgDataNowNext(false);
351         } break;
352         };
353
354 }
355
356 void VEpgListAdvanced::updateEpgDataNowNext(bool changeState)
357 {
358         int startupdate=0;
359         int endupdate=0;
360
361         unsigned int chanlistsize=chanList->size();
362         if (changeState) {
363                 clearEventList();
364                 eventLista.resize(chanList->size());
365                 Channel* chan;
366                 for(UINT listIndex = 0; listIndex < chanlistsize; listIndex++)
367                 {
368                         if (listIndex < 0) continue;
369                         if (listIndex >= chanlistsize) continue;
370                         chan = (*chanList)[listIndex];
371                         if (chan->number == channelNumber) {
372                                 startupdate = listIndex-sl.getNumOptionsDisplayable()-2;
373                                 endupdate = listIndex+sl.getNumOptionsDisplayable()+2;
374                                 break;
375                         }
376                 }
377         } else {
378                 startupdate=sl.getTopOption()-2;
379                 endupdate=sl.getBottomOption()+1;
380         }
381
382         time_t now;
383         time(&now);
384
385         Channel* chan;
386         for(int listIndex = startupdate; listIndex < endupdate; listIndex++)
387         {
388                 if (listIndex < 0) continue;
389                 if (listIndex >= chanlistsize) continue;
390
391             chan = (*chanList)[listIndex];
392                 if (!eventLista[listIndex]) eventLista[listIndex] = VDR::getInstance()->getChannelSchedule(chan->number, now, 4 * 60 *60);
393
394         }
395
396 }
397
398 void VEpgListAdvanced::updateEpgDataChannel()
399 {
400         clearEventList();
401         eventLista.resize(1);
402         time_t now;
403         time(&now);
404         eventLista[0] = VDR::getInstance()->getChannelSchedule(channelNumber, now, 24 * 60 *60 *30); // one month
405         Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "Eventlist %x %d", eventLista[0],channelNumber);
406
407 }
408
409 void VEpgListAdvanced::drawData(bool doIndexPop)
410 {
411         switch (mode)
412         {
413         case OneChannel: {
414                 drawDataChannel(doIndexPop);
415         } break;
416         case Next: {
417                 drawDataNowNext(true, doIndexPop);
418         } break;
419         case Now: {
420                 drawDataNowNext(false, doIndexPop);
421         } break;
422         };
423
424 }
425
426 void VEpgListAdvanced::drawDataChannel(bool doIndexPop)
427 {
428   int saveIndex = sl.getCurrentOption();
429   int saveTop = sl.getTopOption();
430   sl.clear();
431   sl.addColumn(0);
432   sl.addColumn(25 );
433   sl.addColumn(25 + 7);
434   //sl.addColumn(118);
435
436   int first = 1;
437
438   char tempA[300]; // FIXME  this is guesswork!
439   char tempB[300]; // FIXME
440   char tempC[300]; // FIXME
441   struct tm* btime;
442
443
444
445   Event* currentEvent;
446   EventList::iterator j;
447   EventList* eventList = eventLista[0];
448   if (eventList) {
449           for (j = eventList->begin(); j != eventList->end(); j++)
450           {
451                   currentEvent = *j;
452                   time_t eventStartTime = (time_t)currentEvent->time;
453                   time_t eventEndTime = (time_t)(currentEvent->time + currentEvent->duration);
454
455                   btime = localtime(&eventStartTime);
456                   strftime(tempA, 299, "%d/%m/%y %H:%M ", btime);
457                   btime = localtime(&eventEndTime);
458                   strftime(tempB, 299, "- %H:%M ", btime);
459                   //#endif
460                   sprintf(tempC, "%s\n \t%s%s", currentEvent->title,tempA,tempB);
461                   // New TVMedia stuff
462                   TVMediaInfo *info= new TVMediaInfo();
463                   info->setPosterThumb(channelNumber, currentEvent->id);
464                   currentEvent->index = sl.addOption(tempC, currentEvent->id, first, info);
465                   first = 0;
466           }
467   }
468
469   if (doIndexPop)
470   {
471     sl.hintSetCurrent(0);
472   }
473   else
474   {
475     sl.hintSetCurrent(saveIndex);
476     sl.hintSetTop(saveTop);
477   }
478   updateSelection();
479   sl.draw();
480   epg.draw();
481 }
482
483 void VEpgListAdvanced::drawDataNowNext(bool next, bool doIndexPop)
484 {
485   int saveIndex = sl.getCurrentOption();
486   int saveTop = sl.getTopOption();
487   sl.clear();
488   sl.addColumn(0);
489   sl.addColumn(42 );
490   sl.addColumn(160);
491
492   int first = 1;
493
494   char tempA[300]; // FIXME  this is guesswork!
495   char tempB[300]; // FIXME
496   char tempC[300]; // FIXME
497   struct tm* btime;
498
499
500
501   Event* currentEvent;
502   EventList::iterator j;
503   int minevents=1;
504   if (next) minevents++;
505   int setcurrenthelper =0;
506
507   unsigned int chanlistsize=chanList->size();
508   for(UINT listIndex = 0; listIndex < chanlistsize; listIndex++)
509   {
510           Channel* chan;
511           chan = (*chanList)[listIndex];
512
513           EventList* eventList = eventLista[listIndex];
514           if (eventList && eventList->size()>=minevents) {
515                   j = eventList->begin();
516
517                   currentEvent = j[minevents-1];
518                   time_t eventStartTime = (time_t)currentEvent->time;
519                   time_t eventEndTime = (time_t)(currentEvent->time + currentEvent->duration);
520
521                   btime = localtime(&eventStartTime);
522                   strftime(tempA, 299, "%H:%M ", btime);
523                   btime = localtime(&eventEndTime);
524                   strftime(tempB, 299, "- %H:%M ", btime);
525                   //#endif
526                   sprintf(tempC, "%s\n%s\t %s%s", currentEvent->title, chan->name,tempA,tempB);
527
528           } else {
529                   sprintf(tempC, "\n%s", chan->name);
530
531           }
532           TVMediaInfo *info= new TVMediaInfo();
533           if ((*chanList)[listIndex]->number == channelNumber) {
534                   first = 1;
535                   setcurrenthelper = listIndex;
536           }
537           info->setChannelLogo((*chanList)[listIndex]->number);
538           currentEvent->index = sl.addOption(tempC, listIndex, first, info);
539           first = 0;
540   }
541
542   if (doIndexPop)
543   {
544     sl.hintSetCurrent(setcurrenthelper);
545   }
546   else
547   {
548     sl.hintSetCurrent(saveIndex);
549     sl.hintSetTop(saveTop);
550   }
551   updateSelection();
552   sl.draw();
553   epg.draw();
554 }
555
556 void VEpgListAdvanced::draw(bool doIndexPop)
557 {
558
559         // Single channel mode
560         switch (mode) {
561         case OneChannel: {
562                 char tempA[300];
563                  unsigned int chanlistsize=chanList->size();
564                  Channel * chan;
565                  UINT listIndex;
566                  for(listIndex = 0; listIndex < chanlistsize; listIndex++)
567                  {
568                          chan = (*chanList)[listIndex];
569                          if (chan->number == channelNumber) break;
570                  }
571                 sprintf(tempA, tr("Schedule - %s"), (*chanList)[listIndex]->name);
572                 setTitleText(tempA);
573         } break;
574         case Now: {
575                 setTitleText(tr("Now"));
576         } break;
577         case Next: {
578                 setTitleText(tr("Next"));
579         } break;
580         };
581
582
583
584
585         TBBoxx::draw();
586
587
588         TVMediaInfo info;
589         info.setChannelLogo(channelNumber);
590
591
592
593         char freeSpace[50];
594         struct tm* btime;
595         time_t now;
596         time(&now);
597         btime = localtime(&now);
598         strftime(freeSpace, 299, "%d/%m/%y", btime);
599         if (mode == OneChannel) {
600                 drawTVMedia(info,getWidth(),0.f,0,30.f,TopRight);
601                 drawTextRJ(freeSpace, getWidth()-30, 5, DrawStyle::LIGHTTEXT);
602         } else {
603                 drawTextRJ(freeSpace, getWidth(), 5, DrawStyle::LIGHTTEXT);
604         }
605         // Symbols
606
607         WSymbol w;
608         TEMPADD(&w);
609         w.nextSymbol = WSymbol::UP;
610         w.setPosition(20, area.h-35);
611         w.draw();
612         w.nextSymbol = WSymbol::DOWN;
613         w.setPosition(50, area.h-35);
614         w.draw();
615         w.nextSymbol = WSymbol::SKIPBACK;
616         w.setPosition(85, area.h-35);
617         w.draw();
618         w.nextSymbol = WSymbol::SKIPFORWARD;
619         w.setPosition(115, area.h-35);
620         w.draw();
621
622         drawTextRJ(tr("[ok] = info"), 560+70, 385+80, DrawStyle::LIGHTTEXT);
623
624         // All static stuff done
625         drawData(doIndexPop);
626
627 }
628
629 Event* VEpgListAdvanced::getCurrentOptionEvent(int& channel)
630 {
631         // version for channel
632         Event* currentEvent = NULL;
633         EventList::iterator j;
634         EventList* eventList = NULL;
635         switch (mode)
636         {
637         case OneChannel: {
638                 eventList = eventLista[0];
639                 if (eventList) {
640                         channel = channelNumber;
641                         for (j = eventList->begin(); j != eventList->end(); j++)
642                         {
643                                 currentEvent = *j;
644                                 if (currentEvent->index == sl.getCurrentOption()) return currentEvent;
645                         }
646
647
648                 } break;
649         case Next: {
650                 eventList = eventLista[sl.getCurrentOptionData()];
651                 channel = (*chanList)[sl.getCurrentOptionData()]->number;
652
653
654                 if (eventList && eventList->size()>1) {
655                         j = eventList->begin();
656                         currentEvent = j[1];
657                 } else {
658                         currentEvent = NULL;
659                 }
660         } break;
661         case Now: {
662                 eventList = eventLista[sl.getCurrentOptionData()];
663                 channel = (*chanList)[sl.getCurrentOptionData()]->number;
664
665                 if (eventList && eventList->size()>0) {
666                         j = eventList->begin();
667                         currentEvent = j[0];
668                 } else {
669                         currentEvent = NULL;
670                 }
671         } break;
672         };
673
674
675   }
676   return currentEvent;
677 }
678
679
680
681 void VEpgListAdvanced::updateSelection()
682 {
683         updateEpgData();
684         int channel=0;
685         Event* toShow = getCurrentOptionEvent(channel);
686         if (toShow)
687         {
688                 toShow->loadinfos(channel);
689                 std::stringstream description;
690
691                 description << "\n"<< toShow->title  << "\n\n";
692                 description << toShow->subtitle <<"\n";
693                 description << toShow->description;
694
695                 TVMedia poster;
696                 poster.height=0;
697                 if (toShow->movieInfo) {
698                         poster=toShow->movieInfo->poster;
699                 }
700                 if (toShow->seriesInfo) {
701                         if (toShow->seriesInfo->seasonposter.height) {
702                                 poster=toShow->seriesInfo->seasonposter;
703                         }
704                         else if (toShow->seriesInfo->posters.size()) {
705                                 poster=toShow->seriesInfo->posters[0];
706                         }
707                 }
708                 if (poster.height) {
709                         epgTVmedia.setTVMedia(poster.info, WTVMedia::ZoomHorizontal);
710                         epgTVmedia.setVisible(true);
711                 } else {
712                         if (mode!=OneChannel) {
713                                 TVMediaInfo info;
714                                 info.setChannelLogo(channel);
715                                 epgTVmedia.setTVMedia(info, WTVMedia::ZoomHorizontal);
716                                 epgTVmedia.setVisible(true);
717                         } else {
718                                 epgTVmedia.setVisible(false);
719                         }
720                 }
721
722                 epg.setText(description.str().c_str());
723         } else {
724                 epg.setText("");
725                 if (mode!=OneChannel) {
726                         TVMediaInfo info;
727                         info.setChannelLogo(channel);
728                         epgTVmedia.setTVMedia(info, WTVMedia::ZoomHorizontal);
729                         epgTVmedia.setVisible(true);
730                 } else {
731                         epgTVmedia.setVisible(false);
732                 }
733         }
734
735 }
736
737 int VEpgListAdvanced::handleCommand(int command)
738 {
739   switch(command)
740   {
741     case Remote::DF_UP:
742     case Remote::UP:
743     {
744       sl.up();
745       quickUpdate();
746
747       boxstack->update(this);
748       return 2;
749     }
750     case Remote::DF_DOWN:
751     case Remote::DOWN:
752     {
753       sl.down();
754       quickUpdate();
755
756       boxstack->update(this);
757       return 2;
758     }
759     case Remote::SKIPBACK:
760     {
761       sl.pageUp();
762       quickUpdate();
763
764       boxstack->update(this);
765       return 2;
766     }
767     case Remote::SKIPFORWARD:
768     {
769       sl.pageDown();
770       quickUpdate();
771
772       boxstack->update(this);
773       return 2;
774     }
775     case Remote::RED:
776     {
777         doRed();
778         return 2;
779     }
780     case Remote::GREEN:
781     {
782         doGreen();
783         return 2;
784     }
785     case Remote::YELLOW:
786     {
787         doYellow();
788         return 2;
789     }
790     case Remote::BLUE:
791     {
792         doBlue();
793         return 2;
794     }
795     case Remote::OK:
796     {
797       if (sl.getNumOptions() == 0) return 2;
798
799
800       int channel;
801       Event* current = getCurrentOptionEvent(channel);
802       if (current)
803       {
804           Log::getInstance()->log("VEventListAdvanced", Log::DEBUG, "Found the option you pointed at. %s %d", current->title, current->id);
805           unsigned int chanlistsize=chanList->size();
806           Channel * chan;
807           UINT listIndex;
808           for(listIndex = 0; listIndex < chanlistsize; listIndex++)
809           {
810                   chan = (*chanList)[listIndex];
811                   if (chan->number == channel) break;
812           }
813
814           VEpgSummary* vr = new VEpgSummary(current, (*chanList)[listIndex]);
815           vr->draw();
816           boxstack->add(vr);
817           boxstack->update(vr);
818
819           return 2;
820       }
821       // should not get to here
822       return 1;
823     }
824     case Remote::BACK:
825     {
826         return 4;
827     }
828   }
829   // stop command getting to any more views
830   return 1;
831 }
832
833 void VEpgListAdvanced::processMessage(Message* m)
834 {
835   Log::getInstance()->log("VEpgListAdvanced", Log::DEBUG, "Got message value %lu", m->message);
836
837   if (m->message == Message::MOUSE_MOVE)
838   {
839     if (sl.mouseMove((m->parameter>>16)-getScreenX(),(m->parameter&0xFFFF)-getScreenY()))
840     {
841       quickUpdate();
842       boxstack->update(this);
843     }
844   }
845   else if (m->message == Message::MOUSE_LBDOWN)
846   {
847     if (sl.mouseLBDOWN((m->parameter>>16)-getScreenX(),(m->parameter&0xFFFF)-getScreenY()))
848     {
849       boxstack->handleCommand(Remote::OK); //simulate OK press
850     }
851     else
852     {
853       //check if press is outside this view! then simulate cancel
854       int x=(m->parameter>>16)-getScreenX();
855       int y=(m->parameter&0xFFFF)-getScreenY();
856       if (x<0 || y <0 || x>(int)getWidth() || y>(int)getHeight())
857       {
858         boxstack->handleCommand(Remote::BACK); //simulate cancel press
859       }
860     }
861   }
862 }
863
864
865
866 void VEpgListAdvanced::quickUpdate() { //only quick for plattform that need it!
867         updateSelection();
868 #ifdef GRADIENT_DRAWING
869       draw();
870 #else
871       sl.draw();
872       epg.draw();
873 #endif
874 }