summaryrefslogtreecommitdiff
path: root/src/sliceitoff/field
diff options
context:
space:
mode:
Diffstat (limited to 'src/sliceitoff/field')
-rw-r--r--src/sliceitoff/field/field.py20
1 files changed, 10 insertions, 10 deletions
diff --git a/src/sliceitoff/field/field.py b/src/sliceitoff/field/field.py
index a062159..abcc615 100644
--- a/src/sliceitoff/field/field.py
+++ b/src/sliceitoff/field/field.py
@@ -40,6 +40,7 @@ class SliceSprite(FieldSprite):
class Field(pygame.sprite.LayeredUpdates):
+ """ group that contains all pieces of field """
initial_area = (320_000, 220_000)
def __init__(self, stats = None):
@@ -49,11 +50,12 @@ class Field(pygame.sprite.LayeredUpdates):
self.stats = stats
def calculate_current_area(self):
+ """ calculates sum of areas of all fields """
return sum( s.area[2]*s.area[3] for s in self.active_sprites() )
-
+
def update(self, **kwargs):
super().update(explode = True, **kwargs)
-
+
def update_stats(self):
""" calculates remaining area and remaining percentage """
self.stats.percent = 100 * self.calculate_current_area() / self.area_full
@@ -66,15 +68,14 @@ class Field(pygame.sprite.LayeredUpdates):
direction: bool,
thickness: int) -> pygame.Rect:
""" Slice one area into two areas """
-
+
# Slicing hits the area?
for overlap in self.get_sprites_at(Scaling.scale_to_display(pos)):
if not overlap.dead:
break
else:
return None
-
-
+
# Save the area information and remove the sprite
ax, ay, aw, ah = overlap.area
overlap.remove(self)
@@ -85,7 +86,7 @@ class Field(pygame.sprite.LayeredUpdates):
x2 = pos[0] - thickness
x3 = pos[0] + thickness
x4 = ax + aw
-
+
if x2 > x1:
self.add(FieldSprite( (x1, ay, x2-x1, ah) ))
if x4 > x3:
@@ -114,22 +115,21 @@ class Field(pygame.sprite.LayeredUpdates):
def active_sprites(self):
""" Returns all sprites that are not dead """
return [s for s in self.sprites() if not s.dead]
-
+
def active_rects(self):
""" Returns active areas as rects """
return [s.rect for s in self.sprites() if not s.dead]
def explode(self, area):
+ """ Make area full of explogind letters """
sx, sy, w, h = area
for x in range(int(sx),int(sx+w),8_000):
for y in range(int(sy),int(sy+h),8_000):
- #self.add(ExplodedField((x,y,4_000,4_000)))
self.add(LetterSprite(
('8x8', 8_000, 0xf),
randrange(0,0x100),
Scaling.scale_to_display((x,y)) ))
-
-
+
def kill_if_not_colliding(self, sprites):
""" If there is empty fields that are not yet dead kill them """
for field in self.active_sprites():