X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=naja%2Fwidgets%2Ftile.py;h=01efdac4ff8a16a5f029864254d72253a760d1eb;hb=23bc655a89f4ac16e2b17a5f359192d1d9268648;hp=66574b98b1c68490d3e97fec87e98ae72394ea23;hpb=e14cc43236de5407e77ffd5cfa39d98fbfca8693;p=naja.git diff --git a/naja/widgets/tile.py b/naja/widgets/tile.py index 66574b9..01efdac 100644 --- a/naja/widgets/tile.py +++ b/naja/widgets/tile.py @@ -29,8 +29,7 @@ class TileWidget(Widget): def prepare(self): # Draw background x, y = abs(self.board_pos[0] - 2), abs(self.board_pos[1] - 2) - if (x == 1 and y in [0, 1]) or (y == 1 and x in [0, 1]): - # Inner ring + if (x + y) % 2 == 0: bg = resources.get_image('board/tile_2.png', transforms=(EIGHT_BIT,)) else: @@ -40,6 +39,7 @@ class TileWidget(Widget): self.surface.blit(bg, (0, 0)) # Look up the required bits on the board location card = self.state.board_locations[self.board_pos] + player_pos = self.state.player.position bits = [] for action in card.actions: if action.required_bits: @@ -50,9 +50,20 @@ class TileWidget(Widget): bits.sort(key=lambda x: len(x)) y_offset = TILE_SIZE[1] - LOCK_HEIGHT * len(bits) for pattern in bits: - img = resources.get_image(BIT_MAP[pattern], + if self.board_pos != player_pos: + img_name = BIT_MAP[pattern] + x_offset = 0 + else: + img_name = BIT_MAP[pattern].replace('.png', '_small.png') + x_offset = 4 + if y_offset >= TILE_SIZE[1] // 2: + # FIXME: Hack'ish + # Bump the lock down by some hand-tuned factor + # to not overlap with the robot + y_offset += LOCK_HEIGHT // 2 - 4 + img = resources.get_image(img_name, transforms=(EIGHT_BIT,)) - self.surface.blit(img, (5, y_offset)) + self.surface.blit(img, (x_offset, y_offset)) y_offset += LOCK_HEIGHT def draw(self, surface):