X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/fe813cde98c0c550137b47dd7a75ec2d4d9e6f34..b2cb2cf5a88d2df60af474ced13e3c90891cf841:/lib/python/Components/MovieList.py diff --git a/lib/python/Components/MovieList.py b/lib/python/Components/MovieList.py index 003302b3..bc659114 100644 --- a/lib/python/Components/MovieList.py +++ b/lib/python/Components/MovieList.py @@ -1,49 +1,49 @@ from HTMLComponent import * from GUIComponent import * +from Tools.FuzzyDate import FuzzyTime +from ServiceReference import ServiceReference +from Components.MultiContent import MultiContentEntryText, RT_HALIGN_LEFT, RT_HALIGN_RIGHT -from enigma import eListboxPythonMultiContent, eListbox, gFont +from enigma import eListboxPythonMultiContent, eListbox, gFont, iServiceInformation from enigma import eServiceReference, eServiceCenter, \ eServiceCenterPtr, iListableServicePtr, \ iStaticServiceInformationPtr - - -RT_HALIGN_LEFT = 0 -RT_HALIGN_RIGHT = 1 -RT_HALIGN_CENTER = 2 -RT_HALIGN_BLOCK = 4 - -RT_VALIGN_TOP = 0 -RT_VALIGN_CENTER = 8 -RT_VALIGN_BOTTOM = 16 - -RT_WRAP = 32 - - # # | name of movie | # def MovieListEntry(serviceref, serviceHandler): - res = [ serviceref ] + if serviceref.flags & eServiceReference.mustDescent: + return None - info = iStaticServiceInformationPtr() - - if serviceHandler.info(serviceref, info): + info = serviceHandler.info(serviceref) + + if info is None: # ignore service which refuse to info - del info - return + return None len = info.getLength(serviceref) - if len: + if len > 0: len = "%d:%02d" % (len / 60, len % 60) else: len = "?:??" - res.append((0, 0, 400, 30, 0, RT_HALIGN_LEFT, info.getName(serviceref))) - res.append((0, 30, 200, 20, 1, RT_HALIGN_LEFT, "Toller Film")) - res.append((0, 50, 200, 20, 1, RT_HALIGN_LEFT, "Aufgenommen: irgendwann")) - res.append((200, 50, 200, 20, 1, RT_HALIGN_RIGHT, len)) + begin = info.getInfo(serviceref, iServiceInformation.sTimeCreate) + res = [ (serviceref, begin) ] + + res.append(MultiContentEntryText(pos=(0, 0), size=(560, 30), font = 0, flags = RT_HALIGN_LEFT, text = info.getName(serviceref))) + + description = info.getInfoString(serviceref, iServiceInformation.sDescription) + + begin_string = "" + if begin > 0: + t = FuzzyTime(begin) + begin_string = t[0] + ", " + t[1] + + res.append(MultiContentEntryText(pos=(0, 30), size=(560, 20), font=1, flags=RT_HALIGN_LEFT, text=description)) + res.append(MultiContentEntryText(pos=(0, 50), size=(270, 20), font=1, flags=RT_HALIGN_LEFT, text=begin_string)) + res.append(MultiContentEntryText(pos=(290, 50), size=(270, 20), font=1, flags=RT_HALIGN_RIGHT, text=len)) return res @@ -51,13 +51,20 @@ class MovieList(HTMLComponent, GUIComponent): def __init__(self, root): GUIComponent.__init__(self) self.l = eListboxPythonMultiContent() - self.load(root) - self.l.setList(self.list) - self.l.setFont(0, gFont("Arial", 30)) - self.l.setFont(1, gFont("Arial", 18)) - + if root is not None: + self.reload(root) + self.l.setFont(0, gFont("Regular", 30)) + self.l.setFont(1, gFont("Regular", 18)) + + def moveToIndex(self, index): + self.instance.moveSelectionTo(index) + + def getCurrentIndex(self): + return self.instance.getCurrentIndex() + def getCurrent(self): - return self.l.getCurrentSelection() + l = self.l.getCurrentSelection() + return l and l[0] def GUIcreate(self, parent): self.instance = eListbox(parent) @@ -68,28 +75,56 @@ class MovieList(HTMLComponent, GUIComponent): self.instance.setContent(None) self.instance = None + def reload(self, root = None): + if root is not None: + self.load(root) + else: + self.load(self.root) + self.l.setList(self.list) + + def removeService(self, service): + for l in self.list[:]: + if l[0][0] == service: + self.list.remove(l) + self.l.setList(self.list) + def load(self, root): # this lists our root service, then building a # nice list self.list = [ ] + self.root = root - serviceHandler = eServiceCenterPtr() - eServiceCenter.getInstance(serviceHandler) - list = iListableServicePtr() + serviceHandler = eServiceCenter.getInstance() + list = serviceHandler.list(root) - if serviceHandler.list(root, list): + if list is None: raise "listing of movies failed" movieList = [ ] while 1: - s = eServiceReference() - if list.getNext(s): - del s + s = list.getNext() + if not s.valid(): del list break movieList.append(s) # now process them... for ref in movieList: - self.list.append(MovieListEntry(ref, serviceHandler)) + a = MovieListEntry(ref, serviceHandler) + if a is not None: + self.list.append(a) + + self.list.sort(key=lambda x: -x[0][1]) + + def moveTo(self, serviceref): + found = 0 + count = 0 + for x in self.list: + if str(ServiceReference(x[0][0])) == str(ServiceReference(serviceref)): + found = count + count += 1 + self.instance.moveSelectionTo(found) + + def moveDown(self): + self.instance.moveSelection(self.instance.moveDown)