show lists and configs in startwizard by adjusting the zPosition
authorStefan Pluecken <stefan.pluecken@multimedia-labs.de>
Fri, 9 Dec 2005 10:30:39 +0000 (10:30 +0000)
committerStefan Pluecken <stefan.pluecken@multimedia-labs.de>
Fri, 9 Dec 2005 10:30:39 +0000 (10:30 +0000)
left/right is now possible with configlists in the wizard
up/down possible with lists but doesn't work on configlists (why?)

data/keymap.xml
lib/python/Components/ConditionalWidget.py
lib/python/Components/GUIComponent.py
lib/python/Components/Pixmap.py
lib/python/Screens/Wizard.py

index 91f8262..1a0c5c5 100644 (file)
                <key id="BTN_1" mapto="zapDown" flags="mr" />
        </map>
        
+       <map context="WizardActions">
+               <key id="KEY_LEFT" mapto="left" flags="mr" />
+               <key id="KEY_RIGHT" mapto="right" flags="mr" />
+               <key id="KEY_UP" mapto="up" flags="mr" />
+               <key id="KEY_DOWN" mapto="down" flags="mr" />
+               <key id="KEY_OK" mapto="ok" flags="m" />
+       </map>
+       
        <map context="InfobarMenuActions">
                <key id="KEY_MENU" mapto="mainMenu" flags="mr" />
        </map>
                <key id="KEY_POWER" mapto="powerup" flags="b" />
        </map>
        
+       <map context="NumberActions">
+               <key id="KEY_1" mapto="1" flags="m" />
+               <key id="KEY_2" mapto="2" flags="m" />
+               <key id="KEY_3" mapto="3" flags="m" />
+               <key id="KEY_4" mapto="4" flags="m" />
+               <key id="KEY_5" mapto="5" flags="m" />
+               <key id="KEY_6" mapto="6" flags="m" />
+               <key id="KEY_7" mapto="7" flags="m" />
+               <key id="KEY_8" mapto="8" flags="m" />
+               <key id="KEY_9" mapto="9" flags="m" />
+               <key id="KEY_0" mapto="0" flags="m" />
+       </map>
+       
        <map context="NumberZapActions">
                <key id="KEY_1" mapto="1" flags="m" />
                <key id="KEY_2" mapto="2" flags="m" />
index 3d855b2..52dcb20 100644 (file)
@@ -30,6 +30,9 @@ class Widget(GUIComponent):
        def hideWidget(self):
                self.state = self.HIDDEN
                self.instance.hide()
+               
+       def move(self, x, y):
+               self.instance.move(ePoint(int(x), int(y)))
        
 class ConditionalWidget(Widget):
        def __init__(self, withTimer = True):
index fee9341..b84cf8c 100644 (file)
@@ -1,5 +1,7 @@
 import skin
 
+from enigma import ePoint
+
 class GUIComponent:
        """ GUI component """
        
@@ -15,3 +17,6 @@ class GUIComponent:
        # this works only with normal widgets - if you don't have self.instance, override this.
        def applySkin(self, desktop):
                skin.applyAllAttributes(self.instance, desktop, self.skinAttributes)
+
+       def move(self, x, y):
+               self.instance.move(ePoint(int(x), int(y)))
\ No newline at end of file
index d25530e..211b772 100644 (file)
@@ -17,9 +17,6 @@ class Pixmap(Widget):
        def removeWidget(self, w):
                pass
 
-       def move(self, x, y):
-               self.instance.move(ePoint(int(x), int(y)))
-
 class PixmapConditional(ConditionalWidget, Pixmap):
        def __init__(self, withTimer = True):
                ConditionalWidget.__init__(self)
index f0d99a9..fbf2632 100644 (file)
@@ -3,7 +3,7 @@ from Screen import Screen
 from Screens.HelpMenu import HelpableScreen
 from Components.Label import Label
 from Components.Slider import Slider
-from Components.ActionMap import HelpableActionMap
+from Components.ActionMap import HelpableActionMap, NumberActionMap
 from Components.config import config, configElementBoolean
 from Components.Pixmap import *
 from Components.MenuList import MenuList
@@ -19,13 +19,13 @@ class WelcomeWizard(Screen, HelpableScreen):
        skin = """
                <screen position="0,0" size="720,560" title="Welcome..." flags="wfNoBorder" >
                        <widget name="text" position="50,100" size="440,200" font="Arial;23" />
-                       <widget name="list" position="50,300" size="440,200" />
-                       <widget name="config" position="50,300" zPosition="100" size="440,200" />                       
+                       <widget name="list" position="50,300" zPosition="1" size="440,200" />
+                       <widget name="config" position="50,300" zPosition="1" size="440,200" transparent="1" />                 
                        <widget name="step" position="50,50" size="440,25" font="Arial;23" />
                        <widget name="stepslider" position="50,500" zPosition="1" size="440,20" backgroundColor="dark" />
-                       <widget name="rc" pixmap="/usr/share/enigma2/rc.png" position="500,600" size="154,475" transparent="1" alphatest="on"/>
-                       <widget name="arrowdown" pixmap="/usr/share/enigma2/arrowdown.png" position="0,0" zPosition="1" size="37,70" transparent="1" alphatest="on"/>
-                       <widget name="arrowup" pixmap="/usr/share/enigma2/arrowup.png" position="-100,-100" zPosition="1" size="37,70" transparent="1" alphatest="on"/>
+                       <widget name="rc" pixmap="/usr/share/enigma2/rc.png" position="500,600" zPosition="10" size="154,475" transparent="1" alphatest="on"/>
+                       <widget name="arrowdown" pixmap="/usr/share/enigma2/arrowdown.png" position="0,0" zPosition="10" size="37,70" transparent="1" alphatest="on"/>
+                       <widget name="arrowup" pixmap="/usr/share/enigma2/arrowup.png" position="-100,-100" zPosition="10" size="37,70" transparent="1" alphatest="on"/>
                </screen>"""
 
        class parseWizard(ContentHandler):
@@ -89,48 +89,92 @@ class WelcomeWizard(Screen, HelpableScreen):
                self.list = []
                self["list"] = MenuList(self.list)
 
-               self.updateValues()
+               self.onShown.append(self.updateValues)
                
-               self["actions"] = HelpableActionMap(self, "OkCancelActions",
-                       {
-                               "ok": (self.ok, _("Close this Screen...")),
-                       })
+               self["actions"] = NumberActionMap(["WizardActions", "NumberActions"],
+               {
+                       "ok": self.ok,
+                       #"cancel": self.keyCancel,
+                       "left": self.left,
+                       "right": self.right,
+                       #"up": self.up,
+                       #"down": self.down,
+                       #"1": self.keyNumberGlobal,
+                       #"2": self.keyNumberGlobal,
+                       #"3": self.keyNumberGlobal,
+                       #"4": self.keyNumberGlobal,
+                       #"5": self.keyNumberGlobal,
+                       #"6": self.keyNumberGlobal,
+                       #"7": self.keyNumberGlobal,
+                       #"8": self.keyNumberGlobal,
+                       #"9": self.keyNumberGlobal,
+                       #"0": self.keyNumberGlobal
+               }, -1)
+               
+               #self["actions"] = HelpableActionMap(self, "OkCancelActions",
+                       #{
+                               #"ok": (self.ok, _("Close this Screen...")),
+                       #})
 
+       def ok(self):
+               if (self.currStep == self.numSteps): # wizard finished
+                       config.misc.firstrun.value = 0;
+                       config.misc.firstrun.save()
+                       self.session.close()
+               else:
+                       self.currStep += 1
+                       self.updateValues()
+
+       def left(self):
+               if (self.wizard[self.currStep]["config"]["screen"] != None):
+                       self.configInstance.keyLeft()
+               print "left"
+       
+       def right(self):
+               if (self.wizard[self.currStep]["config"]["screen"] != None):
+                       self.configInstance.keyRight()
+               print "right"
+
+       def up(self):
+               if (self.wizard[self.currStep]["config"]["screen"] != None):
+                       self.configInstance.handleKey("moveUp")
+               print "up"
+               
+       def down(self):
+               if (self.wizard[self.currStep]["config"]["screen"] != None):
+                       self.configInstance.handleKey("moveDown")
+               print "down"
+               
        def updateValues(self):
                self["step"].setText(_("Step ") + str(self.currStep) + "/" + str(self.numSteps))
                self["stepslider"].setValue(self.currStep)
 
                self["text"].setText(self.wizard[self.currStep]["text"])
                
+               self["list"].instance.setZPosition(1)
                self.list = []
                if (len(self.wizard[self.currStep]["list"]) > 0):
+                       self["list"].instance.setZPosition(2)
                        for x in self.wizard[self.currStep]["list"]:
                                self.list.append((x, None))
                self["list"].l.setList(self.list)
-               
+
+               self["config"].instance.setZPosition(1)
                if (self.wizard[self.currStep]["config"]["screen"] != None):
+                       self["config"].instance.setZPosition(2)
                        print self.wizard[self.currStep]["config"]["screen"]
                        if self.wizard[self.currStep]["config"]["args"] == None:
                                self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"])
                        else:
                                self.configInstance = self.session.instantiateDialog(self.wizard[self.currStep]["config"]["screen"], eval(self.wizard[self.currStep]["config"]["args"]))
-
                        self["config"].l.setList(self.configInstance["config"].list)
+                       self.configInstance["config"] = self["config"]
                else:
                        self["config"].l.setList([])
 
                if self.wizard[self.currStep]["code"] != "":
                        print self.wizard[self.currStep]["code"]
                        exec(self.wizard[self.currStep]["code"])
-                       
-       def ok(self):
-               if (self.currStep == self.numSteps): # wizard finished
-                       config.misc.firstrun.value = 0;
-                       config.misc.firstrun.save()
-                       self.session.close()
-               else:
-                       self.currStep += 1
-                       self.updateValues()
 
 def listActiveWizards():
        wizards = [ ]