X-Git-Url: http://code.vuplus.com/gitweb/?a=blobdiff_plain;f=lib%2Fpython%2FComponents%2FServiceList.py;h=d255b8e0b55dc05794052db501b4049eb0d72c93;hb=92456d9542585d58e011fa4f0b501de3ef9c1819;hp=e0a3153410a851f9360a161d49ba39173a12f917;hpb=2cd1d9f6f550f89747a579fe923299ac9916afe0;p=vuplus_dvbapp diff --git a/lib/python/Components/ServiceList.py b/lib/python/Components/ServiceList.py index e0a3153..d255b8e 100644 --- a/lib/python/Components/ServiceList.py +++ b/lib/python/Components/ServiceList.py @@ -3,15 +3,40 @@ from GUIComponent import * from enigma import * -class ServiceList(HTMLComponent, GUIComponent): +from string import upper + +from Tools.Directories import resolveFilename, SCOPE_SKIN, SCOPE_SKIN_IMAGE, SCOPE_FONTS +class ServiceList(HTMLComponent, GUIComponent): MODE_NORMAL = 0 MODE_FAVOURITES = 1 def __init__(self): GUIComponent.__init__(self) self.l = eListboxServiceContent() + + pic = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "folder.png")) + if pic: + self.l.setPixmap(self.l.picFolder, pic) + + pic = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "marker-fs8.png")) + if pic: + self.l.setPixmap(self.l.picMarker, pic) + + pic = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "ico_dvb_s-fs8.png")) + if pic: + self.l.setPixmap(self.l.picDVB_S, pic) + + pic = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "ico_dvb_c-fs8.png")) + if pic: + self.l.setPixmap(self.l.picDVB_C, pic) + + pic = loadPNG(resolveFilename(SCOPE_SKIN_IMAGE, "ico_dvb_t-fs8.png")) + if pic: + self.l.setPixmap(self.l.picDVB_T, pic) + self.root = None + self.mode = self.MODE_NORMAL def setCurrent(self, ref): self.l.setCurrent(ref) @@ -21,18 +46,50 @@ class ServiceList(HTMLComponent, GUIComponent): self.l.getCurrent(r) return r + def atBegin(self): + return self.instance.atBegin() + + def atEnd(self): + return self.instance.atEnd() + def moveUp(self): self.instance.moveSelection(self.instance.moveUp) def moveDown(self): self.instance.moveSelection(self.instance.moveDown) - def GUIcreate(self, parent): - self.instance = eListbox(parent) - self.instance.setContent(self.l) + def moveToChar(self, char): + # TODO fill with life + print "Next char: " + index = self.l.getNextBeginningWithChar(char) + indexup = self.l.getNextBeginningWithChar(upper(char)) + if indexup != 0: + if (index > indexup or index == 0): + index = indexup + + self.instance.moveSelectionTo(index) + print "Moving to character " + str(char) + + def moveToNextMarker(self): + idx = self.l.getNextMarkerPos() + self.instance.moveSelectionTo(idx) + + def moveToPrevMarker(self): + idx = self.l.getPrevMarkerPos() + self.instance.moveSelectionTo(idx) + + def moveToIndex(self, index): + self.instance.moveSelectionTo(index) + + def getCurrentIndex(self): + return self.instance.getCurrentIndex() + + GUI_WIDGET = eListbox - def GUIdelete(self): - self.instance = None + def postWidgetCreate(self, instance): + instance.setWrapAround(True) + instance.setContent(self.l) + self.setMode(self.mode) def getRoot(self): return self.root @@ -53,9 +110,23 @@ class ServiceList(HTMLComponent, GUIComponent): def setNumberOffset(self, offset): self.l.setNumberOffset(offset) - def setRoot(self, root): + def setPlayableIgnoreService(self, ref): + self.l.setIgnoreService(ref) + + def setRoot(self, root, justSet=False): self.root = root - self.l.setRoot(root) + self.l.setRoot(root, justSet) + if not justSet: + self.l.sort() + + def removeCurrent(self): + self.l.removeCurrent() + + def addService(self, service, beforeCurrent=False): + self.l.addService(service, beforeCurrent) + + def finishFill(self): + self.l.FillFinished() self.l.sort() # stuff for multiple marks (edit mode / later multiepg) @@ -86,15 +157,18 @@ class ServiceList(HTMLComponent, GUIComponent): self.l.setCurrentMarked(state) def setMode(self, mode): + self.mode = mode + if mode == self.MODE_NORMAL: self.instance.setItemHeight(28) self.l.setVisualMode(eListboxServiceContent.visModeSimple) - self.l.setElementFont(self.l.celServiceName, gFont("Arial", 22)) + self.l.setElementFont(self.l.celServiceName, gFont("Regular", 22)) self.l.setElementPosition(self.l.celServiceName, eRect(0, 0, self.instance.size().width(), 28)) else: self.instance.setItemHeight(28) - self.l.setElementFont(self.l.celServiceName, gFont("Arial", 22)) - self.l.setElementPosition(self.l.celServiceName, eRect(50, 0, self.instance.size().width(), 28)) - self.l.setElementFont(self.l.celServiceNumber, gFont("Arial", 20)) - self.l.setElementPosition(self.l.celServiceNumber, eRect(0, 2, 50, 28)) + self.l.setElementFont(self.l.celServiceNumber, gFont("Regular", 20)) + self.l.setElementPosition(self.l.celServiceNumber, eRect(0, 0, 40, 28)) + self.l.setElementFont(self.l.celServiceName, gFont("Regular", 22)) + self.l.setElementPosition(self.l.celServiceName, eRect(50, 0, self.instance.size().width()-50, 28)) + self.l.setElementFont(self.l.celServiceInfo, gFont("Regular", 18)) self.l.setVisualMode(eListboxServiceContent.visModeComplex)