0.2.2 #14

Merged
Lerking merged 2 commits from 0.2.2 into main 2025-04-15 22:35:27 +02:00
2 changed files with 31 additions and 4 deletions

View File

@@ -26,6 +26,9 @@ class Colors(Enum):
Blue = (0, 0, 255)
Cyan = (0, 255, 255)
Magenta = (255, 0, 255)
WHITE = (255, 255, 255)
RED = (255, 0, 0)
# add others as needed
class GhostColor(Enum):
BLINKY = (255, 0, 0)

View File

@@ -1,18 +1,42 @@
import pygame
import os
from enums import Color
class Scoreboard:
def __init__(self, font_size=24):
def __init__(self, font_size=24, highscore_file="highscore.txt"):
self.score = 0
self.highscore_file = highscore_file
self.highscore = self.load_highscore()
self.font = pygame.font.Font(None, font_size)
self.color = (255, 255, 255)
self.position = (10, 10)
self.color = Color.WHITE.value
self.score_pos = (10, 10)
self.highscore_pos = (10, 40)
def load_highscore(self):
if os.path.exists(self.highscore_file):
with open(self.highscore_file, 'r') as file:
try:
return int(file.read())
except ValueError:
return 0
return 0
def save_highscore(self):
with open(self.highscore_file, 'w') as file:
file.write(str(self.highscore))
def add_points(self, points):
self.score += points
if self.score > self.highscore:
self.highscore = self.score
self.save_highscore()
def reset(self):
self.score = 0
def draw(self, screen):
score_text = self.font.render(f"Score: {self.score}", True, self.color)
screen.blit(score_text, self.position)
highscore_text = self.font.render(f"High Score: {self.highscore}", True, self.color)
screen.blit(score_text, self.score_pos)
screen.blit(highscore_text, self.highscore_pos)