X-Git-Url: http://code.vuplus.com/gitweb/?p=vuplus_dvbapp;a=blobdiff_plain;f=lib%2Fpython%2FPlugins%2FSystemPlugins%2FVideomode%2FVideoWizard.py;h=97038e956fa228736e0f1b420555826a9c9cf293;hp=18e817645639fb6e041ee1f67e69a60494647949;hb=14785fc7f322f874992edc61bd00d9b0e38d6d36;hpb=4d337c52ff25fb3350e7678ebbf5a969c8db8374 diff --git a/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py b/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py old mode 100755 new mode 100644 index 18e8176..97038e9 --- a/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py +++ b/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py @@ -1,200 +1,120 @@ from Screens.Wizard import WizardSummary from Screens.WizardLanguage import WizardLanguage from Screens.Rc import Rc -from VideoHardware import video_hw - -from Components.Pixmap import Pixmap, MovingPixmap, MultiPixmap -from Components.config import config, ConfigBoolean, configfile - +from Components.Pixmap import Pixmap +from Components.config import config, configfile, ConfigBoolean from Tools.Directories import resolveFilename, SCOPE_PLUGINS -from Tools.HardwareInfo import HardwareInfo -config.misc.showtestcard = ConfigBoolean(default = False) +from VideoHardware import video_hw -class VideoWizardSummary(WizardSummary): - skin = ( - """ - - - - - - """, - """ - - - - - - """) - #% (resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/lcd_Scart.png")) - - def __init__(self, session, parent): - WizardSummary.__init__(self, session, parent) - #self["pic"] = Pixmap() - - def setLCDPicCallback(self): - self.parent.setLCDTextCallback(self.setText) - - def setLCDPic(self, file): - self["pic"].instance.setPixmapFromFile(file) +config.misc.showtestcard = ConfigBoolean(default = False) class VideoWizard(WizardLanguage, Rc): skin = """ - + - + - - - + + - - - - - - - """ % (resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/Scart.png")) - + + + + + + + + """ + def __init__(self, session): - # FIXME anyone knows how to use relative paths from the plugin's directory? self.xmlfile = resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/videowizard.xml") - self.hw = video_hw - - WizardLanguage.__init__(self, session, showSteps = False, showStepSlider = False) + self.video_cfg = video_hw + + WizardLanguage.__init__(self, session) Rc.__init__(self) + self["wizard"] = Pixmap() self["portpic"] = Pixmap() - + self.port = None self.mode = None self.rate = None - - + def createSummary(self): - print "++++++++++++***++**** VideoWizard-createSummary" from Screens.Wizard import WizardSummary - return VideoWizardSummary - + return WizardSummary + def markDone(self): - config.misc.videowizardenabled.value = 0 + config.misc.videowizardenabled.setValue(False) config.misc.videowizardenabled.save() configfile.save() - def listInputChannels(self): - hw_type = HardwareInfo().get_device_name() - list = [] - - for port in self.hw.getPortList(): - if self.hw.isPortUsed(port): - descr = port - if descr == 'DVI' and hw_type in ('dm500hd', 'dm800se', 'dm7020hd'): - descr = 'HDMI' + def portList(self): + hw_type = self.video_cfg.getDeviceName() + list = [ ] + + for port in self.video_cfg.getPortList(): + if self.video_cfg.isPortUsed(port): + desc = port + if desc == "DVI" and self.video_cfg.isHDMIAvailable(hw_type): + desc = "HDMI" + if port != "DVI-PC": - list.append((descr,port)) + list.append( (desc, port)) + list.sort(key = lambda x: x[0]) - print "listInputChannels:", list return list - def inputSelectionMade(self, index): - print "inputSelectionMade:", index + def portSelectionMade(self, index): self.port = index - self.inputSelect(index) - - def inputSelectionMoved(self): - print "input selection moved:", self.selection - self.inputSelect(self.selection) - if self["portpic"].instance is not None: - picname = self.selection - if picname == "DVI" and HardwareInfo().get_device_name() in ("dm500hd", "dm800se", "dm7020hd"): - picname = "HDMI" - self["portpic"].instance.setPixmapFromFile(resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/" + picname + ".png")) - - def inputSelect(self, port): - print "inputSelect:", port - modeList = self.hw.getModeList(self.selection) - print "modeList:", modeList - self.port = port - if (len(modeList) > 0): - ratesList = self.listRates(modeList[0][0]) - self.hw.setMode(port = port, mode = modeList[0][0], rate = ratesList[0][0]) + self.video_cfg.setVideomode(self.port, self.mode, self.rate) + + def portSelectionMoved(self): + self.video_cfg.setVideomode(self.selection, self.mode, self.rate) + + def modeList(self): + list = [ ] + for mode in self.video_cfg.getModeList(self.port): + list.append( (mode, mode)) - def listModes(self): - list = [] - print "modes for port", self.port - for mode in self.hw.getModeList(self.port): - #if mode[0] != "PC": - list.append((mode[0], mode[0])) - print "modeslist:", list return list - + def modeSelectionMade(self, index): - print "modeSelectionMade:", index self.mode = index - self.modeSelect(index) - + self.modeSelect(self.mode) + def modeSelectionMoved(self): - print "mode selection moved:", self.selection self.modeSelect(self.selection) - + def modeSelect(self, mode): - ratesList = self.listRates(mode) - print "ratesList:", ratesList - if self.port == "DVI" and mode in ("720p", "1080i"): + if self.port == "DVI" and self.video_cfg.isWidescreenMode(mode): self.rate = "multi" - self.hw.setMode(port = self.port, mode = mode, rate = "multi") else: - self.hw.setMode(port = self.port, mode = mode, rate = ratesList[0][0]) - - def listRates(self, querymode = None): - if querymode is None: - querymode = self.mode - list = [] - print "modes for port", self.port, "and mode", querymode - for mode in self.hw.getModeList(self.port): - print mode - if mode[0] == querymode: - for rate in mode[1]: - if self.port == "DVI-PC": - print "rate:", rate - if rate == "640x480": - list.insert(0, (rate, rate)) - continue - list.append((rate, rate)) + self.rate = None + self.video_cfg.setVideomode(self.port, mode, self.rate) + + def rateList(self): + list = [ ] + for rate in self.video_cfg.getRateList(self.port, self.mode): + list.append( (rate, rate)) + return list - + def rateSelectionMade(self, index): - print "rateSelectionMade:", index self.rate = index - self.rateSelect(index) - + self.video_cfg.setVideomode(self.port, self.mode, self.rate) + def rateSelectionMoved(self): - print "rate selection moved:", self.selection - self.rateSelect(self.selection) + self.video_cfg.setVideomode(self.port, self.mode, self.selection) - def rateSelect(self, rate): - self.hw.setMode(port = self.port, mode = self.mode, rate = rate) - - def showTestCard(self, selection = None): + def showVideoTune(self, selection = None): if selection is None: selection = self.selection - print "set config.misc.showtestcard to", {'yes': True, 'no': False}[selection] + if selection == "yes": config.misc.showtestcard.value = True else: config.misc.showtestcard.value = False - def keyNumberGlobal(self, number): - if number in (1,2,3): - if number == 1: - self.hw.saveMode("DVI", "720p", "multi") - elif number == 2: - self.hw.saveMode("DVI", "1080i", "multi") - elif number == 3: - self.hw.saveMode("Scart", "Multi", "multi") - self.hw.setConfiguredMode() - self.close() - - WizardLanguage.keyNumberGlobal(self, number)