js推箱子小游戏步骤代码解析


Posted in Javascript onJanuary 10, 2018

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

demo:

js推箱子小游戏步骤代码解析

步骤解析:

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

1. 渲染地图

html结构:

js推箱子小游戏步骤代码解析

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地址

Javascript 相关文章推荐
FLASH 广告之外的链接
Dec 16 Javascript
基于JQuery的一句代码实现表格的简单筛选
Jul 26 Javascript
jquery及原生js获取select下拉框选中的值示例
Oct 25 Javascript
3种不同方式的焦点图轮播特效分享
Oct 30 Javascript
利用jq让你的div居中的好方法分享
Nov 21 Javascript
jquery实现的蓝色二级导航条效果代码
Aug 24 Javascript
JS简单设置下拉选择框默认值的方法
Aug 20 Javascript
使用canvas及js简单生成验证码方法
Apr 02 Javascript
jquery网页加载进度条的实现
Jun 01 jQuery
利用vue + koa2 + mockjs模拟数据的方法教程
Nov 22 Javascript
解决低版本的浏览器不支持es6的import问题
Mar 09 Javascript
Vue v-bind动态绑定class实例方法
Jan 15 Javascript
vue select二级联动第二级默认选中第一个option值的实例
Jan 10 #Javascript
AngularJS使用ui-route实现多层嵌套路由的示例
Jan 10 #Javascript
Vue+jquery实现表格指定列的文字收缩的示例代码
Jan 09 #jQuery
基于Vue、Vuex、Vue-router实现的购物商城(原生切换动画)效果
Jan 09 #Javascript
10个经典的网页鼠标特效代码
Jan 09 #Javascript
旺旺在线客服代码 旺旺客服代码生成器
Jan 09 #Javascript
JavaScript实现多重继承的方法分析
Jan 09 #Javascript
You might like
常用星际术语索引(新手指南)
2020/03/04 星际争霸
php is_file 判断给定文件名是否为一个正常的文件
2010/05/10 PHP
php中获取指定IP的物理地址的代码(正则表达式)
2011/06/23 PHP
探讨PHP中OO之静态关键字以及类常量的详解
2013/06/07 PHP
thinkphp5使用无限极分类
2019/02/18 PHP
用js生产批量批处理执行命令
2008/07/28 Javascript
浅析Prototype的模板类 Template
2011/12/07 Javascript
js 点击页面其他地方关闭弹出层(示例代码)
2013/12/24 Javascript
jQuery插件制作之全局函数用法实例
2015/06/01 Javascript
js实现向右横向滑出的二级菜单效果
2015/08/27 Javascript
js实现下一页页码效果
2017/03/07 Javascript
vue 中directive功能的简单实现
2018/01/05 Javascript
Angular实现搜索框及价格上下限功能
2018/01/19 Javascript
Vue 自定义动态组件实例详解
2018/03/28 Javascript
Node.js的进程管理的深入理解
2019/01/09 Javascript
Vue 解决父组件跳转子路由后当前导航active样式消失问题
2020/07/21 Javascript
Javascript confirm多种使用方法解析
2020/09/25 Javascript
[47:52]完美世界DOTA2联赛PWL S2 PXG vs InkIce 第二场 11.26
2020/11/30 DOTA
python 基本数据类型占用内存空间大小的实例
2018/06/12 Python
python用列表生成式写嵌套循环的方法
2018/11/08 Python
python实现将一维列表转换为多维列表(numpy+reshape)
2019/11/29 Python
在Tensorflow中实现梯度下降法更新参数值
2020/01/23 Python
用什么库写 Python 命令行程序(示例代码详解)
2020/02/20 Python
HTML5 canvas 基本语法
2009/08/26 HTML / CSS
详解canvas.toDataURL()报错的解决方案全都在这了
2020/03/31 HTML / CSS
英国布鲁姆精品店:Bloom Boutique
2018/03/01 全球购物
罗马尼亚在线杂货店:Pilulka.ro
2019/09/28 全球购物
美国传奇滑手Paul Rodriguez创办的街头滑板品牌:Primitive Skateboarding
2019/10/29 全球购物
房地产活动策划方案
2014/05/14 职场文书
法院信息化建设方案
2014/05/21 职场文书
今冬明春火灾防控工作方案
2014/05/29 职场文书
南京青奥会口号
2014/06/12 职场文书
领导视察通讯稿
2015/07/18 职场文书
python flask开发的简单基金查询工具
2021/06/02 Python
nginx刷新页面出现404解决方案(亲测有效)
2022/03/18 Servers
Python如何将list中的string转换为int
2022/07/15 Ruby