From 5fdeabed6982fedc10c452ea96e25677b48ae5cc Mon Sep 17 00:00:00 2001 From: PAlexanderFranklin Date: Wed, 17 May 2023 02:06:36 -0700 Subject: [PATCH] Allow concurrent keypresses --- arctic-masher.py | 68 +++++++++++++++++++++++++----------------------- 1 file changed, 36 insertions(+), 32 deletions(-) diff --git a/arctic-masher.py b/arctic-masher.py index fb8c605..b577b4c 100644 --- a/arctic-masher.py +++ b/arctic-masher.py @@ -23,8 +23,7 @@ class Player: self.x = x self.y = y self.color = color - self.keys = keys - self.commands = { + commands = { "n": lambda: self.move(0,-1), "ne": lambda: self.move(1,-1), "e": lambda: self.move(1,0), @@ -34,53 +33,58 @@ class Player: "w": lambda: self.move(-1,0), "nw": lambda: self.move(-1,-1), } + self.commands = [] + for key in keys: + self.commands.append((key[0], commands[key[1]])) self.sprite = pygame.Rect((tile*x)+2,(tile*y)+2,tile-2,tile-2) + def useKeys(self, keys): + try: + for command in self.commands: + if keys[command[0]]: + command[1]() + except: + pass + def move(self, x, y): self.x += x self.y += y players = [] -players.append(Player(25, 20, red, { - pygame.K_w: "n", - pygame.K_e: "ne", - pygame.K_d: "e", - pygame.K_c: "se", - pygame.K_x: "s", - pygame.K_z: "sw", - pygame.K_a: "w", - pygame.K_q: "nw" -})) -players.append(Player(25, 20, green, { - pygame.K_KP_8: "n", - pygame.K_KP_9: "ne", - pygame.K_KP_6: "e", - pygame.K_KP_3: "se", - pygame.K_KP_2: "s", - pygame.K_KP_1: "sw", - pygame.K_KP_4: "w", - pygame.K_KP_7: "nw" -})) +players.append(Player(25, 20, red, [ + (pygame.K_w, "n"), + (pygame.K_e, "ne"), + (pygame.K_d, "e"), + (pygame.K_c, "se"), + (pygame.K_x, "s"), + (pygame.K_z, "sw"), + (pygame.K_a, "w"), + (pygame.K_q, "nw"), +])) +players.append(Player(25, 20, green, [ + (pygame.K_KP_8, "n"), + (pygame.K_KP_9, "ne"), + (pygame.K_KP_6, "e"), + (pygame.K_KP_3, "se"), + (pygame.K_KP_2, "s"), + (pygame.K_KP_1, "sw"), + (pygame.K_KP_4, "w"), + (pygame.K_KP_7, "nw"), +])) game_font = pygame.font.Font("freesansbold.ttf",32) -pygame.key.set_repeat(300, 40) - - while True: for event in pygame.event.get(): if event.type == pygame.QUIT: pygame.quit() sys.exit() - if event.type == pygame.KEYDOWN: - for player in players: - try: - player.commands[player.keys[event.key]]() - except: - pass - keys = pygame.key.get_pressed() + + for player in players: + player.useKeys(keys) + # Rendering screen.fill(bg_color) for player in players: