X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=naja%2Fwidgets%2Finfo_area.py;h=b4c6e2b2a66208b522d638928eddc300f9118399;hb=3273de8b8e17a1d13e46ba920241eae1602d54bb;hp=453e379d1be743a52891a565e9ae4442bc72b77a;hpb=a6de62bab3beb608b3fd9f975947f4a46ec5d1c9;p=naja.git diff --git a/naja/widgets/info_area.py b/naja/widgets/info_area.py index 453e379..b4c6e2b 100644 --- a/naja/widgets/info_area.py +++ b/naja/widgets/info_area.py @@ -12,20 +12,21 @@ from naja.events import finish_event from naja.resources import resources from naja.resources.mutators import EIGHT_BIT, blender from naja.sound import sound -from naja.utils import bit_glyphs +from naja.utils import bit_glyphs, Flashlight from naja.widgets.base import Widget from naja.widgets.tile import BIT_MAP -from naja.widgets.text import TextBoxWidget, TextWidget +from naja.widgets.text import TextBoxWidget +from naja import constants HINTS = { - ACT: "Choose an action using {NORTH,SOUTH} keys.\n" - "Press {RETURN} to execute it.", + ACT: "Choose an action using {NORTH,SOUTH}." + " Press {RETURN} to execute it.", EXAMINE: "Browse the tiles with {NORTH,SOUTH,EAST,WEST} keys.", } -HINT_LEGAL_MOVE = "\nPress {RETURN} to move to this tile." +HINT_LEGAL_MOVE = "\nPress {RETURN} to move." TITLES = { ACT: "Choose an Action", @@ -43,6 +44,7 @@ class InfoAreaWidget(Widget): self.chosen = None self.card_position = state.player.position self.set_position(state.player.position) + self.flash_light = Flashlight(constants.FPS // 2) def prepare(self): if self.state.gameboard.player_mode == ACT: @@ -106,14 +108,14 @@ class InfoAreaWidget(Widget): if gameboard.puzzle: return "PUZZLE" return { - 0: "DEATH", 1: "LUDICROUS", - 2: "RAMBO", 3: "HARD", + 0: "DEATH", 1: "NINTENDO HARD", + 2: "VERY HARD", 3: "HARD", 4: "STANDARD", 5: "EASY", }.get(gameboard.max_health, "UNKNOWN") def prepare_action(self, choice, action, y_offset, box_width): x_offset = INFO_LEFT_PADDING - glyphs_x_offset = 0 + glyphs_x_offset = 2 glyphs_y_offset = y_offset y_offset += ACTION_TEXT_OFFSET action_viable = action.check_available(self.state.player) @@ -128,7 +130,13 @@ class InfoAreaWidget(Widget): border_colour = None if choice == self.chosen: - border_colour = PALETTE.GREEN if action_viable else PALETTE.ORANGE + if self.flash_light.on: + border_colour = (PALETTE.GREEN if action_viable else + PALETTE.ORANGE) + else: + border_colour = (PALETTE.DARK_GREEN if action_viable else + PALETTE.DARK_RED) + if border_colour: bottom = y_offset + text.surface.get_rect().height right = text.surface.get_rect().width + x_offset @@ -179,6 +187,8 @@ class InfoAreaWidget(Widget): self.chosen = None def draw(self, surface): + if self.flash_light.tick(): + self.prepare() surface.blit(self.surface, self.pos) def next_action(self, viable_only=False, step=1):