X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/3861923553aad99f8b1a5ce5d81e7d9b035b65bb..0d6cafcc5471dbaee5b2a1ce68b6b6a5603abe17:/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py
diff --git a/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py b/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py
index 8fffa5a9..1d7ce7b5 100644
--- a/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py
+++ b/lib/python/Plugins/SystemPlugins/Videomode/VideoWizard.py
@@ -1,90 +1,178 @@
-from Screens.Wizard import Wizard, wizardManager
-import sys
+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
+from Components.Pixmap import Pixmap, MovingPixmap, MultiPixmap
from Components.config import config, ConfigBoolean, configfile
-class VideoWizard(Wizard):
+from Tools.Directories import resolveFilename, SCOPE_PLUGINS
+
+config.misc.showtestcard = ConfigBoolean(default = False)
+
+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)
+
+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 = sys.path[0] + "/Plugins/SystemPlugins/Videomode/videowizard.xml"
+ self.xmlfile = resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/videowizard.xml")
self.hw = video_hw
- Wizard.__init__(self, session, showSteps = False)
+ WizardLanguage.__init__(self, session, showSteps = False, showStepSlider = False)
+ Rc.__init__(self)
self["wizard"] = Pixmap()
- self["rc"] = MovingPixmap()
- self["arrowdown"] = MovingPixmap()
- self["arrowup"] = MovingPixmap()
- self["arrowup2"] = MovingPixmap()
+ self["portpic"] = Pixmap()
self.port = None
self.mode = None
+ self.rate = None
+
def createSummary(self):
print "++++++++++++***++**** VideoWizard-createSummary"
from Screens.Wizard import WizardSummary
- return WizardSummary
+ return VideoWizardSummary
def markDone(self):
- pass
+ config.misc.videowizardenabled.value = 0
+ config.misc.videowizardenabled.save()
+ configfile.save()
def listInputChannels(self):
list = []
for port in self.hw.getPortList():
if self.hw.isPortUsed(port):
- list.append((port, port))
+ list.append((port,port))
+ list.sort(key = lambda x: x[0])
+ print "listInputChannels:", list
return list
def inputSelectionMade(self, index):
print "inputSelectionMade:", index
self.port = index
+ self.inputSelect(index)
def inputSelectionMoved(self):
- print "selection moved:", self.selection
+ print "input selection moved:", self.selection
+ self.inputSelect(self.selection)
+ if self["portpic"].instance is not None:
+ self["portpic"].instance.setPixmapFromFile(resolveFilename(SCOPE_PLUGINS, "SystemPlugins/Videomode/" + self.selection + ".png"))
+
+ def inputSelect(self, port):
+ print "inputSelect:", port
+ modeList = self.hw.getModeList(self.selection)
+ print "modeList:", modeList
+ self.port = port
+ ratesList = self.listRates(modeList[0][0])
+ self.hw.setMode(port = port, mode = modeList[0][0], rate = ratesList[0][0])
def listModes(self):
list = []
print "modes for port", self.port
for mode in self.hw.getModeList(self.port):
- list.append((mode[0], mode[0]))
+ #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)
def modeSelectionMoved(self):
- print "selection moved:", self.selection
+ print "mode selection moved:", self.selection
+ self.modeSelect(self.selection)
+
+ def modeSelect(self, mode):
+ ratesList = self.listRates(mode)
+ print "ratesList:", ratesList
+ self.hw.setMode(port = self.port, mode = mode, rate = ratesList[0][0])
- def listRates(self):
+ def listRates(self, querymode = None):
+ if querymode is None:
+ querymode = self.mode
list = []
- print "modes for port", self.port
+ print "modes for port", self.port, "and mode", querymode
for mode in self.hw.getModeList(self.port):
print mode
- if mode[0] == self.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))
return list
def rateSelectionMade(self, index):
print "rateSelectionMade:", index
+ self.rate = index
+ self.rateSelect(index)
def rateSelectionMoved(self):
- print "selection moved:", self.selection
+ print "rate selection moved:", self.selection
+ self.rateSelect(self.selection)
+
+ def rateSelect(self, rate):
+ self.hw.setMode(port = self.port, mode = self.mode, rate = rate)
+
+ def showTestCard(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)