summaryrefslogtreecommitdiff
path: root/src/sliceitoff
diff options
context:
space:
mode:
Diffstat (limited to 'src/sliceitoff')
-rw-r--r--src/sliceitoff/game/gameplay.py7
-rw-r--r--src/sliceitoff/game/initials.py3
-rw-r--r--src/sliceitoff/game/level.py10
-rw-r--r--src/sliceitoff/game/show.py4
-rw-r--r--src/sliceitoff/hiscores/__init__.py1
-rw-r--r--src/sliceitoff/hiscores/hiscores.py23
-rw-r--r--src/sliceitoff/player/__init__.py3
-rw-r--r--src/sliceitoff/player/player.py23
8 files changed, 42 insertions, 32 deletions
diff --git a/src/sliceitoff/game/gameplay.py b/src/sliceitoff/game/gameplay.py
index ef708c4..5a14767 100644
--- a/src/sliceitoff/game/gameplay.py
+++ b/src/sliceitoff/game/gameplay.py
@@ -7,15 +7,13 @@ class Gameplay:
self,
player = None,
field = None,
- status = None,
enemies = None,
stats = None):
- self.status = status
self.player = player
self.field = field
self.enemies = enemies
self.stats = stats
-
+
def fire(self):
""" Lazer is fired. Actions to be taken. """
zap_sprite = self.field.slice(
@@ -33,9 +31,10 @@ class Gameplay:
return self.stats.percent < 20
def quit(self):
+ """ Lose lives so no leveling up """
self.stats.lives = 0
return True
-
+
def step(self):
""" Processes events for the step (frame) """
for event in pygame.event.get():
diff --git a/src/sliceitoff/game/initials.py b/src/sliceitoff/game/initials.py
index 49db3d6..7811afa 100644
--- a/src/sliceitoff/game/initials.py
+++ b/src/sliceitoff/game/initials.py
@@ -14,8 +14,9 @@ class Initials(pygame.sprite.Group):
self.explode = False
self.active = True
self.fadeout = 1_000
-
+
def update(self, dt = 0, **kwargs):
+ """ Does it all. Reads keyboard and updates screen """
if not self.active:
return
diff --git a/src/sliceitoff/game/level.py b/src/sliceitoff/game/level.py
index 26df345..0742213 100644
--- a/src/sliceitoff/game/level.py
+++ b/src/sliceitoff/game/level.py
@@ -20,7 +20,6 @@ class Level:
self.field = Field(stats = self.stats)
self.enemies = Enemies(count = self.stats.enemies)
self.player = Player()
- self.player_single = pygame.sprite.Group()
self.level_info = Show(level_screen(stats.level))
self.ended = False
@@ -28,7 +27,6 @@ class Level:
self.gameplay = Gameplay(
player = self.player,
- status = self.status,
field = self.field,
enemies = self.enemies,
stats = self.stats)
@@ -36,7 +34,8 @@ class Level:
self.status,
self.field,
self.enemies,
- self.level_info]
+ self.level_info,
+ self.player]
def step(self, dt):
self.status.update(dt = dt)
@@ -53,11 +52,8 @@ class Level:
return False
else:
- self.player_single = pygame.sprite.GroupSingle(
- sprite = self.player.get_top_sprite())
self.stats.update_bonus(dt)
if self.gameplay.step():
- self.player_single = pygame.sprite.Group()
self.ended = True
if self.stats.lives:
self.endscreen = Show(levelup_screen(self.stats))
@@ -65,6 +61,6 @@ class Level:
self.endscreen = Show(gameover_screen())
self.obj_classes.append(self.endscreen)
- self.display.update(self.obj_classes+[self.player_single])
+ self.display.update(self.obj_classes)
return True
diff --git a/src/sliceitoff/game/show.py b/src/sliceitoff/game/show.py
index b9b684b..94e2540 100644
--- a/src/sliceitoff/game/show.py
+++ b/src/sliceitoff/game/show.py
@@ -11,7 +11,7 @@ class Show(pygame.sprite.Group):
self.explode = False
self.fadeout = 1_000
self.timeout = 15_000
-
+
def update(self, dt = 0, **kwargs):
""" First timeout then fadeout and then inactivity """
super().update(dt = dt, explode = self.explode, **kwargs)
@@ -29,4 +29,4 @@ class Show(pygame.sprite.Group):
def sprites(self):
""" Return sprites only when active """
- return super().sprites() if self.active else [] \ No newline at end of file
+ return super().sprites() if self.active else []
diff --git a/src/sliceitoff/hiscores/__init__.py b/src/sliceitoff/hiscores/__init__.py
index f3d7811..fdad3e5 100644
--- a/src/sliceitoff/hiscores/__init__.py
+++ b/src/sliceitoff/hiscores/__init__.py
@@ -1 +1,2 @@
+""" highscores - High score storing and listing """
from .hiscores import HiScores
diff --git a/src/sliceitoff/hiscores/hiscores.py b/src/sliceitoff/hiscores/hiscores.py
index 2725931..1b3b87f 100644
--- a/src/sliceitoff/hiscores/hiscores.py
+++ b/src/sliceitoff/hiscores/hiscores.py
@@ -1,9 +1,12 @@
+""" hiscores.hiscores - high socres: loading, saving, converting to string"""
import os
MAX_HIGHSCORES = 20
class HiScores:
+ """ Keeps track of high scores """
def __init__(self):
+ """ On creation load high scores from config file """
self.table=[]
self.config_filename = os.path.join(
os.getenv('HOME'),
@@ -12,7 +15,7 @@ class HiScores:
if not os.path.isfile(self.config_filename):
self.table=[(0,"") for _ in range(MAX_HIGHSCORES)]
return
- with open(self.config_filename, "r") as config_file:
+ with open(self.config_filename, "r", encoding="utf-8") as config_file:
for line in config_file:
option, value = line.split('=')
if option == 'hiscore':
@@ -20,30 +23,32 @@ class HiScores:
self.add(int(score.strip()),name.strip())
if len(self.table)<MAX_HIGHSCORES:
self.table+=[(0,"") for _ in range(MAX_HIGHSCORES-len(self.table))]
-
+
def add(self, score, initials):
+ """ Add new high score and reranks top """
self.table.append( (score, initials) )
self.table.sort(reverse=True)
self.table = self.table[:MAX_HIGHSCORES]
-
+
def high_enough(self, score):
+ """ Score is enough to make high scores """
return self.table[-1][0] < score
-
+
def __del__(self):
+ """ On object deletion save current high scores to config file """
oldlines=[]
-
if os.path.isfile(self.config_filename):
- with open(self.config_filename, "r") as config_file:
+ with (open(self.config_filename, "r", encoding="utf-8")
+ as config_file):
for line in config_file:
option, _ = line.split('=')
if option != 'hiscore':
oldlines.append(line)
-
- with open(self.config_filename, 'w') as config_file:
+ with open(self.config_filename, 'w', encoding="utf-8") as config_file:
config_file.writelines(oldlines)
for score, name in self.table:
config_file.write(f"hiscore={score}!{name}\n")
-
+
def __str__(self):
text = (
" "
diff --git a/src/sliceitoff/player/__init__.py b/src/sliceitoff/player/__init__.py
index bf1fc91..12ca32c 100644
--- a/src/sliceitoff/player/__init__.py
+++ b/src/sliceitoff/player/__init__.py
@@ -1 +1,2 @@
-from .player import Player \ No newline at end of file
+""" player - The slicing tool on the screen """
+from .player import Player
diff --git a/src/sliceitoff/player/player.py b/src/sliceitoff/player/player.py
index 002594f..0103a81 100644
--- a/src/sliceitoff/player/player.py
+++ b/src/sliceitoff/player/player.py
@@ -1,14 +1,14 @@
+""" player.player - Player sprite group and actions """
import os
import pygame
-from random import randrange
-
from display import Scaling
from text import Fonts
DEBUG = os.getenv("DEBUG")
class PlayerSprite(pygame.sprite.Sprite):
+ """ The slicing tool. There is 2 of these. Horizontal and vertical """
def __init__(self, image):
super().__init__()
self.image = image
@@ -19,7 +19,8 @@ class PlayerSprite(pygame.sprite.Sprite):
w, h = self.image.get_size()
self.rect = self.image.get_rect().move(pos[0]-w//2,pos[1]-h//2)
-class Player(pygame.sprite.LayeredUpdates):
+class Player(pygame.sprite.Group):
+ """ The slicer. Special sprite group that only list 1 sprite """
def __init__(self):
super().__init__()
self.position = (0,0)
@@ -34,17 +35,23 @@ class Player(pygame.sprite.LayeredUpdates):
ch.fill( color, special_flags = pygame.BLEND_RGBA_MULT)
image.blit(ch,(0,y))
image = pygame.transform.scale_by(image, 1_200 * Scaling.factor)
- self.add(PlayerSprite(image), layer = 0)
image = pygame.transform.rotate(image, 90)
- self.add(PlayerSprite(image), layer = 1)
+ self.add(PlayerSprite(image))
+ image = pygame.transform.rotate(image, 90)
+ self.add(PlayerSprite(image))
- def update(self, pos = None, direction = False, **kwargs):
+ def update(self, pos = None, direction = False):
+ """ Updates the position and direction """
if self.lazer:
direction = False
pos = None
- super().update(pos = pos, **kwargs)
if direction:
self.direction = not self.direction
- self.switch_layer(0,1)
if pos:
self.position = Scaling.scale_to_internal(pos)
+ for sprite in super().sprites():
+ sprite.update(pos = pos)
+
+ def sprites(self):
+ """ Only list sprite of current direction for draw """
+ return [super().sprites()[self.direction]]