X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/0d8132d3512dbf77d817aa8fb6684384155b642e..ff008af237bba3e58012f637cbe8996f4450f031:/mytest.py diff --git a/mytest.py b/mytest.py index aa63567a..9587273a 100644 --- a/mytest.py +++ b/mytest.py @@ -19,21 +19,27 @@ import time import ServiceReference +from Components.ParentalControl import InitParentalControl +InitParentalControl() + from Navigation import Navigation from skin import readSkin, applyAllAttributes from Tools.Directories import InitFallbackFiles, resolveFilename, SCOPE_PLUGINS, SCOPE_SKIN_IMAGE -from Components.config import configfile, configElement, configText, ConfigSubsection, config, configSequence, configsequencearg +from Components.config import config, ConfigText, configfile, ConfigSubsection, ConfigInteger InitFallbackFiles() eDVBDB.getInstance().reloadBouquets() -config.misc.radiopic = configElement("config.misc.radiopic", configText, resolveFilename(SCOPE_SKIN_IMAGE)+"radio.mvi", 0) +config.misc.radiopic = ConfigText(default = resolveFilename(SCOPE_SKIN_IMAGE)+"radio.mvi") try: import e2reactor e2reactor.install() + import twisted.python.runtime + twisted.python.runtime.platform.supportsThreads = lambda: False + from twisted.internet import reactor def runReactor(): @@ -193,6 +199,10 @@ class Session: def instantiateDialog(self, screen, *arguments, **kwargs): return self.doInstantiateDialog(screen, arguments, kwargs, self.desktop) + def deleteDialog(self, screen): + screen.hide() + screen.doClose() + def instantiateSummaryDialog(self, screen, *arguments, **kwargs): return self.doInstantiateDialog(screen, arguments, kwargs, self.summary_desktop) @@ -316,7 +326,7 @@ class VolumeControl: globalActionMap.actions["volumeMute"]=self.volMute config.audio = ConfigSubsection() - config.audio.volume = configElement("config.audio.volume", configSequence, [100], configsequencearg.get("INTEGER", (0, 100))) + config.audio.volume = ConfigInteger(default = 100, limits = (0, 100)) self.volumeDialog = session.instantiateDialog(Volume) self.muteDialog = session.instantiateDialog(Mute) @@ -324,43 +334,58 @@ class VolumeControl: self.hideVolTimer = eTimer() self.hideVolTimer.timeout.get().append(self.volHide) - vol = config.audio.volume.value[0] + vol = config.audio.volume.value self.volumeDialog.setValue(vol) - eDVBVolumecontrol.getInstance().setVolume(vol, vol) + self.volctrl = eDVBVolumecontrol.getInstance() + self.volctrl.setVolume(vol, vol) def volSave(self): - config.audio.volume.value = eDVBVolumecontrol.getInstance().getVolume() + if self.volctrl.isMuted(): + config.audio.volume.value = 0 + else: + config.audio.volume.value = self.volctrl.getVolume() config.audio.volume.save() - def volUp(self): - if (eDVBVolumecontrol.getInstance().isMuted()): - self.volMute() - eDVBVolumecontrol.getInstance().volumeUp() - self.volumeDialog.show() - self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume()) - self.volSave() - self.hideVolTimer.start(3000, True) + def volUp(self): + self.setVolume(+1) + + def volDown(self): + self.setVolume(-1) - def volDown(self): - if (eDVBVolumecontrol.getInstance().isMuted()): - self.volMute() - eDVBVolumecontrol.getInstance().volumeDown() + def setVolume(self, direction): + oldvol = self.volctrl.getVolume() + if direction > 0: + self.volctrl.volumeUp() + else: + self.volctrl.volumeDown() + is_muted = self.volctrl.isMuted() + vol = self.volctrl.getVolume() self.volumeDialog.show() - self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume()) + if is_muted: + self.volMute() # unmute + elif not vol: + self.volMute(False, True) # mute but dont show mute symbol + if self.volctrl.isMuted(): + self.volumeDialog.setValue(0) + else: + self.volumeDialog.setValue(self.volctrl.getVolume()) self.volSave() self.hideVolTimer.start(3000, True) def volHide(self): self.volumeDialog.hide() - def volMute(self): - eDVBVolumecontrol.getInstance().volumeToggleMute() - self.volumeDialog.setValue(eDVBVolumecontrol.getInstance().getVolume()) - - if (eDVBVolumecontrol.getInstance().isMuted()): - self.muteDialog.show() - else: - self.muteDialog.hide() + def volMute(self, showMuteSymbol=True, force=False): + vol = self.volctrl.getVolume() + if vol or force: + self.volctrl.volumeToggleMute() + if self.volctrl.isMuted(): + if showMuteSymbol: + self.muteDialog.show() + self.volumeDialog.setValue(0) + else: + self.muteDialog.hide() + self.volumeDialog.setValue(vol) from Screens.Standby import Standby @@ -397,12 +422,38 @@ class PowerKey: self.standby() def standby(self): - self.session.open(Standby, self) + if self.session.current_dialog and self.session.current_dialog.ALLOW_SUSPEND: + self.session.open(Standby, self) def quit(self): # halt quitMainloop(1) +from Screens.Scart import Scart + +class AutoScartControl: + def __init__(self, session): + self.force = False + self.current_vcr_sb = eAVSwitch.getInstance().getVCRSlowBlanking() + if self.current_vcr_sb and config.av.vcrswitch.value: + self.scartDialog = session.instantiateDialog(Scart, True) + else: + self.scartDialog = session.instantiateDialog(Scart, False) + config.av.vcrswitch.addNotifier(self.recheckVCRSb) + eAVSwitch.getInstance().vcr_sb_notifier.get().append(self.VCRSbChanged) + + def recheckVCRSb(self, configElement): + self.VCRSbChanged(self.current_vcr_sb) + + def VCRSbChanged(self, value): + #print "vcr sb changed to", value + self.current_vcr_sb = value + if config.av.vcrswitch.value or value > 2: + if value: + self.scartDialog.showMessageBox() + else: + self.scartDialog.switchToTV() + def runScreenTest(): plugins.readPluginList(resolveFilename(SCOPE_PLUGINS)) @@ -435,6 +486,9 @@ def runScreenTest(): vol = VolumeControl(session) power = PowerKey(session) + + # we need session.scart to access it from within menu.xml + session.scart = AutoScartControl(session) runReactor() @@ -449,6 +503,7 @@ def runScreenTest(): else: setFPWakeuptime(nextRecordingTime - (300)) + session.nav.stopService() session.nav.shutdown() return 0 @@ -492,6 +547,9 @@ try: runScreenTest() plugins.shutdown() + + from Components.ParentalControl import parentalControl + parentalControl.save() except: print 'EXCEPTION IN PYTHON STARTUP CODE:' print '-'*60