diff options
author | Viljami Ilola <+@hix.fi> | 2024-03-30 16:08:03 +0200 |
---|---|---|
committer | Viljami Ilola <+@hix.fi> | 2024-03-30 16:08:03 +0200 |
commit | 1def24341ce4f3ab1c1de4a9dde27bf0b5fab179 (patch) | |
tree | e846c7ea2f4306146f33381c289350c2edf6f093 /src/sliceitoff/enemies/enemies.py | |
parent | 5874005e58d0f26b4393845b3b18160658ece160 (diff) |
bounching balls and more refactoring
Diffstat (limited to 'src/sliceitoff/enemies/enemies.py')
-rw-r--r-- | src/sliceitoff/enemies/enemies.py | 56 |
1 files changed, 13 insertions, 43 deletions
diff --git a/src/sliceitoff/enemies/enemies.py b/src/sliceitoff/enemies/enemies.py index 41a19fa..c52059f 100644 --- a/src/sliceitoff/enemies/enemies.py +++ b/src/sliceitoff/enemies/enemies.py @@ -1,52 +1,22 @@ -import pygame from random import randrange +import pygame -from display import Scaling -from text import get_letter_surface - -BALL_SPAWN_AREA = (0, 0, 300_000, 200_000) -BALL_MOVEMENT = (100, 100) - -class EnemyBall(pygame.sprite.Sprite): - def __init__(self): - super().__init__() - self.position = ( - randrange(BALL_SPAWN_AREA[0], BALL_SPAWN_AREA[2]), - randrange(BALL_SPAWN_AREA[1], BALL_SPAWN_AREA[3])) - self.movement = ( - randrange(0, BALL_MOVEMENT[0]*2) - BALL_MOVEMENT[0], - randrange(0, BALL_MOVEMENT[1]*2) - BALL_MOVEMENT[1]) - self.image = get_letter_surface( - ('8x8', 8_000, 0), - randrange(1,3)).subsurface( - (0,0,8_000*Scaling.factor,8_000*Scaling.factor)) - self.update() - self.rect = None - - def update(self, dt = 0, wall_hit = None, **kwargs): - if wall_hit: - if self.rect.x < wall_hit.x: - self.movement = (abs(self.movement[0]), self.movement[1]) - if self.rect.y < wall_hit.y: - self.movement = (self.movement[0], abs(self.movement[1])) - if self.rect.x + self.rect.w >= wall_hit.x + wall_hit.w: - self.movement = (-abs(self.movement[0]), self.movement[1]) - if self.rect.y + self.rect.h >= wall_hit.y + wall_hit.h: - self.movement = (self.movement[0], -abs(self.movement[1])) - return - if dt: - self.position = ( - self.position[0] + self.movement[0] * dt, - self.position[1] + self.movement[1] * dt) - self.rect = pygame.Rect( - Scaling.scale_to_display(self.position), - self.image.get_size()) +from .ball import EnemyBall +from .bouncher import EnemyBouncher class Enemies(pygame.sprite.Group): def __init__(self, field = None, count = 0): super().__init__() - for _ in range(count): - self.add(EnemyBall()) + while count: + match randrange(0,4): + case 0|1|2: + if count >= 1: + self.add(EnemyBall()) + count -= 1 + case 3: + if count >= 2: + self.add(EnemyBouncher()) + count -= 2 self.field = field def update(self, field_rects = [], **kwargs): |