From 98d91824cacec97c581ae0a4f1efd9fa3faa18ab Mon Sep 17 00:00:00 2001 From: Viljami Ilola <+@hix.fi> Date: Sat, 23 Mar 2024 22:19:00 +0200 Subject: player through SingleGroup --- src/sliceitoff/field/field.py | 1 - src/sliceitoff/game/gameplay.py | 19 ++++++++--- src/sliceitoff/game/level.py | 19 ++++++++--- src/sliceitoff/game/show.py | 2 +- src/sliceitoff/player/player.py | 70 +++++++++++++---------------------------- src/sliceitoff/status/status.py | 26 +++++++-------- src/sliceitoff/text/text.py | 8 ++--- 7 files changed, 69 insertions(+), 76 deletions(-) (limited to 'src/sliceitoff') diff --git a/src/sliceitoff/field/field.py b/src/sliceitoff/field/field.py index 9e04b4f..4fb4eff 100644 --- a/src/sliceitoff/field/field.py +++ b/src/sliceitoff/field/field.py @@ -2,7 +2,6 @@ import os import pygame from display import Scaling, INTERNAL_WIDTH, INTERNAL_HEIGHT - from stats import Stats DEBUG = os.getenv("DEBUG") diff --git a/src/sliceitoff/game/gameplay.py b/src/sliceitoff/game/gameplay.py index e691b84..12daeaf 100644 --- a/src/sliceitoff/game/gameplay.py +++ b/src/sliceitoff/game/gameplay.py @@ -17,7 +17,18 @@ class Gameplay: self.enemies = enemies def fire(self): - if self.player.fire_lazer(): + hitbox = self.field.slice( + self.player.position, + self.player.direction, + 4_500) + hit = False + if hitbox is not None: + for enemy in self.enemies.sprites(): + if hitbox.colliderect(enemy.rect): + hit = True + break + + if hit: if Stats.lose_life(): return True self.field.kill_if_not_colliding(self.enemies.sprites()) @@ -33,14 +44,14 @@ class Gameplay: for event in pygame.event.get(): match event.type: case pygame.MOUSEMOTION: - self.player.set_position(pygame.mouse.get_pos()) + self.player.update(pos = pygame.mouse.get_pos()) case pygame.MOUSEBUTTONDOWN: - self.player.set_position(pygame.mouse.get_pos()) + self.player.update(pos = pygame.mouse.get_pos()) if event.button == 1: if self.fire(): return True if event.button == 3: - self.player.set_direction() + self.player.update(direction = True) case pygame.KEYDOWN: match event.key: case pygame.K_ESCAPE | pygame.K_q: diff --git a/src/sliceitoff/game/level.py b/src/sliceitoff/game/level.py index 7c58b86..25c34b9 100644 --- a/src/sliceitoff/game/level.py +++ b/src/sliceitoff/game/level.py @@ -1,3 +1,5 @@ +import pygame + from display import Display from status import Status from player import Player @@ -13,9 +15,13 @@ class Level: self.display = display self.status = Status() self.field = Field() - self.enemies = Enemies(field = self.field) - self.player = Player(field = self.field, enemies = self.enemies) - self.gameplay = Gameplay(player = self.player, status = self.status, field = self.field, enemies = self.enemies) + self.enemies = Enemies() + self.player = Player() + self.gameplay = Gameplay( + player = self.player, + status = self.status, + field = self.field, + enemies = self.enemies) self.obj_classes = ( self.status, self.field, @@ -31,10 +37,13 @@ class Level: Stats.update_bonus(dt) self.display.update( ( - self.status.sprites, + self.status, self.field, self.enemies, - self.player.sprites) ) + pygame.sprite.GroupSingle( + sprite = self.player.get_top_sprite()))) + + if self.gameplay.step(): return False diff --git a/src/sliceitoff/game/show.py b/src/sliceitoff/game/show.py index f81c211..c3fe436 100644 --- a/src/sliceitoff/game/show.py +++ b/src/sliceitoff/game/show.py @@ -5,7 +5,7 @@ class Show: """ To show some sprites and quit on any key """ def __init__(self, sprites = []): self.sprites = sprites - self.fadeout = 500 + self.fadeout = 1_000 self.timeout = 5_000 def step(self, dt): diff --git a/src/sliceitoff/player/player.py b/src/sliceitoff/player/player.py index d36691c..de49083 100644 --- a/src/sliceitoff/player/player.py +++ b/src/sliceitoff/player/player.py @@ -7,58 +7,32 @@ from images import Images DEBUG = os.getenv("DEBUG") class PlayerSprite(pygame.sprite.Sprite): - def __init__(self, image, pos): + def __init__(self, image): super().__init__() self.image = image - x, y = self.image.get_size() - x = pos[0] - x // 2 - y = pos[1] - y // 2 - self.rect = self.image.get_rect().move(x,y) + self.rect = self.image.get_rect() + + def update(self, pos = None): + if pos: + w, h = self.image.get_size() + self.rect = self.image.get_rect().move(pos[0]-w//2,pos[1]-h//2) -class Player(): - def __init__(self, field = None, enemies = None): - self.enemies = enemies - self.position = (200_000, 140_000) - self.direction = False +class Player(pygame.sprite.LayeredUpdates): + def __init__(self): + super().__init__() + self.position = (0,0) + self.direction = True self.lazer = False - self.sprites = pygame.sprite.Group() - self.updated = True - self.field = field - - def __update_sprites(self): - self.sprites.empty() image = Images.surfaces['player_00'] - if self.direction: - image = pygame.transform.rotate(image, 90) - self.sprites.add(PlayerSprite( - image, - Scaling.scale_to_display(self.position) )) - if not self.lazer: - self.updated = False - - def set_position(self, pos): - if not self.lazer: - self.position = Scaling.scale_to_internal(pos) - self.updated = True - - def update(self, dt): - """ Update sprites basis of dt. dt = milliseconds from last update """ - if self.updated: - self.__update_sprites() - - def fire_lazer(self): - if DEBUG: - print("PLAYER: fire lazer") - hitbox = self.field.slice(self.position, self.direction, 4_500) - hit = False - if hitbox is not None: - for enemy in self.enemies.sprites(): - if hitbox.colliderect(enemy.rect): - hit = True - break - return hit + self.add(PlayerSprite(image), layer = 0) + image = pygame.transform.rotate(image, 90) + self.add(PlayerSprite(image), layer = 1) - def set_direction(self): + def update(self, pos = None, direction = False, dt = 0): if not self.lazer: - self.direction = not self.direction - self.updated = True + if direction: + self.direction = not self.direction + self.switch_layer(0,1) + if pos: + super().update(pos = pos) + self.position = Scaling.scale_to_internal(pos) diff --git a/src/sliceitoff/status/status.py b/src/sliceitoff/status/status.py index a337a5b..cacc84a 100644 --- a/src/sliceitoff/status/status.py +++ b/src/sliceitoff/status/status.py @@ -1,18 +1,16 @@ -import os import pygame -from display import Scaling -from images import Images, Fonts from stats import Stats from text import TextPage -class Status(): +class Status(pygame.sprite.Group): def __init__(self): - self.sprites = pygame.sprite.Group() + super().__init__() + self.old_srt = None - def update(self, dt): - """ Update sprites basis of dt. dt = milliseconds from last update """ - + def update(self, **kwargs): + """ Rebuilds statusline if needed """ + super().update(**kwargs) score_str = ( "\x12{:1d} \x03{:1d} \x0e{:02d} \xfe{:02d} " "\x0f{:08d}").format( @@ -21,8 +19,10 @@ class Status(): Stats.bonus // 1000, 99 if Stats.percent == 100 else int(Stats.percent), Stats.score) - self.sprites = TextPage( - score_str, - pos = (0, 220_000), - size = (12_000, 0), - font = 'lcd') + if self.old_srt != score_str: + self.empty() + self.add( TextPage( + score_str, + pos = (0, 220_000), + size = (12_000, 0), + font = 'lcd') ) diff --git a/src/sliceitoff/text/text.py b/src/sliceitoff/text/text.py index e8ccb57..9bb7c9a 100644 --- a/src/sliceitoff/text/text.py +++ b/src/sliceitoff/text/text.py @@ -15,16 +15,16 @@ class LetterSprite(pygame.sprite.Sprite): Scaling.factor * (1_000 - randrange(2_000)), Scaling.factor * (1_000 - randrange(2_000))) - def update(self, explode=0): + def update(self, explode = 0, **kwargs): if explode: self.rect = pygame.Rect( self.rect.x + self.direction[0] * explode, self.rect.y + self.direction[1] * explode, self.rect.w, self.rect.h) - self.direction = ( - self.direction[0] * 0.8, - self.direction[1] * 0.8 + 1) + self.direction = ( + self.direction[0] * 1, + self.direction[1] * 1 + 0.5) class TextPage(pygame.sprite.Group): -- cgit v1.2.3