X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/8ef98e5273d9778bd7c53b5ea30de3e1c5d0165e..5763b994b39952bc06a75e634b4418f13b0aeaf2:/lib/python/Screens/ServiceInfo.py diff --git a/lib/python/Screens/ServiceInfo.py b/lib/python/Screens/ServiceInfo.py index 10f7b28c..faa006bd 100644 --- a/lib/python/Screens/ServiceInfo.py +++ b/lib/python/Screens/ServiceInfo.py @@ -5,17 +5,35 @@ from Components.ActionMap import ActionMap from Components.Label import Label from Components.MenuList import MenuList from ServiceReference import ServiceReference -from enigma import eListboxPythonMultiContent, eListbox, gFont +from enigma import eListboxPythonMultiContent, eListbox, gFont, iServiceInformation RT_HALIGN_LEFT = 0 -def ServiceInfoListEntry(a, b): +TYPE_TEXT = 0 +TYPE_VALUE_HEX = 1 +TYPE_VALUE_DEC = 2 +TYPE_VALUE_HEX_DEC = 3 +TYPE_SLIDER = 4 + +def ServiceInfoListEntry(a, b, valueType=TYPE_TEXT, param=4): res = [ ] - #PyObject *px, *py, *pwidth, *pheight, *pfnt, *pstring, *pflags; - res.append((0, 0, 200, 30, 0, RT_HALIGN_LEFT, "")) - res.append((0, 0, 150, 25, 0, RT_HALIGN_LEFT, a)) - res.append((170, 0, 150, 25, 0, RT_HALIGN_LEFT, b)) + #PyObject *type, *px, *py, *pwidth, *pheight, *pfnt, *pstring, *pflags; + res.append((eListboxPythonMultiContent.TYPE_TEXT, 0, 0, 200, 30, 0, RT_HALIGN_LEFT, "")) + res.append((eListboxPythonMultiContent.TYPE_TEXT, 0, 0, 200, 25, 0, RT_HALIGN_LEFT, a)) + print "b:", b + if type(b) is not str: + if valueType == TYPE_VALUE_HEX: + b = ("0x%0" + str(param) + "x") % b + elif valueType == TYPE_VALUE_DEC: + b = str(b) + elif valueType == TYPE_VALUE_HEX_DEC: + b = ("0x%0" + str(param) + "x (%dd)") % (b, b) + else: + b = str(b) + + + res.append((eListboxPythonMultiContent.TYPE_TEXT, 220, 0, 350, 25, 0, RT_HALIGN_LEFT, b)) return res @@ -25,7 +43,7 @@ class ServiceInfoList(HTMLComponent, GUIComponent): self.l = eListboxPythonMultiContent() self.list = source self.l.setList(self.list) - self.l.setFont(0, gFont("Arial", 23)) + self.l.setFont(0, gFont("Regular", 23)) def GUIcreate(self, parent): self.instance = eListbox(parent) @@ -39,33 +57,113 @@ class ServiceInfoList(HTMLComponent, GUIComponent): class ServiceInfo(Screen): def __init__(self, session): Screen.__init__(self, session) - - self["actions"] = ActionMap(["OkCancelActions"], + + self["actions"] = ActionMap(["OkCancelActions", "ColorActions"], { "ok": self.close, - "cancel": self.close + "cancel": self.close, + "red": self.information, + "green": self.pids, + "yellow": self.transponder, + "blue": self.tuner }, -1) + + service = session.nav.getCurrentService() + if service is not None: + self.info = service.info() + self.feinfo = service.frontendStatusInfo() + else: + self.info = None + + + self["red"] = Label("Serviceinfo") + self["green"] = Label("PIDs") + self["yellow"] = Label("Transponder") + self["blue"] = Label("Tuner status") + + tlist = [ ] + + self["infolist"] = ServiceInfoList(tlist) + self.onShown.append(self.information) + + def information(self): + if self.session.nav.getCurrentlyPlayingServiceReference() is not None: + name = ServiceReference(self.session.nav.getCurrentlyPlayingServiceReference()).getServiceName() + else: + name = "N/A" + Labels = ( ("Name", name, TYPE_TEXT), + ("Provider", self.getServiceInfoValue(iServiceInformation.sProvider), TYPE_TEXT), + ("Videoformat", self.getServiceInfoValue(iServiceInformation.sAspect), TYPE_TEXT), + ("Namespace", self.getServiceInfoValue(iServiceInformation.sNamespace), TYPE_VALUE_HEX, 8)) + self.fillList(Labels) - Labels = ( ("Name", "ServiceReference(self.session.nav.getCurrentlyPlayingServiceReference()).getServiceName()"), - ("Provider", ), - ("VideoPID",""), - ("AudioPID",""), - ("PCRPID",""), - ("PMTPID",""), - ("TXTPID",""), - ("Videoformat",""), - ("TSID",""), - ("ONID",""), - ("SID",""), - ("Namespace","")) + def pids(self): + Labels = ( ("VideoPID", self.getServiceInfoValue(iServiceInformation.sVideoPID), TYPE_VALUE_HEX_DEC, 4), + ("AudioPID", self.getServiceInfoValue(iServiceInformation.sAudioPID), TYPE_VALUE_HEX_DEC, 4), + ("PCRPID", self.getServiceInfoValue(iServiceInformation.sPCRPID), TYPE_VALUE_HEX_DEC, 4), + ("PMTPID", self.getServiceInfoValue(iServiceInformation.sPMTPID), TYPE_VALUE_HEX_DEC, 4), + ("TXTPID", self.getServiceInfoValue(iServiceInformation.sTXTPID), TYPE_VALUE_HEX_DEC, 4), + ("TSID", self.getServiceInfoValue(iServiceInformation.sTSID), TYPE_VALUE_HEX_DEC, 4), + ("ONID", self.getServiceInfoValue(iServiceInformation.sONID), TYPE_VALUE_HEX_DEC, 4), + ("SID", self.getServiceInfoValue(iServiceInformation.sSID), TYPE_VALUE_HEX_DEC, 4)) + self.fillList(Labels) + def transponder(self): + frontendData = self.feinfo.getFrontendData(True) + Labels = self.getFEData(frontendData) + self.fillList(Labels) + + def tuner(self): + frontendData = self.feinfo.getFrontendData(False) + Labels = self.getFEData(frontendData) + self.fillList(Labels) + + def getFEData(self, frontendData): + if frontendData is None: + return [] + if frontendData["tuner_type"] == "DVB-S": + return ( ("NIM", ['A', 'B', 'C', 'D'][frontendData["tuner_number"]], TYPE_TEXT), + ("Type", frontendData["tuner_type"], TYPE_TEXT), + ("Orbital position", frontendData["orbital_position"], TYPE_VALUE_DEC), + ("Frequency", frontendData["frequency"], TYPE_VALUE_DEC), + ("Symbolrate", frontendData["symbol_rate"], TYPE_VALUE_DEC), + ("Polarization", frontendData["polarization"], TYPE_TEXT), + ("Inversion", frontendData["inversion"], TYPE_TEXT), + ("FEC inner", frontendData["fec_inner"], TYPE_TEXT), + ) + elif frontendData["tuner_type"] == "DVB-C": + return ( ("NIM", ['A', 'B', 'C', 'D'][frontendData["tuner_number"]], TYPE_TEXT), + ("Type", frontendData["tuner_type"], TYPE_TEXT), + ("Frequency", frontendData["frequency"], TYPE_VALUE_DEC), + ("Symbolrate", frontendData["symbol_rate"], TYPE_VALUE_DEC), + ("Modulation", frontendData["modulation"], TYPE_TEXT), + ("Inversion", frontendData["inversion"], TYPE_TEXT), + ("FEC inner", frontendData["fec_inner"], TYPE_TEXT), + ) + elif frontendData["tuner_type"] == "DVB-T": + return [] + + def fillList(self, Labels): tlist = [ ] for item in Labels: - try: - value = str(eval(item[1])) - except: - value = "N/A" - tlist.append(ServiceInfoListEntry(item[0]+":", value)) + print item + value = item[1] + if len(item) < 4: + tlist.append(ServiceInfoListEntry(item[0]+":", value, item[2])) + else: + tlist.append(ServiceInfoListEntry(item[0]+":", value, item[2], item[3])) - self["infolist"] = ServiceInfoList(tlist) + self["infolist"].l.setList(tlist) + + def getServiceInfoValue(self, what): + if self.info is None: + return "" + + v = self.info.getInfo(what) + if v == -2: + v = self.info.getInfoString(what) + elif v == -1: + v = "N/A" + + return v