X-Git-Url: https://git.cweiske.de/enigma2.git/blobdiff_plain/9202d4248dd7df2f6e5eb53b4154c8297ec9b1d1..a5307ff8aa3456aa5bec285e7d94d8d7c014d131:/mytest.py diff --git a/mytest.py b/mytest.py index 0cbeac02..c0967d78 100644 --- a/mytest.py +++ b/mytest.py @@ -29,7 +29,6 @@ screens["global"](components) # test our screens components["$001"] = screens["testDialog"]() -components["$002"] = screens["clockDisplay"](components["clock"]) print "*** classes:" dump(screens) @@ -55,24 +54,65 @@ class GUIOutputDevice(OutputDevice): def create(self, comp): comp.createGUIScreen(self.parent) -def runScreenTest(): - desktop = getDesktop() - - wnd = eWindow(desktop) - mainwnd = wnd - wnd.setTitle("Screen from python!") - wnd.move(ePoint(300, 100)) - wnd.resize(eSize(300, 300)) - - gui = GUIOutputDevice() - gui.parent = wnd - gui.create(components["$002"]) - - applyGUIskin(components["$002"], None, "clockDialog") +class Session: + def __init__(self): + self.desktop = None + self.delayTimer = eTimer() + self.delayTimer.timeout.get().append(self.processDelay) + + self.currentDialog = None + + def processDelay(self): + self.currentDialog.close() + if self.currentWindow != None: + self.currentWindow.hide() + + del self.currentDialog + del self.currentWindow + + self.open(screens["testDialog"]()) + + def open(self, screen): + self.currentDialog = screen + screen.session = self + + if self.desktop != None: + self.currentWindow = wnd = eWindow(self.desktop) + wnd.setTitle("Screen from python!") + wnd.move(ePoint(300, 100)) + wnd.resize(eSize(300, 300)) + + gui = GUIOutputDevice() + gui.parent = wnd + gui.create(self.currentDialog) + + applyGUIskin(self.currentDialog, None, screen.__class__.__name__) + + wnd.show() + else: + self.currentWindow = None + + def close(self): + self.delayTimer.start(0, 1) - wnd.show() +def runScreenTest(): + session = Session() + session.desktop = getDesktop() + + session.open(screens["clockDisplay"](components["clock"])) +# session.open(screens["testDialog"]()) + + # simple reason for this helper function: we want to call the currently + # active "okbutton", even when we changed the dialog + # + # more complicated reason: we don't want to hold a reference. + def blub(): + session.currentDialog.data["okbutton"]["instance"].push() + + tmr = eTimer() + tmr.timeout.get().append(blub) + tmr.start(4000, 0) -# components["$002"].data["okbutton"]["instance"].push() runMainloop() return 0