mirror of
https://github.com/maoakeEnterprise/amazing.git
synced 2026-04-28 16:04:35 +02:00
Compare commits
2 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
| 68d710e313 | |||
| b682274102 |
+36
-1
@@ -116,6 +116,7 @@ class MazeMLX:
|
|||||||
)
|
)
|
||||||
)
|
)
|
||||||
self.update_maze(maze)
|
self.update_maze(maze)
|
||||||
|
self.color_ft(maze)
|
||||||
for i in range(len(path)):
|
for i in range(len(path)):
|
||||||
ul = (
|
ul = (
|
||||||
(actual[0]) * cell_size + margin + 12,
|
(actual[0]) * cell_size + margin + 12,
|
||||||
@@ -157,6 +158,38 @@ class MazeMLX:
|
|||||||
self.redraw_image()
|
self.redraw_image()
|
||||||
return
|
return
|
||||||
|
|
||||||
|
def color_ft(self, maze: np.ndarray):
|
||||||
|
self.clear_image()
|
||||||
|
margin = math.trunc(
|
||||||
|
math.sqrt(self.width if self.width > self.height else self.height)
|
||||||
|
// 2
|
||||||
|
)
|
||||||
|
line_len = math.trunc(
|
||||||
|
(
|
||||||
|
(self.height - margin) // len(maze)
|
||||||
|
if self.height > self.width
|
||||||
|
else (self.width - margin) // len(maze[0])
|
||||||
|
)
|
||||||
|
)
|
||||||
|
for y in range(len(maze)):
|
||||||
|
for x in range(len(maze[0])):
|
||||||
|
x0 = x * line_len + margin
|
||||||
|
y0 = y * line_len + margin
|
||||||
|
x1 = x * line_len + line_len + margin
|
||||||
|
y1 = y * line_len + line_len + margin
|
||||||
|
|
||||||
|
if maze[y][x].get_north():
|
||||||
|
self.put_line((x0, y0), (x1, y0))
|
||||||
|
if maze[y][x].get_est():
|
||||||
|
self.put_line((x1, y0), (x1, y1))
|
||||||
|
if maze[y][x].get_south():
|
||||||
|
self.put_line((x0, y1), (x1, y1))
|
||||||
|
if maze[y][x].get_west():
|
||||||
|
self.put_line((x0, y0), (x0, y1))
|
||||||
|
if maze[y][x].value == 15:
|
||||||
|
self.put_block((x0, y0), (x1, y1))
|
||||||
|
self.redraw_image()
|
||||||
|
|
||||||
def close_loop(self, _: Any):
|
def close_loop(self, _: Any):
|
||||||
self.mlx.mlx_loop_exit(self.mlx_ptr)
|
self.mlx.mlx_loop_exit(self.mlx_ptr)
|
||||||
|
|
||||||
@@ -172,7 +205,6 @@ class MazeMLX:
|
|||||||
|
|
||||||
def start(self, amazing: AMazeIng) -> None:
|
def start(self, amazing: AMazeIng) -> None:
|
||||||
self.restart_maze(amazing)
|
self.restart_maze(amazing)
|
||||||
self.restart_path(amazing)
|
|
||||||
self.mlx.mlx_loop_hook(self.mlx_ptr, self.render_maze, amazing)
|
self.mlx.mlx_loop_hook(self.mlx_ptr, self.render_maze, amazing)
|
||||||
self.mlx.mlx_hook(self.win_ptr, 33, 0, self.close_loop, None)
|
self.mlx.mlx_hook(self.win_ptr, 33, 0, self.close_loop, None)
|
||||||
self.mlx.mlx_hook(
|
self.mlx.mlx_hook(
|
||||||
@@ -199,8 +231,11 @@ class MazeMLX:
|
|||||||
self.update_maze(amazing.maze.get_maze())
|
self.update_maze(amazing.maze.get_maze())
|
||||||
# time.sleep(0.01)
|
# time.sleep(0.01)
|
||||||
except StopIteration:
|
except StopIteration:
|
||||||
|
# self.color_ft(amazing)
|
||||||
if self.path_printer is not None:
|
if self.path_printer is not None:
|
||||||
self.render_path()
|
self.render_path()
|
||||||
|
else:
|
||||||
|
self.color_ft(amazing.maze.get_maze())
|
||||||
|
|
||||||
|
|
||||||
def main() -> None:
|
def main() -> None:
|
||||||
|
|||||||
+5
-5
@@ -1,8 +1,8 @@
|
|||||||
WIDTH=11
|
WIDTH=50
|
||||||
HEIGHT=11
|
HEIGHT=50
|
||||||
ENTRY=1,1
|
ENTRY=1,1
|
||||||
EXIT=11,11
|
EXIT=11,11
|
||||||
OUTPUT_FILE=maze.txt
|
OUTPUT_FILE=maze.txt
|
||||||
PERFECT=True
|
PERFECT=False
|
||||||
GENERATOR=Kruskal
|
GENERATOR=DFS
|
||||||
SOLVER=AStar
|
SOLVER=DFS
|
||||||
|
|||||||
@@ -166,6 +166,13 @@ class DepthFirstSearchSolver(MazeSolver):
|
|||||||
|
|
||||||
def solve(self, maze: Maze, height: int = None,
|
def solve(self, maze: Maze, height: int = None,
|
||||||
width: int = None) -> str:
|
width: int = None) -> str:
|
||||||
|
res = list()
|
||||||
|
for _ in range(50):
|
||||||
|
res.append(self.get_path(maze, height, width))
|
||||||
|
return min(res, key=lambda x: len(x))
|
||||||
|
|
||||||
|
def get_path(self, maze: Maze, height: int = None,
|
||||||
|
width: int = None) -> str:
|
||||||
path_str = ""
|
path_str = ""
|
||||||
visited = np.zeros((height, width), dtype=bool)
|
visited = np.zeros((height, width), dtype=bool)
|
||||||
path = list()
|
path = list()
|
||||||
|
|||||||
Reference in New Issue
Block a user