reenable PC mode video selection for dvi ports in the video wizard
[enigma2.git] / lib / python / Plugins / SystemPlugins / Videomode / VideoWizard.py
index b4223b5ff455c2e05644f7f3d4e9e0c6ffd6758e..f46b11c26b3787754554a972b0eb0d705146861b 100644 (file)
@@ -1,4 +1,5 @@
-from Screens.Wizard import Wizard, wizardManager, WizardSummary
+from Screens.Wizard import wizardManager, WizardSummary
+from Screens.WizardLanguage import WizardLanguage
 import sys
 from VideoHardware import video_hw
 
@@ -31,20 +32,22 @@ class VideoWizardSummary(WizardSummary):
        def setLCDPic(self, file):
                self["pic"].instance.setPixmapFromFile(file)
 
-class VideoWizard(Wizard):
+class VideoWizard(WizardLanguage):
        skin = """
                <screen position="0,0" size="720,576" title="Welcome..." flags="wfNoBorder" >
                        <widget name="text" position="153,50" size="340,270" font="Regular;23" />
                        <widget source="list" render="Listbox" position="200,300" size="290,200" scrollbarMode="showOnDemand" >
                                <convert type="StringList" />
                        </widget>
-                       <widget name="config" position="50,300" zPosition="1" size="440,200" transparent="1" scrollbarMode="showOnDemand" />                    
-                       <widget name="wizard" pixmap="wizard.png" position="40,50" zPosition="10" size="110,174" transparent="1" alphatest="on"/>
+                       <widget name="config" position="50,300" zPosition="1" size="440,200" transparent="1" scrollbarMode="showOnDemand" />
+                       <widget name="wizard" pixmap="skin_default/wizard.png" position="40,50" zPosition="10" size="110,174" transparent="1" alphatest="on"/>
+                       <ePixmap pixmap="skin_default/buttons/button_red.png" position="40,225" zPosition="0" size="15,16" transparent="1" alphatest="on" />
+                       <widget name="languagetext" position="55,225" size="95,30" font="Regular;18" />
                        <widget name="portpic" pixmap="%s" position="50,300" zPosition="10" size="150,150" transparent="1" alphatest="on"/>
-                       <widget name="rc" pixmap="rc.png" position="500,600" zPosition="10" size="154,475" transparent="1" alphatest="on"/>
-                       <widget name="arrowdown" pixmap="arrowdown.png" position="0,0" zPosition="11" size="37,70" transparent="1" alphatest="on"/>
-                       <widget name="arrowup" pixmap="arrowup.png" position="-100,-100" zPosition="11" size="37,70" transparent="1" alphatest="on"/>
-                       <widget name="arrowup2" pixmap="arrowup.png" position="-100,-100" zPosition="11" size="37,70" transparent="1" alphatest="on"/>
+                       <widget name="rc" pixmap="skin_default/rc.png" position="500,600" zPosition="10" size="154,475" transparent="1" alphatest="on"/>
+                       <widget name="arrowdown" pixmap="skin_default/arrowdown.png" position="0,0" zPosition="11" size="37,70" transparent="1" alphatest="on"/>
+                       <widget name="arrowup" pixmap="skin_default/arrowup.png" position="-100,-100" zPosition="11" size="37,70" transparent="1" alphatest="on"/>
+                       <widget name="arrowup2" pixmap="skin_default/arrowup.png" position="-100,-100" zPosition="11" size="37,70" transparent="1" alphatest="on"/>
                </screen>""" % (resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/Scart.png"))
        
        def __init__(self, session):
@@ -52,7 +55,7 @@ class VideoWizard(Wizard):
                self.xmlfile = resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/videowizard.xml")
                self.hw = video_hw
                
-               Wizard.__init__(self, session, showSteps = False, showStepSlider = False)
+               WizardLanguage.__init__(self, session, showSteps = False, showStepSlider = False)
                self["wizard"] = Pixmap()
                self["rc"] = MovingPixmap()
                self["portpic"] = Pixmap()
@@ -62,6 +65,7 @@ class VideoWizard(Wizard):
                
                self.port = None
                self.mode = None
+               self.rate = None
                
                
        def createSummary(self):
@@ -70,7 +74,9 @@ class VideoWizard(Wizard):
                return VideoWizardSummary
                
        def markDone(self):
-               pass
+               config.misc.videowizardenabled.value = 0
+               config.misc.videowizardenabled.save()
+               configfile.save()
        
        def listInputChannels(self):
                list = []
@@ -78,6 +84,7 @@ class VideoWizard(Wizard):
                for port in self.hw.getPortList():
                        if self.hw.isPortUsed(port):
                                list.append((port,port))
+               list.sort(key = lambda x: x[0])
                print "listInputChannels:", list
                return list
 
@@ -102,7 +109,7 @@ class VideoWizard(Wizard):
                list = []
                print "modes for port", self.port
                for mode in self.hw.getModeList(self.port):
-                       if mode[0] != "PC":
+                       #if mode[0] != "PC":
                                list.append((mode[0], mode[0]))
                print "modeslist:", list
                return list
@@ -135,6 +142,7 @@ class VideoWizard(Wizard):
        
        def rateSelectionMade(self, index):
                print "rateSelectionMade:", index
+               self.rate = index
                self.rateSelect(index)
                
        def rateSelectionMoved(self):
@@ -152,3 +160,16 @@ class VideoWizard(Wizard):
                        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)