X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/2dc9b0cb83069aaed4dbb3f45b3d15835568d0d9..01f6932815a6a21ab46bb420be093685378b43dd:/lib/python/Components/EventInfo.py diff --git a/lib/python/Components/EventInfo.py b/lib/python/Components/EventInfo.py index c8e5a13f..36a5aa4d 100644 --- a/lib/python/Components/EventInfo.py +++ b/lib/python/Components/EventInfo.py @@ -1,4 +1,6 @@ from PerServiceDisplay import * +from time import strftime +from time import localtime, time from enigma import iServiceInformationPtr, eServiceEventPtr @@ -7,6 +9,8 @@ class EventInfo(PerServiceDisplay): Next = 1 Now_Duration = 2 Next_Duration = 3 + Now_StartTime = 4 + Next_StartTime = 5 def __init__(self, navcore, now_or_next): # listen to evUpdatedEventInfo and evStopService @@ -27,12 +31,37 @@ class EventInfo(PerServiceDisplay): if info is not None: ev = info.getEvent(self.now_or_next & 1) if ev is not None: - if self.now_or_next & 2: - self.setText("%d min" % (ev.m_duration / 60)) - else: - self.setText(ev.m_event_name) + self.update(ev) + + + def update(self, ev): + if (self.Now_Duration <= self.now_or_next <= self.Next_Duration): + self.setText("%d min" % (ev.getDuration() / 60)) + if (self.Now_StartTime <= self.now_or_next <= self.Next_StartTime): + self.setText(strftime("%H:%M", localtime(ev.getBeginTime()))) + if (self.Now <= self.now_or_next <= self.Next): + self.setText(ev.getEventName()) def stopEvent(self): self.setText( - ("waiting for event data...", "", "--:--", "--:--")[self.now_or_next]); + #(_("waiting for event data..."), "", "--:--", "--:--", "--:--", "--:--")[self.now_or_next]); + ("", "", "--:--", "--:--", "--:--", "--:--")[self.now_or_next]); + +class EventInfoProgress(PerServiceDisplayProgress, EventInfo): + def __init__(self, navcore, now_or_next): + self.now_or_next = now_or_next + PerServiceDisplayProgress.__init__(self, navcore, + { + pNavigation.evUpdatedEventInfo: self.ourEvent, + pNavigation.evStopService: self.stopEvent + }) + + def update(self, ev): + self.g.setRange(0, ev.getDuration()) + progress = int(time() - ev.getBeginTime()) + + self.setValue(progress) + + def stopEvent(self): + self.setValue(0)