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 相关文章推荐
奉献给JavaScript初学者的编写开发的七个细节
Jan 11 Javascript
jQuery 名称冲突的解决方法
Apr 08 Javascript
jQuery使用技巧简单汇总
Apr 18 Javascript
JS烟花背景效果实现方法
Mar 03 Javascript
浅谈react.js 之 批量添加与删除功能
Apr 17 Javascript
详解angular应用容器化部署
Aug 14 Javascript
如何实现小程序tab栏下划线动画效果
May 18 Javascript
node.js实现上传文件功能
Jul 15 Javascript
layui table复选框禁止某几条勾选的实例
Sep 20 Javascript
vue实现表格过滤功能
Sep 27 Javascript
Ajax是什么?Ajax高级用法之Axios技术
Apr 21 Javascript
vue实现可以快进后退的跑马灯组件
Apr 08 Vue.js
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
PHP文件去掉PHP注释空格的函数分析(PHP代码压缩)
2013/07/02 PHP
php addslashes 利用递归实现使用反斜线引用字符串
2013/08/05 PHP
PHP学习笔记(一) 简单了解PHP
2014/08/04 PHP
php中解析带中文字符的url函数分享
2015/01/20 PHP
php实现的任意进制互转类分享
2015/07/07 PHP
laravel ORM 只开启created_at的几种方法总结
2018/01/29 PHP
PHP PDOStatement::fetchColumn讲解
2019/01/31 PHP
javascript两段代码,两个小技巧
2010/02/04 Javascript
基于jquery的滑动样例代码
2010/11/20 Javascript
javascript改变position值实现菜单滚动至顶部后固定
2013/01/18 Javascript
jquery text(),val(),html()方法区别总结
2013/11/04 Javascript
Javascript字符串对象的常用方法简明版
2014/06/26 Javascript
three.js绘制地球、飞机与轨迹的效果示例
2017/02/28 Javascript
vue父组件通过props如何向子组件传递方法详解
2017/08/16 Javascript
在小程序中集成redux/immutable/thunk第三方库的方法
2018/08/12 Javascript
详解微信小程序-获取用户session_key,openid,unionid - 后端为nodejs
2019/04/29 NodeJs
Nodejs中使用puppeteer控制浏览器中视频播放功能
2019/08/26 NodeJs
Vue.set 全局操作简单示例
2019/09/19 Javascript
[44:47]Ti4 循环赛第三日 iG vs NaVi
2014/07/12 DOTA
python3+PyQt5泛型委托详解
2018/04/24 Python
Python中的Django基本命令实例详解
2018/07/15 Python
python 数字类型和字符串类型的相互转换实例
2018/07/17 Python
基于tensorflow加载部分层的方法
2018/07/26 Python
python多进程下实现日志记录按时间分割
2019/07/22 Python
Python generator生成器和yield表达式详解
2019/08/08 Python
关于阿里云oss获取sts凭证 app直传 python的实例
2019/08/20 Python
python下载卫星云图合成gif的方法示例
2020/02/18 Python
python将音频进行变速的操作方法
2020/04/08 Python
教你使用Sublime text3搭建Python开发环境及常用插件安装另分享Sublime text3最新激活注册码
2020/11/12 Python
Bibloo奥地利:购买女装、男装、童装、鞋和配件
2018/10/18 全球购物
加州风格的游泳和沙滩装品牌:Cupshe
2019/06/10 全球购物
全国爱牙日活动总结
2015/02/05 职场文书
婚前保证书范文
2015/02/28 职场文书
Python 的 sum() Pythonic 的求和方法详细
2021/10/16 Python
如何使用注解方式实现 Redis 分布式锁
2022/07/23 Redis
Redis实战之Lettuce的使用技巧详解
2022/12/24 Redis