搜索
查看: 1090|回复: 0

Maze.js-基于递归分割算法实现的简单迷宫生成器

[复制链接]
发表于 2024-6-7 07:13:04 来自手机 | 显示全部楼层 |阅读模式
Maze.js
这是一个使用递归分割算法实现的简单 JavaScript 迷宫生成器。该生成器将迷宫生成为两个emoji的二维数组。使用MIT开源协议开源,发布于Github
(文章使用Markdown编写,使用其他工具转换成语法,排班可能有些问题)
原文地址:https://www.mengze2.cn/post/506.html
项目地址:https://github.com/MengZeMC/Maze.js
记得给我点歌star
使用方法
首先得安装项目,克隆版仓库:
  1. git clone https://github.com/MengZeMC/Maze.js
复制代码

然后进入项目目录:
  1. cd Maze.js
复制代码

开始使用项目:
确保已安装
  1. seedrandom
复制代码
。您可以通过 npm 安装它:
  1. npm i
复制代码

启动迷宫,直接使用以下命令启动迷宫
  1. node Maze.js
复制代码

实例化迷宫(深度开发)
通过提供所需的宽度、高度和种子(可选)来创建
  1. Maze
复制代码
类的实例。例如:

  1.    const seedrandom = require('seedrandom');
  2.    const Maze = require('./Maze');
  3.    // 生成一个随机种子
  4.    const randomSeed = Math.floor(Math.random() * 1000000);
  5.    // 创建宽度为 35,高度为 20 的迷宫,并使用随机种子
  6.    const maze = new Maze(35, 20, randomSeed.toString());
复制代码


1. 生成迷宫:调用迷宫实例的
  1. generate()
复制代码
方法来生成迷宫。

  1.    maze.generate();
复制代码

2. 显示迷宫:使用
  1. toString()
复制代码
方法获取迷宫的字符串表示形式。

  1.    console.log('迷宫:');
  2.    console.log(maze.toString());
复制代码

3. 获取唯一标识符:如果需要,您可以获取用于生成迷宫的唯一标识符(种子)。

  1.    console.log('迷宫唯一标识符:', randomSeed);
复制代码

迷宫类
  1. Maze
复制代码
类提供以下方法:
-
  1. constructor(width, height, seed)
复制代码
: 使用指定的宽度、高度和可选的种子初始化新的迷宫。
-
  1. generate()
复制代码
: 使用递归分割算法生成迷宫。
-
  1. toString()
复制代码
: 返回迷宫的字符串表示形式。
-
  1. findDeadEnds(x, y)
复制代码
: 查找迷宫中的所有死胡同。
-
  1. removeDeadEnds()
复制代码
: 从迷宫中移除死胡同以创建更复杂的结构。
示例
  1. const seedrandom = require('seedrandom');
  2. const Maze = require('./Maze');
  3. // 生成一个随机种子
  4. const randomSeed = Math.floor(Math.random() * 1000000);
  5. // 创建宽度为 35,高度为 20 的迷宫,并使用随机种子
  6. const maze = new Maze(35, 20, randomSeed.toString());
  7. // 生成迷宫
  8. maze.generate();
  9. // 显示迷宫
  10. console.log('迷宫:');
  11. console.log(maze.toString());
  12. // 显示迷宫的唯一标识符(种子)
  13. console.log('迷宫唯一标识符:', randomSeed);
复制代码

随时根据需要自定义迷宫的尺寸,并尝试使用不同的种子生成独特的迷宫。
更新日志:
- 1.0.0:初代版本发布,算法不完善且bug多
- 1.0.1:完善了算法,使用emoji代替字符,并添加了出入口和通关路径,使迷宫可以正常使用
回复

使用道具 举报

联系我们(Contact)|手机版|萝卜头IT论坛 ( 苏ICP备15050961号-1 )

GMT+8, 2024-11-5 11:23 , Processed in 0.103488 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表