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 28 Javascript
利用JavaScript检测CPU使用率自己写的
Mar 22 Javascript
JavaScript中的getTimezoneOffset()方法使用详解
Jun 10 Javascript
使用ngView配合AngularJS应用实现动画效果的方法
Jun 19 Javascript
js实现select跳转菜单新窗口效果代码分享(超简单)
Aug 21 Javascript
ES6中非常实用的新特性介绍
Mar 10 Javascript
EditPlus中的正则表达式 实战(4)
Dec 15 Javascript
canvas雪花效果核心代码分享
Feb 19 Javascript
ES6新特性三: Generator(生成器)函数详解
Apr 21 Javascript
JavaScript+HTML5实现的日期比较功能示例
Jul 12 Javascript
vue2 mint-ui loadmore实现下拉刷新,上拉更多功能
Mar 21 Javascript
React中如何引入Angular组件详解
Aug 09 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
从MySQL数据库表中取出随机数据的代码
2007/09/05 PHP
深入eAccelerator与memcached的区别详解
2013/06/06 PHP
让CodeIgniter数据库缓存自动过期的处理的方法
2014/06/12 PHP
学习thinkphp5.0验证类使用方法
2017/11/16 PHP
PHP使用PDO实现mysql防注入功能详解
2019/12/20 PHP
php实现通过stomp协议连接ActiveMQ操作示例
2020/02/23 PHP
JavaScript/Js脚本处理html元素的自定义属性解析(亲测兼容Firefox与IE)
2013/11/25 Javascript
javascript中数组(Array)对象和字符串(String)对象的常用方法总结
2016/12/15 Javascript
JS实现简单抖动效果
2017/06/01 Javascript
浅谈vue中使用图片懒加载vue-lazyload插件详细指南
2017/10/23 Javascript
vue.js与element-ui实现菜单树形结构的解决方法
2018/04/21 Javascript
JS限制输入框输入的实现代码
2018/07/02 Javascript
微信小程序实现渐入渐出动画效果
2019/06/13 Javascript
vue-cli2与vue-cli3在一台电脑共存的实现方法
2019/09/25 Javascript
通过vue.extend实现消息提示弹框的方法记录
2021/01/07 Vue.js
[02:49]2018DOTA2亚洲邀请赛主赛事决赛日战况回顾 Mineski鏖战5局夺得辉耀
2018/04/10 DOTA
在Python的Django框架中创建和使用模版
2015/07/15 Python
Python使用cookielib模块操作cookie的实例教程
2016/07/12 Python
python实现验证码识别功能
2018/06/07 Python
如何用C代码给Python写扩展库(Cython)
2019/05/17 Python
详解PyCharm安装MicroPython插件的教程
2019/06/24 Python
Python如何通过百度翻译API实现翻译功能
2020/04/02 Python
python实现PDF中表格转化为Excel的方法
2020/06/16 Python
英国文胸专家:AmpleBosom.com
2018/02/06 全球购物
澳大利亚儿童精品仓库:Goo & Co.
2019/06/20 全球购物
美赞臣营养马来西亚旗舰店:Enfagrow马来西亚
2019/07/26 全球购物
俄罗斯品牌服装和鞋子在线商店:BRIONITY
2020/03/26 全球购物
什么是规则表达式
2012/05/03 面试题
事务机电主管工作职责
2014/02/25 职场文书
能源工程专业应届生求职信
2014/03/01 职场文书
辣妈辣妹观后感
2015/06/10 职场文书
小学语文教学随笔
2015/08/14 职场文书
2016年大学生就业指导课心得体会
2015/10/09 职场文书
职场新人知识:如何制定一份合理的工作计划?
2019/09/11 职场文书
导游词之山东红叶谷
2019/10/31 职场文书
vue 数字翻牌器动态加载数据
2022/04/20 Vue.js