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 相关文章推荐
网上应用的一个不错common.js脚本
Aug 08 Javascript
浅析jQuery中常用的元素查找方法总结
Jul 04 Javascript
javascript设计模式之解释器模式详解
Jun 05 Javascript
JS实现图片无间断滚动代码汇总
Jul 30 Javascript
jquery mobile界面数据刷新的实现方法
May 28 Javascript
angularjs实现多张图片上传并预览功能
Feb 24 Javascript
Bootstrap警告(Alerts)的实现方法
Mar 22 Javascript
Angularjs自定义指令Directive详解
May 27 Javascript
vue实现form表单与table表格的数据关联功能示例
Jan 29 Javascript
Vue+Express实现登录注销功能的实例代码
May 05 Javascript
JS中的一些常用的函数式编程术语
Jun 15 Javascript
微信小程序自定义头部导航栏(组件化)
Nov 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
PHP的autoload自动加载机制使用说明
2010/12/28 PHP
浅析十款PHP开发框架的对比
2013/07/05 PHP
PHP实现简单汉字验证码
2015/07/28 PHP
php制作的简单验证码识别代码
2016/01/26 PHP
thinkPHP2.1自定义标签库的导入方法详解
2016/07/20 PHP
自制PHP框架之路由与控制器
2017/05/07 PHP
thinkPHP通用控制器实现方法示例
2017/11/23 PHP
js正确获取元素样式详解
2009/08/07 Javascript
javascript qq右下角滑出窗口 sheyMsg
2010/03/21 Javascript
一个js拖拽的效果类和dom-drag.js浅析
2010/07/17 Javascript
Google (Local) Search API的简单使用介绍
2013/11/28 Javascript
JavaScript Serializer序列化时间处理示例
2014/07/31 Javascript
jQuery+Ajax实现无刷新操作
2016/01/04 Javascript
jQuery ajax中使用confirm,确认是否删除的简单实例
2016/06/17 Javascript
H5用户注册表单页 注册模态框!
2016/09/17 Javascript
javascript实现文字无缝滚动
2016/12/27 Javascript
JavaScript实现计算多边形质心的方法示例
2018/01/31 Javascript
详解jQuery中的isPlainObject()使用方法
2018/02/27 jQuery
vue axios请求频繁时取消上一次请求的方法
2018/11/10 Javascript
微信小程序授权登录解决方案的代码实例(含未通过授权解决方案)
2019/05/10 Javascript
vue keep-alive的简单总结
2021/01/25 Vue.js
python的描述符(descriptor)、装饰器(property)造成的一个无限递归问题分享
2014/07/09 Python
python实现的DES加密算法和3DES加密算法实例
2015/06/03 Python
详解Python3中yield生成器的用法
2015/08/20 Python
Python 遍历子文件和所有子文件夹的代码实例
2016/12/21 Python
pytorch cnn 识别手写的字实现自建图片数据
2018/05/20 Python
Python JSON格式数据的提取和保存的实现
2019/03/22 Python
Python redis操作实例分析【连接、管道、发布和订阅等】
2019/05/16 Python
Python如何使用k-means方法将列表中相似的句子归类
2019/08/08 Python
Python3 shelve对象持久存储原理详解
2020/03/23 Python
pandas 像SQL一样使用WHERE IN查询条件说明
2020/06/05 Python
AP澳洲中文网:澳洲正品直邮,包税收件无忧
2019/07/12 全球购物
军训自我鉴定
2014/01/22 职场文书
服装促销活动方案
2014/02/23 职场文书
清明节演讲稿
2014/05/27 职场文书
在校大学生才艺比赛策划书怎么写?
2019/08/26 职场文书