X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=tabakrolletjie%2Fenemies.py;h=140edf7964054ddd7ec3bd6117a9681a6c7f3e15;hb=19b114e401d5df983d693d6402c435975d53e9ce;hp=0fe1619fc175f63b970deb882e8d1ed5a15e6e6a;hpb=e9598e08943dd68a66f0a0f2f5eb2a8757051a50;p=tabakrolletjie.git diff --git a/tabakrolletjie/enemies.py b/tabakrolletjie/enemies.py index 0fe1619..140edf7 100644 --- a/tabakrolletjie/enemies.py +++ b/tabakrolletjie/enemies.py @@ -32,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 @@ -48,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""" @@ -93,10 +100,14 @@ class Mould(pymunk.Body): 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) @@ -130,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