X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=naja%2Fwidgets%2Frobot.py;h=09fd099f0a258d7d5136d590318512b4f7ca72f9;hb=ea9ef7135b38cb5256c0700f5a0ab023d6378831;hp=2653f815aef860b7bc7f06e40aa82d4ab76f457b;hpb=cd0b75b50d9db985634a4cf0b539fd327c11e325;p=naja.git diff --git a/naja/widgets/robot.py b/naja/widgets/robot.py index 2653f81..09fd099 100644 --- a/naja/widgets/robot.py +++ b/naja/widgets/robot.py @@ -1,18 +1,16 @@ """Widget to draw the player on the screen""" -import pygame.locals as pgl - -from naja.constants import PLAYER_SIZE, BIT_SIZE, TILE_SIZE, BITS, ACT -from naja.events import InvalidateTheWorld +from naja.constants import (PLAYER_SIZE, BIT_SIZE, TILE_SIZE, BITS) from naja.resources import resources from naja.resources.mutators import EIGHT_BIT from naja.widgets.base import Widget IMG_MAP = { - BITS.CYAN: 'board/robot_cyan.png', - BITS.YELLOW: 'board/robot_yellow.png', - BITS.MAGENTA: 'board/robot_magenta.png', - } + BITS.MSB: 'board/robot_msb.png', + BITS.RED: 'board/robot_red.png', + BITS.GREEN: 'board/robot_green.png', + BITS.BLUE: 'board/robot_blue.png', +} class RobotWidget(Widget): @@ -28,7 +26,7 @@ class RobotWidget(Widget): self.pos = (self.state.player.position[0] * TILE_SIZE[0], self.state.player.position[1] * TILE_SIZE[1] + BIT_SIZE[1]) self.surface = resources.get_image('board/robot.png', - transforms=(EIGHT_BIT,)) + transforms=(EIGHT_BIT,)).copy() for bit, img_name in IMG_MAP.iteritems(): if self.state.player.bits.check_bit(bit): bit_img = resources.get_image(img_name, @@ -37,33 +35,3 @@ class RobotWidget(Widget): def draw(self, surface): surface.blit(self.surface, self.rect) - - def handle_event(self, ev): - if self.state.gameboard.player_mode == ACT: - return super(RobotWidget, self).handle_event(ev) - if ev.type == pgl.KEYDOWN: - if ev.key in (pgl.K_UP, pgl.K_w, pgl.K_COMMA): - if self.state.player.move(BITS.NORTH): - self.state.gameboard.change_mode() - InvalidateTheWorld.post() - return True - if ev.key in (pgl.K_DOWN, pgl.K_s, pgl.K_o): - if self.state.player.move(BITS.SOUTH): - self.state.gameboard.change_mode() - InvalidateTheWorld.post() - return True - if ev.key in (pgl.K_LEFT, pgl.K_a): - if self.state.player.move(BITS.WEST): - self.state.gameboard.change_mode() - InvalidateTheWorld.post() - return True - if ev.key in (pgl.K_RIGHT, pgl.K_d, pgl.K_e): - if self.state.player.move(BITS.EAST): - self.state.gameboard.change_mode() - InvalidateTheWorld.post() - return True - if ev.key in (pgl.K_SPACE,): - self.state.gameboard.change_mode() - InvalidateTheWorld.post() - return True - return super(RobotWidget, self).handle_event(ev)