aboutsummaryrefslogtreecommitdiff
path: root/lib/python/Components
diff options
context:
space:
mode:
Diffstat (limited to 'lib/python/Components')
-rw-r--r--lib/python/Components/NimManager.py3
-rw-r--r--lib/python/Components/TunerInfo.py56
2 files changed, 45 insertions, 14 deletions
diff --git a/lib/python/Components/NimManager.py b/lib/python/Components/NimManager.py
index 6b6a9ceb..950f48fd 100644
--- a/lib/python/Components/NimManager.py
+++ b/lib/python/Components/NimManager.py
@@ -571,6 +571,9 @@ class NimManager:
def getNimConfigMode(self, slotid):
return currentConfigSelectionElement(config.Nims[slotid].configMode)
+
+ def getSatList(self):
+ return self.satList
def getSatListForNim(self, slotid):
list = []
diff --git a/lib/python/Components/TunerInfo.py b/lib/python/Components/TunerInfo.py
index f39babf2..f841832c 100644
--- a/lib/python/Components/TunerInfo.py
+++ b/lib/python/Components/TunerInfo.py
@@ -5,6 +5,11 @@ from enigma import eLabel, eSlider, iFrontendStatusInformation
from math import log
class TunerInfo(GUIComponent):
+ SNR = 0
+ AGC = 1
+ BER = 2
+ LOCK = 3
+
SNR_PERCENTAGE = 0
AGC_PERCENTAGE = 1
BER_VALUE = 2
@@ -13,13 +18,14 @@ class TunerInfo(GUIComponent):
BER_BAR = 5
LOCK_STATE = 6
SYNC_STATE = 7
- def __init__(self, type, servicefkt):
+ def __init__(self, type, servicefkt = None, frontendfkt = None):
GUIComponent.__init__(self)
self.instance = None
self.message = None
self.value = None
self.servicefkt = servicefkt
+ self.frontendfkt = frontendfkt
self.type = type
self.update()
@@ -41,19 +47,14 @@ class TunerInfo(GUIComponent):
return val*100/65535
def update(self):
- service = self.servicefkt()
- value = 0
- if service is not None:
- feinfo = service.frontendStatusInfo()
- if feinfo is not None:
- if self.type == self.SNR_PERCENTAGE or self.type == self.SNR_BAR:
- value = feinfo.getFrontendInfo(iFrontendStatusInformation.signalPower) * 100 / 65536
- elif self.type == self.AGC_PERCENTAGE or self.type == self.AGC_BAR:
- value = feinfo.getFrontendInfo(iFrontendStatusInformation.signalQuality) * 100 / 65536
- elif self.type == self.BER_VALUE or self.type == self.BER_BAR:
- value = feinfo.getFrontendInfo(iFrontendStatusInformation.bitErrorRate)
- elif self.type == self.LOCK_STATE:
- value = feinfo.getFrontendInfo(iFrontendStatusInformation.LockState)
+ if self.type == self.SNR_PERCENTAGE or self.type == self.SNR_BAR:
+ value = self.getValue(self.SNR) * 100 / 65536
+ elif self.type == self.AGC_PERCENTAGE or self.type == self.AGC_BAR:
+ value = self.getValue(self.AGC) * 100 / 65536
+ elif self.type == self.BER_VALUE or self.type == self.BER_BAR:
+ value = self.getValue(self.BER)
+ elif self.type == self.LOCK_STATE:
+ value = self.getValue(self.LOCK)
if self.type == self.SNR_PERCENTAGE or self.type == self.AGC_PERCENTAGE:
self.setText("%d%%" % (value))
@@ -69,6 +70,33 @@ class TunerInfo(GUIComponent):
else:
self.setText(_("not locked"))
+ def getValue(self, what):
+ if self.servicefkt is not None:
+ service = self.servicefkt()
+ if service is not None:
+ feinfo = service.frontendStatusInfo()
+ if feinfo is not None:
+ if what == self.SNR:
+ return feinfo.getFrontendInfo(iFrontendStatusInformation.signalPower)
+ elif what == self.AGC:
+ return feinfo.getFrontendInfo(iFrontendStatusInformation.signalQuality)
+ elif what == self.BER:
+ return feinfo.getFrontendInfo(iFrontendStatusInformation.bitErrorRate)
+ elif what == self.LOCK:
+ return feinfo.getFrontendInfo(iFrontendStatusInformation.LockState)
+ elif self.frontendfkt is not None:
+ frontend = self.frontendfkt()
+ if what == self.SNR:
+ return frontend.readFrontendData(iFrontendStatusInformation.signalPower)
+ elif what == self.AGC:
+ return frontend.readFrontendData(iFrontendStatusInformation.signalQuality)
+ elif what == self.BER:
+ return frontend.readFrontendData(iFrontendStatusInformation.bitErrorRate)
+ elif what == self.LOCK:
+ return frontend.readFrontendData(iFrontendStatusInformation.LockState)
+
+ return 0
+
def createWidget(self, parent):
if self.SNR_PERCENTAGE <= self.type <= self.BER_VALUE or self.type == self.LOCK_STATE:
return eLabel(parent)