X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/f50ea7e42b05996b75eba9ed4376c539c5fc00ae..9f6a10b46af262567a5add9312927887c86531b8:/lib/python/Components/AVSwitch.py diff --git a/lib/python/Components/AVSwitch.py b/lib/python/Components/AVSwitch.py index b4090c19..b391dab6 100644 --- a/lib/python/Components/AVSwitch.py +++ b/lib/python/Components/AVSwitch.py @@ -9,8 +9,8 @@ class AVSwitch: eAVSwitch.getInstance().setInput(self.INPUT[input][0]) if self.INPUT[input][1] == 4: aspect = self.getAspectRatioSetting() - self.setWSS(aspect) - self.setSlowBlank(aspect) + self.setAspectWSS(aspect) + self.setAspectSlowBlank(aspect) else: eAVSwitch.getInstance().setSlowblank(self.INPUT[input][1]) # FIXME why do we have to reset the colorformat? bug in avs-driver? @@ -21,8 +21,8 @@ class AVSwitch: def setAspectRatio(self, value): eAVSwitch.getInstance().setAspectRatio(value) - self.setWSS(value) - self.setSlowBlank(value) + self.setAspectWSS(value) + self.setAspectSlowBlank(value) def setSystem(self, value): eAVSwitch.getInstance().setVideomode(value) @@ -39,7 +39,7 @@ class AVSwitch: val = 3 return val - def setWSS(self, aspect=None): + def setAspectWSS(self, aspect=None): if aspect is None: aspect = self.getAspectRatioSetting() if aspect == 0 or aspect == 1: # letterbox or panscan @@ -53,7 +53,7 @@ class AVSwitch: value = 4 # 16:9_full_format eAVSwitch.getInstance().setWSS(value) - def setSlowBlank(self, aspect=None): + def setAspectSlowBlank(self, aspect=None): if aspect is None: aspect = self.getAspectRatioSetting() if aspect == 0 or aspect == 1: # letterbox or panscan @@ -66,7 +66,14 @@ class AVSwitch: def InitAVSwitch(): config.av = ConfigSubsection(); - config.av.colorformat = configElement("config.av.colorformat", configSelection, 1, (("cvbs", _("CVBS")), ("rgb", _("RGB")), ("svideo", _("S-Video")) )) + config.av.yuvenabled = configElementBoolean("config.av.yuvenabled", 0) + colorformat_choices = ( ("cvbs", _("CVBS")), ("rgb", _("RGB")), ("svideo", _("S-Video")), ("yuv", _("YPbPr")) ) + + # when YUV is not enabled, don't let the user select it + if not config.av.yuvenabled.value: + colorformat_choices = colorformat_choices[:3] + + config.av.colorformat = configElement("config.av.colorformat", configSelection, 1, colorformat_choices) config.av.aspectratio = configElement("config.av.aspectratio", configSelection, 0, (("4_3_letterbox", _("4:3 Letterbox")), ("4_3_panscan", _("4:3 PanScan")), ("16_9", _("16:9")), ("16_9_always", _("16:9 always"))) ) #config.av.tvsystem = configElement("config.av.tvsystem", configSelection, 0, ("PAL", "PAL + PAL60", "Multi", "NTSC") ) config.av.tvsystem = configElement("config.av.tvsystem", configSelection, 0, (("pal", _("PAL")), ("ntsc", _("NTSC"))) ) @@ -86,7 +93,7 @@ def InitAVSwitch(): iAVSwitch.setSystem(configElement.value) def setWSS(configElement): - iAVSwitch.setWSS(configElement.value) + iAVSwitch.setAspectWSS() # this will call the "setup-val" initial config.av.colorformat.addNotifier(setColorFormat) @@ -94,4 +101,4 @@ def InitAVSwitch(): config.av.tvsystem.addNotifier(setSystem) config.av.wss.addNotifier(setWSS) - iAVSwitch.setInput("ENCODER") # init on startup \ No newline at end of file + iAVSwitch.setInput("ENCODER") # init on startup