summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAineopintojen-harjoitustyo-Algoritmit-j <github-hy-tiralabra@v.hix.fi>2024-01-13 13:10:21 +0200
committerAineopintojen-harjoitustyo-Algoritmit-j <github-hy-tiralabra@v.hix.fi>2024-01-13 13:10:21 +0200
commit41f6ff58c4800c85e8c2d53498eddc3590acfde9 (patch)
tree468f30f29126c7711e06e3793cbdfbfe37027991
parentdca833cd9a62e163f300572ed0b3ec0dd63aa123 (diff)
Implementing tile flagging.
-rw-r--r--app.py33
-rw-r--r--board/board.py57
-rw-r--r--tui/tui.py31
3 files changed, 82 insertions, 39 deletions
diff --git a/app.py b/app.py
index d0d7a14..6a63978 100644
--- a/app.py
+++ b/app.py
@@ -1,5 +1,5 @@
from board.board import Board
-from tui.tui import Tui
+from tui.tui import Tui, Action
b = Board(10)
t = Tui()
@@ -9,17 +9,20 @@ for _ in range(b.size):
print()
while True:
- x, y = t.matrix_selector(b.get_view(), x, y)
- if x == -1:
- t.draw_matrix(b.get_view(),-1,-1)
- print("LOPETUS!")
- break
- if b.get_mask(x,y) and not b.make_guess(x, y):
- t.draw_matrix(b.get_view(),-1,-1)
- print("KUOLEMA!")
- break
- if b.is_winning():
- t.draw_matrix(b.get_view(),-1,-1)
- print("VOITTO!")
- break
-
+ action, x, y = t.matrix_selector(b.get_view(), x, y)
+ match action:
+ case Action.QUIT:
+# t.draw_matrix(b.get_view(),-1,-1)
+ print("LOPETUS!")
+ break
+ case Action.OPEN:
+ if b.get_mask(x,y) and not b.make_guess(x, y):
+ t.draw_matrix(b.get_view(),-1,-1)
+ print("KUOLEMA!")
+ break
+ elif b.is_winning():
+ t.draw_matrix(b.get_view(),-1,-1)
+ print("VOITTO!")
+ break
+ case Action.FLAG:
+ b.flag_tile(x,y) \ No newline at end of file
diff --git a/board/board.py b/board/board.py
index 2d3fa1f..dbec117 100644
--- a/board/board.py
+++ b/board/board.py
@@ -21,10 +21,12 @@ class Board():
self.randomize_bombs( bombs )
self.calculate_neighbours()
+
def initialize_tiles(self, size):
self.tiles = [[0 for _ in range(size)] for _ in range(size)]
self.masked = [[10 for _ in range(size)] for _ in range(size)]
+
def randomize_bombs(self, bomb_count):
for _ in range(bomb_count):
while True:
@@ -34,9 +36,23 @@ class Board():
self.tiles[x][y]=9
break
+
+ def calculate_neighbours(self):
+ for y in range(self.size):
+ for x in range(self.size):
+ if self.tiles[x][y] == 9:
+ continue
+ neighbouring_bombs = 0
+ for nx, ny in self.get_neighbours_coords(x,y):
+ if self.tiles[nx][ny] == 9:
+ neighbouring_bombs += 1
+ self.tiles[x][y] = neighbouring_bombs
+
+
def invalid_coordinates(self, x, y):
return x < 0 or x >= self.size or y < 0 or y >= self.size
+
def get_neighbours_coords(self, x, y, include_home = False):
offsets = (
(-1,-1), (0,-1), (1,-1),
@@ -53,17 +69,7 @@ class Board():
coordinates.append( (x+dx, y+dy) )
return coordinates
- def calculate_neighbours(self):
- for y in range(self.size):
- for x in range(self.size):
- if self.tiles[x][y] == 9:
- continue
- neighbouring_bombs = 0
- for nx, ny in self.get_neighbours_coords(x,y):
- if self.tiles[nx][ny] == 9:
- neighbouring_bombs += 1
- self.tiles[x][y] = neighbouring_bombs
-
+
def get_view(self):
view = deepcopy(self.masked)
for y in range(self.size):
@@ -72,6 +78,7 @@ class Board():
view[x][y]=self.tiles[x][y]
return view
+
def is_winning(self):
for y in range(self.size):
for x in range(self.size):
@@ -79,7 +86,7 @@ class Board():
return False
return True
-
+
def collect_area(self, x, y, area=set()):
if not area:
area.add((x,y))
@@ -92,8 +99,34 @@ class Board():
area=area.union(self.collect_area(tx, ty, area))
return area
+
def get_mask(self, x, y):
return self.masked[x][y]
+
+
+ def flag_tile(self, x, y):
+ if self.invalid_coordinates(x, y):
+ print("Koordinaatit on pelilaudan ulkopuolella", file=stderr)
+ return False
+
+ if self.masked[x][y] == 0:
+ print("Ei voi liputtaa avattua ruutua", file=stderr)
+ return False
+
+ match self.masked[x][y]:
+ case 0:
+ print("Ei voi liputtaa avattua ruutua", file=stderr)
+ return False
+ case 10 | 11:
+ self.masked[x][y]+=1
+ return True
+ case 12:
+ self.masked[x][y]=10
+ return True
+
+ print("Ruudulla odottamaton lippu", file=stderr)
+ return False
+
def make_guess(self, x, y):
if self.invalid_coordinates(x, y):
diff --git a/tui/tui.py b/tui/tui.py
index 559d309..0f9ffca 100644
--- a/tui/tui.py
+++ b/tui/tui.py
@@ -1,4 +1,10 @@
import termios, fcntl, sys, os
+from enum import Enum
+
+class Action(Enum):
+ QUIT = 0
+ OPEN = 1
+ FLAG = 2
class Tui():
def __init__(self):
@@ -40,7 +46,8 @@ class Tui():
(' ', 7, 0), ('1', 10, 0), ('2', 11, 0),
('3', 13, 0), ('4', 9, 0), ('5', 9, 0),
('6', 9, 0), ('7', 9, 0), ('8', 9, 0),
- ('¤', 15, 1), ('#', 8, 7)
+ ('¤', 15, 1), ('#', 8, 7), ('B', 8, 7),
+ ('?', 8, 7)
)
if hilighted:
@@ -61,7 +68,7 @@ class Tui():
x == hx and y == hy )
print()
- def matrix_selector(self, matrix, x,y ):
+ def matrix_selector(self, matrix, x, y ):
self.draw_matrix(matrix, x, y)
while True:
try:
@@ -69,20 +76,20 @@ class Tui():
except:
continue
match c:
- case 'A':
+ case 'A' | 'w':
y-=1
- case 'B':
+ case 'D' | 'a':
+ x-=1
+ case 'B' | 's':
y+=1
- case 'C':
+ case 'C' | 'd':
x+=1
- case 'D':
- x-=1
- case '':
- continue
case 'q':
- return (-1,-1)
- case ' ':
- return (x,y)
+ return (Action.QUIT,-1,-1)
+ case ' ' | '\n':
+ return (Action.OPEN, x, y)
+ case 'f' | 'm':
+ return (Action.FLAG, x, y)
case _:
continue
x = 0 if x < 0 else x