Merge remote-tracking branch 'origin/master' into village
# Conflicts: # squirrelbattle/display/texturepack.py # squirrelbattle/interfaces.py
This commit is contained in:
		| @@ -0,0 +1,2 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| import curses | ||||
| from typing import Any, Optional, Union | ||||
|  | ||||
| @@ -19,6 +22,24 @@ class Display: | ||||
|     def newpad(self, height: int, width: int) -> Union[FakePad, Any]: | ||||
|         return curses.newpad(height, width) if self.screen else FakePad() | ||||
|  | ||||
|     def truncate(self, msg: str, height: int, width: int) -> str: | ||||
|         height = max(0, height) | ||||
|         width = max(0, width) | ||||
|         lines = msg.split("\n") | ||||
|         lines = lines[:height] | ||||
|         lines = [line[:width] for line in lines] | ||||
|         return "\n".join(lines) | ||||
|  | ||||
|     def addstr(self, pad: Any, y: int, x: int, msg: str, *options) -> None: | ||||
|         """ | ||||
|         Display a message onto the pad. | ||||
|         If the message is too large, it is truncated vertically and horizontally | ||||
|         """ | ||||
|         height, width = pad.getmaxyx() | ||||
|         msg = self.truncate(msg, height - y, width - x - 1) | ||||
|         if msg.replace("\n", "") and x >= 0 and y >= 0: | ||||
|             return pad.addstr(y, x, msg, *options) | ||||
|  | ||||
|     def init_pair(self, number: int, foreground: int, background: int) -> None: | ||||
|         return curses.init_pair(number, foreground, background) \ | ||||
|             if self.screen else None | ||||
| @@ -32,14 +53,36 @@ class Display: | ||||
|         self.y = y | ||||
|         self.width = width | ||||
|         self.height = height | ||||
|         if hasattr(self, "pad") and resize_pad: | ||||
|             self.pad.resize(self.height, self.width) | ||||
|         if hasattr(self, "pad") and resize_pad and \ | ||||
|                 self.height >= 0 and self.width >= 0: | ||||
|             self.pad.resize(self.height + 1, self.width + 1) | ||||
|  | ||||
|     def refresh(self, *args, resize_pad: bool = True) -> None: | ||||
|         if len(args) == 4: | ||||
|             self.resize(*args, resize_pad) | ||||
|         self.display() | ||||
|  | ||||
|     def refresh_pad(self, pad: Any, top_y: int, top_x: int, | ||||
|                     window_y: int, window_x: int, | ||||
|                     last_y: int, last_x: int) -> None: | ||||
|         """ | ||||
|         Refresh a pad on a part of the window. | ||||
|         The refresh starts at coordinates (top_y, top_x) from the pad, | ||||
|         and is drawn from (window_y, window_x) to (last_y, last_x). | ||||
|         If coordinates are invalid (negative indexes/length..., then nothing | ||||
|         is drawn and no error is raised. | ||||
|         """ | ||||
|         top_y, top_x = max(0, top_y), max(0, top_x) | ||||
|         window_y, window_x = max(0, window_y), max(0, window_x) | ||||
|         screen_max_y, screen_max_x = self.screen.getmaxyx() if self.screen \ | ||||
|             else (42, 42) | ||||
|         last_y, last_x = min(screen_max_y - 1, last_y), \ | ||||
|             min(screen_max_x - 1, last_x) | ||||
|  | ||||
|         if last_y >= window_y and last_x >= window_x: | ||||
|             # Refresh the pad only if coordinates are valid | ||||
|             pad.refresh(top_y, top_x, window_y, window_x, last_y, last_x) | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         raise NotImplementedError | ||||
|  | ||||
| @@ -50,3 +93,68 @@ class Display: | ||||
|     @property | ||||
|     def cols(self) -> int: | ||||
|         return curses.COLS if self.screen else 42 | ||||
|  | ||||
|  | ||||
| class VerticalSplit(Display): | ||||
|  | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         super().__init__(*args, **kwargs) | ||||
|         self.pad = self.newpad(self.rows, 1) | ||||
|  | ||||
|     @property | ||||
|     def width(self) -> int: | ||||
|         return 1 | ||||
|  | ||||
|     @width.setter | ||||
|     def width(self, val: Any) -> None: | ||||
|         pass | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         for i in range(self.height): | ||||
|             self.addstr(self.pad, i, 0, "┃") | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, | ||||
|                          self.y + self.height - 1, self.x) | ||||
|  | ||||
|  | ||||
| class HorizontalSplit(Display): | ||||
|  | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         super().__init__(*args, **kwargs) | ||||
|         self.pad = self.newpad(1, self.cols) | ||||
|  | ||||
|     @property | ||||
|     def height(self) -> int: | ||||
|         return 1 | ||||
|  | ||||
|     @height.setter | ||||
|     def height(self, val: Any) -> None: | ||||
|         pass | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         for i in range(self.width): | ||||
|             self.addstr(self.pad, 0, i, "━") | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, self.y, | ||||
|                          self.x + self.width - 1) | ||||
|  | ||||
|  | ||||
| class Box(Display): | ||||
|  | ||||
|     def __init__(self, *args, fg_border_color: Optional[int] = None, **kwargs): | ||||
|         super().__init__(*args, **kwargs) | ||||
|         self.pad = self.newpad(self.rows, self.cols) | ||||
|         self.fg_border_color = fg_border_color or curses.COLOR_WHITE | ||||
|  | ||||
|         pair_number = 4 + self.fg_border_color | ||||
|         self.init_pair(pair_number, self.fg_border_color, curses.COLOR_BLACK) | ||||
|         self.pair = self.color_pair(pair_number) | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         self.addstr(self.pad, 0, 0, "┏" + "━" * (self.width - 2) + "┓", | ||||
|                     self.pair) | ||||
|         for i in range(1, self.height - 1): | ||||
|             self.addstr(self.pad, i, 0, "┃", self.pair) | ||||
|             self.addstr(self.pad, i, self.width - 1, "┃", self.pair) | ||||
|         self.addstr(self.pad, self.height - 1, 0, | ||||
|                     "┗" + "━" * (self.width - 2) + "┛", self.pair) | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, | ||||
|                          self.y + self.height - 1, self.x + self.width - 1) | ||||
|   | ||||
| @@ -1,5 +1,10 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| import curses | ||||
| from squirrelbattle.display.display import VerticalSplit, HorizontalSplit | ||||
| from squirrelbattle.display.mapdisplay import MapDisplay | ||||
| from squirrelbattle.display.messagedisplay import MessageDisplay | ||||
| from squirrelbattle.display.statsdisplay import StatsDisplay | ||||
| from squirrelbattle.display.menudisplay import SettingsMenuDisplay, \ | ||||
|     MainMenuDisplay | ||||
| @@ -22,9 +27,12 @@ class DisplayManager: | ||||
|                                                screen, pack) | ||||
|         self.settingsmenudisplay = SettingsMenuDisplay(screen, pack) | ||||
|         self.logsdisplay = LogsDisplay(screen, pack) | ||||
|         self.messagedisplay = MessageDisplay(screen=screen, pack=None) | ||||
|         self.hbar = HorizontalSplit(screen, pack) | ||||
|         self.vbar = VerticalSplit(screen, pack) | ||||
|         self.displays = [self.statsdisplay, self.mapdisplay, | ||||
|                          self.mainmenudisplay, self.settingsmenudisplay, | ||||
|                          self.logsdisplay] | ||||
|                          self.logsdisplay, self.messagedisplay] | ||||
|         self.update_game_components() | ||||
|  | ||||
|     def handle_display_action(self, action: DisplayActions) -> None: | ||||
| @@ -40,20 +48,35 @@ class DisplayManager: | ||||
|         self.statsdisplay.update_player(self.game.player) | ||||
|         self.settingsmenudisplay.update_menu(self.game.settings_menu) | ||||
|         self.logsdisplay.update_logs(self.game.logs) | ||||
|         self.messagedisplay.update_message(self.game.message) | ||||
|  | ||||
|     def refresh(self) -> None: | ||||
|         if self.game.state == GameMode.PLAY: | ||||
|             # The map pad has already the good size | ||||
|             self.mapdisplay.refresh(0, 0, self.rows * 4 // 5, self.cols, | ||||
|             self.mapdisplay.refresh(0, 0, self.rows * 4 // 5, | ||||
|                                     self.mapdisplay.pack.tile_width | ||||
|                                     * (self.cols * 4 // 5 | ||||
|                                        // self.mapdisplay.pack.tile_width), | ||||
|                                     resize_pad=False) | ||||
|             self.statsdisplay.refresh(self.rows * 4 // 5, 0, | ||||
|                                       self.rows // 10, self.cols) | ||||
|             self.logsdisplay.refresh(self.rows * 9 // 10, 0, | ||||
|                                      self.rows // 10, self.cols) | ||||
|             self.statsdisplay.refresh(0, self.cols * 4 // 5 + 1, | ||||
|                                       self.rows, self.cols // 5 - 1) | ||||
|             self.logsdisplay.refresh(self.rows * 4 // 5 + 1, 0, | ||||
|                                      self.rows // 5 - 1, self.cols * 4 // 5) | ||||
|             self.hbar.refresh(self.rows * 4 // 5, 0, 1, self.cols * 4 // 5) | ||||
|             self.vbar.refresh(0, self.cols * 4 // 5, self.rows, 1) | ||||
|         if self.game.state == GameMode.MAINMENU: | ||||
|             self.mainmenudisplay.refresh(0, 0, self.rows, self.cols) | ||||
|         if self.game.state == GameMode.SETTINGS: | ||||
|             self.settingsmenudisplay.refresh(0, 0, self.rows, self.cols - 1) | ||||
|  | ||||
|         if self.game.message: | ||||
|             height, width = 0, 0 | ||||
|             for line in self.game.message.split("\n"): | ||||
|                 height += 1 | ||||
|                 width = max(width, len(line)) | ||||
|             y, x = (self.rows - height) // 2, (self.cols - width) // 2 | ||||
|             self.messagedisplay.refresh(y, x, height, width) | ||||
|  | ||||
|         self.resize_window() | ||||
|  | ||||
|     def resize_window(self) -> bool: | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| from squirrelbattle.display.display import Display | ||||
| from squirrelbattle.interfaces import Logs | ||||
|  | ||||
| @@ -12,12 +15,11 @@ class LogsDisplay(Display): | ||||
|         self.logs = logs | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         print(type(self.logs.messages), flush=True) | ||||
|         messages = self.logs.messages[-self.height:] | ||||
|         messages = messages[::-1] | ||||
|         self.pad.clear() | ||||
|         self.pad.erase() | ||||
|         for i in range(min(self.height, len(messages))): | ||||
|             self.pad.addstr(self.height - i - 1, self.x, | ||||
|                             messages[i][:self.width]) | ||||
|         self.pad.refresh(0, 0, self.y, self.x, self.y + self.height, | ||||
|                          self.x + self.width) | ||||
|             self.addstr(self.pad, self.height - i - 1, self.x, | ||||
|                         messages[i][:self.width]) | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, | ||||
|                          self.y + self.height - 1, self.x + self.width - 1) | ||||
|   | ||||
| @@ -1,4 +1,6 @@ | ||||
| #!/usr/bin/env python | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| from squirrelbattle.interfaces import Map | ||||
| from .display import Display | ||||
|  | ||||
| @@ -15,11 +17,11 @@ class MapDisplay(Display): | ||||
|     def update_pad(self) -> None: | ||||
|         self.init_pair(1, self.pack.tile_fg_color, self.pack.tile_bg_color) | ||||
|         self.init_pair(2, self.pack.entity_fg_color, self.pack.entity_bg_color) | ||||
|         self.pad.addstr(0, 0, self.map.draw_string(self.pack), | ||||
|                         self.color_pair(1)) | ||||
|         self.addstr(self.pad, 0, 0, self.map.draw_string(self.pack), | ||||
|                     self.color_pair(1)) | ||||
|         for e in self.map.entities: | ||||
|             self.pad.addstr(e.y, self.pack.tile_width * e.x, | ||||
|                             self.pack[e.name.upper()], self.color_pair(2)) | ||||
|             self.addstr(self.pad, e.y, self.pack.tile_width * e.x, | ||||
|                         self.pack[e.name.upper()], self.color_pair(2)) | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         y, x = self.map.currenty, self.pack.tile_width * self.map.currentx | ||||
| @@ -31,9 +33,18 @@ class MapDisplay(Display): | ||||
|         smaxrow = min(smaxrow, self.height - 1) | ||||
|         smaxcol = self.pack.tile_width * self.map.width - \ | ||||
|             (x + deltax) + self.width - 1 | ||||
|  | ||||
|         # Wrap perfectly the map according to the width of the tiles | ||||
|         pmincol = self.pack.tile_width * (pmincol // self.pack.tile_width) | ||||
|         smincol = self.pack.tile_width * (smincol // self.pack.tile_width) | ||||
|         smaxcol = self.pack.tile_width \ | ||||
|             * (smaxcol // self.pack.tile_width + 1) - 1 | ||||
|  | ||||
|         smaxcol = min(smaxcol, self.width - 1) | ||||
|         pminrow = max(0, min(self.map.height, pminrow)) | ||||
|         pmincol = max(0, min(self.pack.tile_width * self.map.width, pmincol)) | ||||
|         self.pad.clear() | ||||
|  | ||||
|         self.pad.erase() | ||||
|         self.update_pad() | ||||
|         self.pad.refresh(pminrow, pmincol, sminrow, smincol, smaxrow, smaxcol) | ||||
|         self.refresh_pad(self.pad, pminrow, pmincol, sminrow, smincol, smaxrow, | ||||
|                          smaxcol) | ||||
|   | ||||
| @@ -1,8 +1,12 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| from typing import List | ||||
|  | ||||
| from squirrelbattle.menus import Menu, MainMenu | ||||
| from .display import Display | ||||
| from .display import Display, Box | ||||
| from ..resources import ResourceManager | ||||
| from ..translations import gettext as _ | ||||
|  | ||||
|  | ||||
| class MenuDisplay(Display): | ||||
| @@ -11,25 +15,23 @@ class MenuDisplay(Display): | ||||
|     """ | ||||
|     position: int | ||||
|  | ||||
|     def __init__(self, *args): | ||||
|         super().__init__(*args) | ||||
|         self.menubox = self.newpad(self.rows, self.cols) | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         super().__init__(*args, **kwargs) | ||||
|         self.menubox = Box(*args, **kwargs) | ||||
|  | ||||
|     def update_menu(self, menu: Menu) -> None: | ||||
|         self.menu = menu | ||||
|         self.trueheight = len(self.values) | ||||
|         self.truewidth = max([len(a) for a in self.values]) | ||||
|  | ||||
|         # Menu values are printed in pad | ||||
|         self.pad = self.newpad(self.trueheight, self.truewidth + 2) | ||||
|         for i in range(self.trueheight): | ||||
|             self.pad.addstr(i, 0, "  " + self.values[i]) | ||||
|             self.addstr(self.pad, i, 0, "  " + self.values[i]) | ||||
|  | ||||
|     def update_pad(self) -> None: | ||||
|         for i in range(self.trueheight): | ||||
|             self.pad.addstr(i, 0, "  " + self.values[i]) | ||||
|             self.addstr(self.pad, i, 0, "  " + self.values[i]) | ||||
|         # set a marker on the selected line | ||||
|         self.pad.addstr(self.menu.position, 0, ">") | ||||
|         self.addstr(self.pad, self.menu.position, 0, ">") | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         cornery = 0 if self.height - 2 >= self.menu.position - 1 \ | ||||
| @@ -37,20 +39,21 @@ class MenuDisplay(Display): | ||||
|             if self.height - 2 >= self.trueheight - self.menu.position else 0 | ||||
|  | ||||
|         # Menu box | ||||
|         self.menubox.addstr(0, 0, "┏" + "━" * (self.width - 2) + "┓") | ||||
|         for i in range(1, self.height - 1): | ||||
|             self.menubox.addstr(i, 0, "┃" + " " * (self.width - 2) + "┃") | ||||
|         self.menubox.addstr(self.height - 1, 0, | ||||
|                             "┗" + "━" * (self.width - 2) + "┛") | ||||
|  | ||||
|         self.menubox.refresh(0, 0, self.y, self.x, | ||||
|                              self.height + self.y, | ||||
|                              self.width + self.x) | ||||
|         self.menubox.refresh(self.y, self.x, self.height, self.width) | ||||
|         self.pad.erase() | ||||
|         self.update_pad() | ||||
|         self.pad.refresh(cornery, 0, self.y + 1, self.x + 2, | ||||
|         self.refresh_pad(self.pad, cornery, 0, self.y + 1, self.x + 2, | ||||
|                          self.height - 2 + self.y, | ||||
|                          self.width - 2 + self.x) | ||||
|  | ||||
|     @property | ||||
|     def truewidth(self) -> int: | ||||
|         return max([len(str(a)) for a in self.values]) | ||||
|  | ||||
|     @property | ||||
|     def trueheight(self) -> int: | ||||
|         return len(self.values) | ||||
|  | ||||
|     @property | ||||
|     def preferred_width(self) -> int: | ||||
|         return self.truewidth + 6 | ||||
| @@ -70,9 +73,10 @@ class SettingsMenuDisplay(MenuDisplay): | ||||
|     """ | ||||
|     @property | ||||
|     def values(self) -> List[str]: | ||||
|         return [a[1][1] + (" : " | ||||
|         return [_(a[1][1]) + (" : " | ||||
|                 + ("?" if self.menu.waiting_for_key | ||||
|                     and a == self.menu.validate() else a[1][0]) | ||||
|                     and a == self.menu.validate() else a[1][0] | ||||
|                    .replace("\n", "\\n")) | ||||
|             if a[1][0] else "") for a in self.menu.values] | ||||
|  | ||||
|  | ||||
| @@ -95,9 +99,11 @@ class MainMenuDisplay(Display): | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         for i in range(len(self.title)): | ||||
|             self.pad.addstr(4 + i, max(self.width // 2 | ||||
|                             - len(self.title[0]) // 2 - 1, 0), self.title[i]) | ||||
|         self.pad.refresh(0, 0, self.y, self.x, self.height, self.width) | ||||
|             self.addstr(self.pad, 4 + i, max(self.width // 2 | ||||
|                         - len(self.title[0]) // 2 - 1, 0), self.title[i]) | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, | ||||
|                          self.height + self.y - 1, | ||||
|                          self.width + self.x - 1) | ||||
|         menuwidth = min(self.menudisplay.preferred_width, self.width) | ||||
|         menuy, menux = len(self.title) + 8, self.width // 2 - menuwidth // 2 - 1 | ||||
|         self.menudisplay.refresh( | ||||
|   | ||||
							
								
								
									
										31
									
								
								squirrelbattle/display/messagedisplay.py
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								squirrelbattle/display/messagedisplay.py
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,31 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
| import curses | ||||
|  | ||||
| from squirrelbattle.display.display import Box, Display | ||||
|  | ||||
|  | ||||
| class MessageDisplay(Display): | ||||
|     """ | ||||
|     Display a message in a popup. | ||||
|     """ | ||||
|  | ||||
|     def __init__(self, *args, **kwargs): | ||||
|         super().__init__(*args, **kwargs) | ||||
|  | ||||
|         self.box = Box(fg_border_color=curses.COLOR_RED, *args, **kwargs) | ||||
|         self.message = "" | ||||
|         self.pad = self.newpad(1, 1) | ||||
|  | ||||
|     def update_message(self, msg: str) -> None: | ||||
|         self.message = msg | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         self.box.refresh(self.y - 1, self.x - 2, | ||||
|                          self.height + 2, self.width + 4) | ||||
|         self.box.display() | ||||
|         self.pad.erase() | ||||
|         self.addstr(self.pad, 0, 0, self.message, curses.A_BOLD) | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, | ||||
|                          self.height + self.y - 1, | ||||
|                          self.width + self.x - 1) | ||||
| @@ -1,9 +1,12 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| import curses | ||||
|  | ||||
| from ..entities.player import Player | ||||
| from ..translations import gettext as _ | ||||
| from .display import Display | ||||
|  | ||||
| from squirrelbattle.entities.player import Player | ||||
|  | ||||
|  | ||||
| class StatsDisplay(Display): | ||||
|     player: Player | ||||
| @@ -17,36 +20,28 @@ class StatsDisplay(Display): | ||||
|         self.player = p | ||||
|  | ||||
|     def update_pad(self) -> None: | ||||
|         string = "" | ||||
|         for _ in range(self.width - 1): | ||||
|             string = string + "-" | ||||
|         self.pad.addstr(0, 0, string) | ||||
|         string2 = "Player -- LVL {}  EXP {}/{}  HP {}/{}"\ | ||||
|         string2 = "Player -- LVL {}\nEXP {}/{}\nHP {}/{}"\ | ||||
|             .format(self.player.level, self.player.current_xp, | ||||
|                     self.player.max_xp, self.player.health, | ||||
|                     self.player.maxhealth) | ||||
|         for _ in range(self.width - len(string2) - 1): | ||||
|             string2 = string2 + " " | ||||
|         self.pad.addstr(1, 0, string2) | ||||
|         string3 = "Stats : STR {}  INT {}  CHR {}  DEX {} CON {}"\ | ||||
|         self.addstr(self.pad, 0, 0, string2) | ||||
|         string3 = "STR {}\nINT {}\nCHR {}\nDEX {}\nCON {}"\ | ||||
|             .format(self.player.strength, | ||||
|                     self.player.intelligence, self.player.charisma, | ||||
|                     self.player.dexterity, self.player.constitution) | ||||
|         for _ in range(self.width - len(string3) - 1): | ||||
|             string3 = string3 + " " | ||||
|         self.pad.addstr(2, 0, string3) | ||||
|         self.addstr(self.pad, 3, 0, string3) | ||||
|  | ||||
|         inventory_str = "Inventaire : " + "".join( | ||||
|         inventory_str = _("Inventory:") + " " + "".join( | ||||
|             self.pack[item.name.upper()] for item in self.player.inventory) | ||||
|         self.pad.addstr(3, 0, inventory_str) | ||||
|         self.addstr(self.pad, 8, 0, inventory_str) | ||||
|  | ||||
|         if self.player.dead: | ||||
|             self.pad.addstr(4, 0, "VOUS ÊTES MORT", | ||||
|                             curses.A_BOLD | curses.A_BLINK | curses.A_STANDOUT | ||||
|                             | self.color_pair(3)) | ||||
|             self.addstr(self.pad, 10, 0, _("YOU ARE DEAD"), | ||||
|                         curses.A_BOLD | curses.A_BLINK | curses.A_STANDOUT | ||||
|                         | self.color_pair(3)) | ||||
|  | ||||
|     def display(self) -> None: | ||||
|         self.pad.clear() | ||||
|         self.pad.erase() | ||||
|         self.update_pad() | ||||
|         self.pad.refresh(0, 0, self.y, self.x, | ||||
|                          4 + self.y, self.width + self.x) | ||||
|         self.refresh_pad(self.pad, 0, 0, self.y, self.x, | ||||
|                          self.y + self.height - 1, self.width + self.x - 1) | ||||
|   | ||||
| @@ -1,3 +1,6 @@ | ||||
| # Copyright (C) 2020 by ÿnérant, eichhornchen, nicomarg, charlse | ||||
| # SPDX-License-Identifier: GPL-3.0-or-later | ||||
|  | ||||
| import curses | ||||
| from typing import Any | ||||
|  | ||||
| @@ -51,7 +54,7 @@ TexturePack.ASCII_PACK = TexturePack( | ||||
|     HEART='❤', | ||||
|     BOMB='o', | ||||
|     RABBIT='Y', | ||||
|     BEAVER='_', | ||||
|     TIGER='n', | ||||
|     TEDDY_BEAR='8', | ||||
|     MERCHANT='M', | ||||
|     SUNFLOWER='I', | ||||
| @@ -67,12 +70,12 @@ TexturePack.SQUIRREL_PACK = TexturePack( | ||||
|     EMPTY='  ', | ||||
|     WALL='🧱', | ||||
|     FLOOR='██', | ||||
|     PLAYER='🐿️️', | ||||
|     PLAYER='🐿️ ️', | ||||
|     HEDGEHOG='🦔', | ||||
|     HEART='💜', | ||||
|     BOMB='💣', | ||||
|     RABBIT='🐇', | ||||
|     BEAVER='🦫', | ||||
|     TIGER='🐅', | ||||
|     TEDDY_BEAR='🧸', | ||||
|     MERCHANT='🦜', | ||||
|     SUNFLOWER='🌻', | ||||
|   | ||||
		Reference in New Issue
	
	Block a user