這個(gè)系列分為兩部分,第一部分為迷宮的生成及操作,第二部分為自動(dòng)尋路算法。
我們先看效果:
我們直入正題,先說(shuō)一說(shuō)生成迷宮的思路。
整個(gè)思路十分簡(jiǎn)單:
首先我們將迷宮視為一個(gè)m行n列的單元格組合,每一個(gè)單元格便可以表示為maze[i][j]。接下來(lái)迷宮與m*n單元格的區(qū)別是什么呢?對(duì),迷宮就是相當(dāng)于不同單元格以某種規(guī)律相互連通,也就相當(dāng)于我們把相鄰的兩個(gè)單元格之間的重合線給去掉,然后按照某種規(guī)律循環(huán),便可生成一個(gè)迷宮。
我們假定從左上角開(kāi)始出發(fā),遍歷每一個(gè)單元格,如果該單元格未被訪問(wèn)過(guò),則查看其相鄰元素(上,下,左,右)是否有未訪問(wèn)的單元格,如果有則隨機(jī)取出一個(gè)相鄰元素并打通他們之間的重合線,如果沒(méi)有則回退到上一個(gè)單元格。
上代碼:
首先我們創(chuàng)建一個(gè)構(gòu)造函數(shù):
function Maze(obj,col,row){ this.col = col || 10; this.row = row || 10; this.canvas = obj.getCo