视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
js推箱子小游戏步骤代码解析
2020-11-27 22:21:52 责编:小采
文档


推箱子小游戏大家肯定都玩过,之所以写这篇文章,是觉得这个小游戏足够简单好理解

demo:

步骤解析:

本文代码已经放在了github上面了,里面也进行了很详细的代码注释,可以copy下来,在本地运行一下看看。

1. 渲染地图

html结构:

html结构十分简单,只要弄一堆div,来放置地图的class就可以了,我这里初始化了12*9个div,地图里最多九行高度。
这些div都是同样大小,地图渲染出来区别的只是颜色的不同。

地图函数:

 var box=$('.box div'); //地图使用的div集合
 function create(){ //创建地图函数
 box.each(function(index){ //index的数量是固定的,是box div下面div的数量
 // 每次创建地图初始化div
 box.eq(index).removeClass();
 });
 box.each(function(index,element){ //循环整个div的数量 二维数组里数量不够的 默认为空白
 //level为关卡数 根据关卡渲染地图 builder为二维数组,为地图关卡
 if(builder[level][index]){ //过滤0
 box.eq(index).addClass('type'+builder[level][index]);
 }
 });
 box.eq(origin[level]).addClass("pusher"); //推箱人 皮卡丘位置
 }
 //第一关的地图长这样(下面只是栗子,不是代码),0代表不可抵达区域,1代表目标(要被推到的地方),
 //2代表普通路径(可以走的),3代表墙,4代表箱子
 [0,0,0,0,3,3,3,0,0,0,0,0,
 0,0,0,0,3,1,3,0,0,0,0,0,
 0,0,0,0,3,2,3,3,3,3,0,0,
 0,0,3,3,3,4,2,4,1,3,0,0,
 0,0,3,1,2,4,2,3,3,3,0,0,
 0,0,3,3,3,3,4,3,0,0,0,0,
 0,0,0,0,0,3,1,3,0,0,0,0,
 0,0,0,0,0,3,3,3,0,0,0,0] 

2. 捕获键盘事件,判断是否可以移动
使用$(document).keydown()jqery事件,捕获键盘事件。

捕获键盘事件,上下左右以及wsad。

 $(document).keydown(function (e) {
 var key=e.which;
 switch(key){
 //col 的值为12,上下移动要12个div为一个周期
 //方向键上或者w
 case 87:
 case 38:
 move(-col);//判断移动函数
 break;
 //方向键下或者s
 case 83:
 case 40:
 move(col);
 break;
 //方向键左或者a
 case 65:
 case 37:
 move(-1);
 break;
 //方向键右或者d
 case 68:
 case 39:
 move(1);
 break;
 }
 setTimeout(win,500); //按键之后调判断是否过关
 });

判断是否可以移动。
分为两个判断条件:一个是推箱子,一个是不推箱子 自然移动,否则不移动皮卡丘。

 function move(step){ //是否移动判断
 // 分为两个判断条件一个是推箱子,一个是不推箱子 自然移动。 否则不移动皮卡丘
 //step 上下是12个div一个周期,左右是1个div positin是皮卡丘的原来位置
 var pikaqiu1=box.eq(position);//皮卡丘现在的地方
 var pikaqiu2=box.eq(position+step);//皮卡丘要去的下一个地方
 var pushBox=box.eq(position+step*2);//箱子要去的下一个地方
 if(!pikaqiu2.hasClass('type4')&&( pikaqiu2.hasClass('type1')||pikaqiu2.hasClass('type2'))){ //自然移动
 //判断:如果下一个div的class不包含type4(箱子),并且 下一个div含有type1(目标位置),或者type2(普通路径)
 //这一步和下一步判断是否有type4的原因是普通路径会变成有type4的路径,这时候就会出现问题
 pikaqiu1.removeClass("pusher"); //移除当前皮卡丘
 pikaqiu2.addClass("pusher");//移动皮卡丘到下一个位置
 position=position+step;//增加position值
 }
 else if((pikaqiu2.hasClass('type4'))&&(!pushBox.hasClass('type4'))&&(pushBox.hasClass('type1')|| pushBox.hasClass('type2')) ) {
 //推箱子 
 //如果下一个div的class包含type4(箱子)并且 不包含重叠type4(箱子) 并且 包含class type1(目标位置)或者 包含type2(空路)
 pikaqiu2.removeClass('type4');//移除当前箱子
 pikaqiu1.removeClass("pusher");//移除当前皮卡丘
 pushBox.addClass('type4');//移动箱子到下一个位置
 pikaqiu2.addClass("pusher").addClass("type2");//
 //本来是type4 移除之后,这里没有class了,要变成普通路径
 position=position+step;//增加position值 
 }
 } 

3.胜利判断:
每次移动都要调用这个胜利判断。

function win(){ //胜利条件判断
 if($(".type1.type4").length===goal){ //推的箱子与关卡设置通过箱子的数量对比
 if(level<9) {
 alert("666,挑战下一关吧--OBKoro1");
 level++; //关卡+1
 goal = goalList[level];
 position = origin[level];
 create();
 }else {
 alert("厉害啊 大佬 通关了都");
 }
 }
}

代码地址

demo地址

下载本文
显示全文
专题