X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=koperkapel%2Fscenes%2Fmenu.py;h=65128b9e49d3184028320914508063cbc727c877;hb=685bc607ffc97579ab5522e9c799ee0eef334777;hp=4d3b5cf70219613b396638e34de2b997c86ec000;hpb=5ab15f1f73b9997759ab4bc2ecb02334ffd1e9a9;p=koperkapel.git diff --git a/koperkapel/scenes/menu.py b/koperkapel/scenes/menu.py index 4d3b5cf..65128b9 100644 --- a/koperkapel/scenes/menu.py +++ b/koperkapel/scenes/menu.py @@ -1,10 +1,59 @@ """ Main menu scene. """ -from .base import Scene +from pgzero.constants import keys +from ..actors.buttons import TextButton +from ..actors.navigator import ActorNavigator +from .base import Scene, ChangeSceneEvent, WorldEvent, QuitEvent class MenuScene(Scene): """ Main menu scene. """ - def draw(self, screen): - screen.draw.text("Main menu", (300, 300)) + def __init__(self): + super().__init__() + self._title = self.actors.add(TextButton("Main Menu")) + self._title.pos = (300, 100) + self._nav = ActorNavigator() + self._menu = [ + TextButton("New Game", action=self.change_to_new_game), + TextButton("Resume", action=self.change_to_resume), + TextButton("Credits", action=self.change_to_credits), + TextButton("Quit", action=self.quit), + ] + for i, item in enumerate(self._menu): + item.pos = (300, 200 + (i * 100)) + self.actors.add(item) + self._nav.connect( + self._menu, [keys.DOWN, keys.RIGHT], [keys.UP, keys.LEFT], + wrap=True) + self._nav.current.select() + + def change_to_resume(self): + from .level import GameLevelScene + return [ChangeSceneEvent(GameLevelScene())] + + def change_to_new_game(self): + from .level import GameLevelScene + return [ + WorldEvent("reset"), + ChangeSceneEvent(GameLevelScene()) + ] + + def change_to_credits(self): + from .credits import CreditsScene + return [ChangeSceneEvent(CreditsScene())] + + def quit(self): + return [QuitEvent()] + + def on_key_down(self, key, mod, unicode): + if key == keys.RETURN: + current = self._nav.current + if current is not None: + return current.action() + else: + prev, current = self._nav.follow(key) + if prev is not None: + prev.deselect() + if current is not None: + current.select()