aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-12-22 15:50:51 +0000
committerAndreas Monzner <andreas.monzner@multimedia-labs.de>2006-12-22 15:50:51 +0000
commitd4ac90a0740a22c86e8f18a49a594e9a8f3746df (patch)
treefbf3e60ffb40575bde8961ab202f9c3a3ddc555c
parent3b42e4b203eb2295992e75553cb9f5bc5ac0c485 (diff)
downloadenigma2-d4ac90a0740a22c86e8f18a49a594e9a8f3746df.tar.gz
enigma2-d4ac90a0740a22c86e8f18a49a594e9a8f3746df.zip
add "show transponder" info to service context menu in channellist
-rw-r--r--Navigation.py2
-rw-r--r--lib/python/Screens/ChannelSelection.py8
-rw-r--r--lib/python/Screens/ScanSetup.py6
-rw-r--r--lib/python/Screens/ServiceInfo.py119
-rw-r--r--lib/service/servicedvb.cpp6
5 files changed, 93 insertions, 48 deletions
diff --git a/Navigation.py b/Navigation.py
index c2d2752a..ece89227 100644
--- a/Navigation.py
+++ b/Navigation.py
@@ -1,4 +1,4 @@
-from enigma import eServiceCenter, eServiceReference, pNavigation
+from enigma import eServiceCenter, eServiceReference, pNavigation, getBestPlayableServiceReference
from Components.ParentalControl import parentalControl
from Tools.BoundFunction import boundFunction
import RecordTimer
diff --git a/lib/python/Screens/ChannelSelection.py b/lib/python/Screens/ChannelSelection.py
index 9cbb4221..db2789d0 100644
--- a/lib/python/Screens/ChannelSelection.py
+++ b/lib/python/Screens/ChannelSelection.py
@@ -15,6 +15,7 @@ from Components.Input import Input
from Components.ParentalControl import parentalControl
from Screens.InputBox import InputBox, PinInput
from Screens.MessageBox import MessageBox
+from Screens.ServiceInfo import ServiceInfo
from ServiceReference import ServiceReference
from Tools.BoundFunction import boundFunction
from re import *
@@ -81,6 +82,8 @@ class ChannelContextMenu(Screen):
inBouquet = csel.getMutableList() is not None
haveBouquets = config.usage.multibouquet.value
+ if not (len(current_sel_path) or current_sel_flags & eServiceReference.isDirectory):
+ menu.append((_("show transponder info"), self.showServiceInformations))
if csel.bouquet_mark_edit == OFF and not csel.movemode:
if not inBouquetRootList:
isPlayable = not (current_sel_flags & (eServiceReference.isMarker|eServiceReference.isDirectory))
@@ -146,7 +149,10 @@ class ChannelContextMenu(Screen):
def cancelClick(self):
self.close(False)
-
+
+ def showServiceInformations(self):
+ self.session.open( ServiceInfo, self.csel.getCurrentSelection() )
+
def showBouquetInputBox(self):
self.session.openWithCallback(self.bouquetInputCallback, InputBox, title=_("Please enter a name for the new bouquet"), text="bouquetname", maxSize=False, type=Input.TEXT)
diff --git a/lib/python/Screens/ScanSetup.py b/lib/python/Screens/ScanSetup.py
index 81985a83..f9c25c70 100644
--- a/lib/python/Screens/ScanSetup.py
+++ b/lib/python/Screens/ScanSetup.py
@@ -188,10 +188,10 @@ class ScanSetup(ConfigListScreen, Screen):
self.list.append(self.typeOfScanEntry)
if nimmanager.getNimType(self.scan_nims.index) == nimmanager.nimType["DVB-S"]:
-
if self.scan_type.value == "single_transponder":
-# self.systemEntry = getConfigListEntry(_('Transpondertype'), self.scan_sat.system)
-# self.list.append(self.systemEntry)
+ if nimmanager.getNimName(self.scan_nims.index).find("DVB-S2") != -1:
+ self.systemEntry = getConfigListEntry(_('Transpondertype'), self.scan_sat.system)
+ self.list.append(self.systemEntry)
self.list.append(getConfigListEntry(_('Satellite'), self.scan_satselection[self.scan_nims.index]))
self.list.append(getConfigListEntry(_('Frequency'), self.scan_sat.frequency))
self.list.append(getConfigListEntry(_('Inversion'), self.scan_sat.inversion))
diff --git a/lib/python/Screens/ServiceInfo.py b/lib/python/Screens/ServiceInfo.py
index 639b970a..3899968a 100644
--- a/lib/python/Screens/ServiceInfo.py
+++ b/lib/python/Screens/ServiceInfo.py
@@ -5,7 +5,7 @@ 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, iServiceInformation
+from enigma import eListboxPythonMultiContent, eListbox, gFont, iServiceInformation, eServiceCenter
RT_HALIGN_LEFT = 0
@@ -51,8 +51,11 @@ class ServiceInfoList(HTMLComponent, GUIComponent):
self.instance.setContent(self.l)
self.instance.setItemHeight(25)
+TYPE_SERVICE_INFO = 1
+TYPE_TRANSPONDER_INFO = 2
+
class ServiceInfo(Screen):
- def __init__(self, session):
+ def __init__(self, session, serviceref=None):
Screen.__init__(self, session)
self["actions"] = ActionMap(["OkCancelActions", "ColorActions"],
@@ -64,60 +67,96 @@ class ServiceInfo(Screen):
"yellow": self.transponder,
"blue": self.tuner
}, -1)
-
- service = session.nav.getCurrentService()
- if service is not None:
- self.info = service.info()
- self.feinfo = service.frontendInfo()
- print self.info.getInfoObject(iServiceInformation.sCAIDs);
- else:
- self.info = None
- self.feinfo = None
+ if serviceref:
+ self.type = TYPE_TRANSPONDER_INFO
+ self["red"] = Label()
+ self["green"] = Label()
+ self["yellow"] = Label()
+ self["blue"] = Label()
+ info = eServiceCenter.getInstance().info(serviceref)
+ self.transponder_info = info.getInfoObject(serviceref, iServiceInformation.sTransponderData)
+ else:
+ self.type = TYPE_SERVICE_INFO
+ self["red"] = Label(_("Serviceinfo"))
+ self["green"] = Label(_("PIDs"))
+ self["yellow"] = Label(_("Transponder"))
+ self["blue"] = Label(_("Tuner status"))
+ service = session.nav.getCurrentService()
+ if service is not None:
+ self.info = service.info()
+ self.feinfo = service.frontendInfo()
+ print self.info.getInfoObject(iServiceInformation.sCAIDs);
+ else:
+ self.info = None
+ self.feinfo = 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()
+ if self.type == TYPE_SERVICE_INFO:
+ 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)
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)
-
+ if self.transponder_info:
+ conv = { "type" : _("Transponder Type:"),
+ "frequency" : _("Frequency:"),
+ "symbolrate" : _("Symbolrate:"),
+ "orbital position" : _("Orbital Position:"),
+ "inversion" : _("Inversion:"),
+ "fec inner" : _("FEC:"),
+ "modulation" : _("Modulation:"),
+ "polarization" : _("Polarization:"),
+ "roll off" : _("Rolloff:"),
+ "system" : _("System:"),
+ "bandwidth" : _("Bandwidth:"),
+ "code rate lp" : _("Coderate LP:"),
+ "code rate hp" : _("Coderate HP:"),
+ "constellation" : _("Constellation:"),
+ "transmission mode": _("Transmission Mode:"),
+ "guard interval" : _("Guard Interval:"),
+ "hierarchy" : _("Hierarchy Information:") }
+ Labels = [ ]
+ for i in self.transponder_info.keys():
+ Labels.append( (conv[i], self.transponder_info[i], TYPE_TEXT) )
+ self.fillList(Labels)
+
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)
+ if self.type == TYPE_SERVICE_INFO:
+ 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 showFrontendData(self, real):
- frontendData = self.feinfo and self.feinfo.getFrontendData(real)
- Labels = self.getFEData(frontendData)
- self.fillList(Labels)
+ if self.type == TYPE_SERVICE_INFO:
+ frontendData = self.feinfo and self.feinfo.getFrontendData(real)
+ Labels = self.getFEData(frontendData)
+ self.fillList(Labels)
def transponder(self):
- self.showFrontendData(True)
+ if self.type == TYPE_SERVICE_INFO:
+ self.showFrontendData(True)
def tuner(self):
- self.showFrontendData(False)
-
+ if self.type == TYPE_SERVICE_INFO:
+ self.showFrontendData(False)
+
def getFEData(self, frontendData):
if frontendData is None:
return []
diff --git a/lib/service/servicedvb.cpp b/lib/service/servicedvb.cpp
index 774e3f6b..ea014a19 100644
--- a/lib/service/servicedvb.cpp
+++ b/lib/service/servicedvb.cpp
@@ -125,7 +125,7 @@ extern void PutToDict(ePyObject &dict, const char*key, const char *value);
void PutSatelliteDataToDict(ePyObject &dict, eDVBFrontendParametersSatellite &feparm)
{
const char *tmp=0;
- PutToDict(dict, "type", "satellite");
+ PutToDict(dict, "type", "Satellite");
PutToDict(dict, "frequency", feparm.frequency);
PutToDict(dict, "symbolrate", feparm.symbol_rate);
PutToDict(dict, "orbital position", feparm.orbital_position);
@@ -192,7 +192,7 @@ void PutSatelliteDataToDict(ePyObject &dict, eDVBFrontendParametersSatellite &fe
void PutTerrestrialDataToDict(ePyObject &dict, eDVBFrontendParametersTerrestrial &feparm)
{
- PutToDict(dict, "type", "terrestrial");
+ PutToDict(dict, "type", "Terrestrial");
PutToDict(dict, "frequency", feparm.frequency);
const char *tmp=0;
switch (feparm.bandwidth)
@@ -276,7 +276,7 @@ void PutTerrestrialDataToDict(ePyObject &dict, eDVBFrontendParametersTerrestrial
void PutCableDataToDict(ePyObject &dict, eDVBFrontendParametersCable &feparm)
{
const char *tmp=0;
- PutToDict(dict, "type", "cable");
+ PutToDict(dict, "type", "Cable");
PutToDict(dict, "frequency", feparm.frequency);
PutToDict(dict, "symbolrate", feparm.symbol_rate);
switch (feparm.modulation)