X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=tabakrolletjie%2Fenemies.py;h=140edf7964054ddd7ec3bd6117a9681a6c7f3e15;hb=19b114e401d5df983d693d6402c435975d53e9ce;hp=7ed6cf9f7355b63a9edb013efb9ecc19266e35e9;hpb=b3a98c5532a9aef2c48f2bc894ada824b2456675;p=tabakrolletjie.git diff --git a/tabakrolletjie/enemies.py b/tabakrolletjie/enemies.py index 7ed6cf9..140edf7 100644 --- a/tabakrolletjie/enemies.py +++ b/tabakrolletjie/enemies.py @@ -12,6 +12,7 @@ import pygame.locals as pgl from .constants import SCREEN_SIZE, MOULD_CATEGORY, OBSTACLE_CATEGORY from .loader import loader +from .sound import sound MOULD_FILTER = pymunk.ShapeFilter( mask=MOULD_CATEGORY | OBSTACLE_CATEGORY, @@ -31,6 +32,8 @@ class Mould(pymunk.Body): self._age = 0 self._img = None self._health = 500 + self.has_eyeball = False + self._eyeball = None def pygame_pos(self, surface): """Convert to pygame coordinates and offset position so @@ -47,6 +50,11 @@ class Mould(pymunk.Body): self._img = loader.load_image(size, name) return self._img + def get_eyeball(self): + if not self._eyeball: + self._eyeball = loader.load_image("32", "eyeball.png") + return self._eyeball + def tick(self, gamestate, space, moulds): """Grow and / or Die""" @@ -88,12 +96,18 @@ class Mould(pymunk.Body): child._health = self._health moulds.append(child) refresh = True + if random.randint(0, 10) < 2: + sound.play_sound("mouth_pop_2a.ogg") if self._age in (10, 20): - # Segment grows in size + # We grow in size refresh = True self._img = None # invalidate cached image + if self._age > 20 and random.randint(0, 100) < 1: + # Maybe we grow an eyeball + self.has_eyeball = True + if self._age > 120: # We die of old age space.remove(self, self._shape) @@ -127,6 +141,9 @@ class Boyd(object): self._image.blit(m.get_image(), m.pygame_pos(self._image), None, 0) + for m in self._moulds: + if m.has_eyeball: + self._image.blit(m.get_eyeball(), m.pygame_pos(self._image), None, 0) def tick(self, gamestate, space, lights): redraw = False