summaryrefslogtreecommitdiff
path: root/src/sliceitoff/status
diff options
context:
space:
mode:
Diffstat (limited to 'src/sliceitoff/status')
-rw-r--r--src/sliceitoff/status/status.py40
1 files changed, 28 insertions, 12 deletions
diff --git a/src/sliceitoff/status/status.py b/src/sliceitoff/status/status.py
index d99c7d5..a63a7db 100644
--- a/src/sliceitoff/status/status.py
+++ b/src/sliceitoff/status/status.py
@@ -2,20 +2,31 @@ import os
import pygame
from display import Scaling
-from images import Images
+from images import Images, Fonts
class LetterSprite(pygame.sprite.Sprite):
def __init__(self, image, pos):
super().__init__()
self.image = image
self.rect = self.image.get_rect().move(pos)
-
+
+class TextGroup(pygame.sprite.Group):
+ def __init__(self, text, pos, size = 8_000, spacing = None, font = 'lcd'):
+ super().__init__()
+ if spacing == None:
+ spacing = size
+ for i in range(len(text)):
+ image = pygame.transform.scale_by(
+ Fonts.fonts[font].get(text[i]),
+ size/8 * Scaling.factor)
+ image_pos = Scaling.scale_to_display( (pos[0]+i*spacing, pos[1]) )
+ self.add(LetterSprite(image, image_pos))
class Status():
def __init__(self, level = 1):
self.score = 0
self.bonus = 20_000
- self.health = 3
+ self.lives = 3
self.level = level
self.sprites = pygame.sprite.Group()
@@ -24,12 +35,17 @@ class Status():
self.bonus = max(0, self.bonus - dt)
- self.sprites.empty()
- y = 280_000
- #score_str="{:010d}".format(self.score)
- score_str="{:010d}".format(self.bonus)
- for letter, x in zip(score_str, range(300_000,400_000,10_000)):
- self.sprites.add(LetterSprite(
- Images.surfaces[f"letter_{letter}"],
- Scaling.scale_to_display((x,y)) ))
- self.updated = False
+ score_str="LEVEL{:02d}LIVES{:02d}{:010d}".format(self.level, self.lives, self.bonus)
+ self.sprites = TextGroup(
+ score_str,
+ (0, 280_000),
+ size = 10_000)
+
+ def lose_life(self):
+ """ Lose 1 life and return true if no lives left """
+ self.lives -= 1
+ return not self.lives
+
+ def gain_life(self):
+ """ Gain 1 life """
+ self.lives += 1