X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=tabakrolletjie%2Fenemies.py;h=65bae00ea4af6b79e5eeba8f76984f8435b8eb58;hb=3f3f85d9bb45ae64540f3a725915466a2f187a9e;hp=7ed6cf9f7355b63a9edb013efb9ecc19266e35e9;hpb=245421aeaa0d5af6b31471fa9b9fc3e4b7453b6e;p=tabakrolletjie.git diff --git a/tabakrolletjie/enemies.py b/tabakrolletjie/enemies.py index 7ed6cf9..65bae00 100644 --- a/tabakrolletjie/enemies.py +++ b/tabakrolletjie/enemies.py @@ -10,13 +10,17 @@ import pygame.display import pygame.locals as pgl -from .constants import SCREEN_SIZE, MOULD_CATEGORY, OBSTACLE_CATEGORY +from .constants import (SCREEN_SIZE, MOULD_CATEGORY, OBSTACLE_CATEGORY, + TURNIP_CATEGORY) from .loader import loader +from .sound import sound MOULD_FILTER = pymunk.ShapeFilter( mask=MOULD_CATEGORY | OBSTACLE_CATEGORY, categories=MOULD_CATEGORY) +EAT_TURNIP_FILTER = pymunk.ShapeFilter(mask=TURNIP_CATEGORY) + class Mould(pymunk.Body): """A segment of Boyd""" @@ -31,6 +35,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 +53,13 @@ class Mould(pymunk.Body): self._img = loader.load_image(size, name) return self._img + def get_eyeball(self): + if not self._eyeball: + name = random.choice( + ('eyeballA.png', 'eyeballB.png', 'eyeballC.png')) + self._eyeball = loader.load_image("32", name) + return self._eyeball + def tick(self, gamestate, space, moulds): """Grow and / or Die""" @@ -88,17 +101,29 @@ 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 + self._img = None # invalidate cached image + + if self._age > 20 and random.randint(0, 500) < 1: + # Maybe we grow an eyeball + self.has_eyeball = True if self._age > 120: # We die of old age space.remove(self, self._shape) moulds.remove(self) refresh = True + else: + # Check for turnips we can eat + # Note that we can only eat a tick after we spawn + query = space.point_query(self.position, 16, EAT_TURNIP_FILTER) + if query: + query[0].shape.body.turnip.eaten = True return refresh def damage(self, light_color, intensity, space, moulds): @@ -118,7 +143,7 @@ class Boyd(object): seed = Mould(gamestate, space, (350, 370)) self._moulds = [seed] self._image = pygame.surface.Surface(SCREEN_SIZE) - self._image.convert_alpha(pygame.display.get_surface()) + self._image = self._image.convert_alpha(pygame.display.get_surface()) self._draw_moulds() def _draw_moulds(self): @@ -127,6 +152,10 @@ 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 @@ -147,4 +176,4 @@ class Boyd(object): def render(self, surface): """Draw ourselves""" - surface.blit(self._image, (0, 0), None, pgl.BLEND_RGBA_ADD) + surface.blit(self._image, (0, 0), None, 0)