X-Git-Url: https://git.ctpug.org.za/?a=blobdiff_plain;f=tabakrolletjie%2Fenemies.py;h=eef2596e5300455ea7437d29642b27b9bdaabe02;hb=a2c09130986d18095773c96b9dc797f3b3eb542d;hp=7ed6cf9f7355b63a9edb013efb9ecc19266e35e9;hpb=b3a98c5532a9aef2c48f2bc894ada824b2456675;p=tabakrolletjie.git diff --git a/tabakrolletjie/enemies.py b/tabakrolletjie/enemies.py index 7ed6cf9..eef2596 100644 --- a/tabakrolletjie/enemies.py +++ b/tabakrolletjie/enemies.py @@ -8,15 +8,17 @@ import pygame.draw import pygame.surface 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 +33,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 +51,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,22 +99,34 @@ 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): + def damage(self, light, space, moulds): """Take damage for light, adjusted for resistances.""" - self._health -= 3 + self._health -= light.base_damage() if self._health <= 0 and self._age <= 120: # We die of damage space.remove(self, self._shape) @@ -115,10 +138,10 @@ class Mould(pymunk.Body): class Boyd(object): def __init__(self, gamestate, space): - seed = Mould(gamestate, space, (350, 370)) + seed = Mould(gamestate, space, (275, 300)) 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 +150,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 @@ -139,7 +166,7 @@ class Boyd(object): lit_by = lights.light_query(mould._shape) for light in lit_by: # Todo: extract colour and intensity from light - if mould.damage(None, None, space, self._moulds): + if mould.damage(light, space, self._moulds): redraw = True break # we only die once if redraw: @@ -147,4 +174,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)