资讯专栏INFORMATION COLUMN

js 简单的推箱子小游戏步骤解析--大家都玩过的

wangbjun / 1668人阅读

摘要:本文首发于我的个人推箱子小游戏步骤解析本文代码已经放在了上面了里面也进行了很详细的代码注释,可以下来,在本地运行一下看看。分为两个判断条件一个是推箱子,一个是不推箱子自然移动,否则不移动皮卡丘。

前言

推箱子小游戏大家肯定都玩过,之所以写这篇文章,是觉得这个小游戏足够简单好理解,大家看完文章之后,自己也能花上半天功夫敲出一个推箱子小游戏来,如果喜欢的话可以点波赞,或者关注一下,希望本文可以帮到大家。

本文首发于我的个人blog:obkoro1.com
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地址 结语

本文到这里就结束了,喜欢的话,赶紧自己去敲一个出来,希望本文可以帮助大家发散思维。

最后:如需转载,请放上原文链接并署名。码字不易,感谢支持!本人写文章本着交流记录的心态,写的不好之处,不撕逼,但是欢迎指点。然后就是希望看完的朋友点个喜欢,也可以关注一下我。
个人blog and 掘金个人主页

以上2018.1.7

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/57057.html

相关文章

  • js 简单推箱小游步骤解析--大家玩过

    摘要:本文首发于我的个人推箱子小游戏步骤解析本文代码已经放在了上面了里面也进行了很详细的代码注释,可以下来,在本地运行一下看看。分为两个判断条件一个是推箱子,一个是不推箱子自然移动,否则不移动皮卡丘。 前言 推箱子小游戏大家肯定都玩过,之所以写这篇文章,是觉得这个小游戏足够简单好理解,大家看完文章之后,自己也能花上半天功夫敲出一个推箱子小游戏来,如果喜欢的话可以点波赞,或者关注一下,希望本文...

    Raaabbit 评论0 收藏0
  • 射击类小游讲解:太空大战

    摘要:相信不少人都玩过太空大战,版本不同,原理相同。除此之外,今天用的不是大家常知的而是。小结这几天摸索的经验总结很重要学会查如果想做游戏开发还是用吧相关代码分享完整源码链接 相信不少人都玩过太空大战,版本不同,原理相同。没玩过的看下图了解一下: showImg(https://segmentfault.com/img/bV8Frt?w=168&h=300); 首先先分解一下游戏的构成: ...

    DDreach 评论0 收藏0
  • ⚡王者农药皮肤图片获取!⚡

    ⚡王者农药皮肤图片获取!⚡ 一、前言二、环境准备三、具体实现1、所有英雄信息获取2、分析图片url3、具体实现4、结果 四、最后 一、前言   王者荣耀大家都玩过吧,没玩过的也应该听说过,作为时下最火的手机MOBA游戏,咳咳,好像跑题了。我们今天的重点是爬取王者荣耀所有英雄的所有皮肤! 二、环境准备 编辑器:pycharm 用到的库:requests、lxml 三、具体实现 1、所有...

    StonePanda 评论0 收藏0
  • 用c语言写三子棋游戏

    摘要:因为每个格子在游戏开始的时候都是空着的状态,而在玩家与电脑进行游戏中是要输入符号的,所以我们还要定义一个型的二维数组,并初始化为。函数声明打印棋盘初始化数组玩家下棋二维数组进行函数传参时可以不用写行数电脑下棋判断是否胜利定义一个二维数组。 三子棋是大家小时候和同桌在纸上都玩过的简单小游戏,这...

    boredream 评论0 收藏0
  • 基于HTML5打造一款别踩白板小游

    摘要:看完本文有收获请转发分享给更多的人共享之家入群请在微信后台回复入群基于打造的一款别踩白板小游戏背景颜色 背景简介别踩白板这个游戏相信大家都玩过,这个是基于HTML5打造的简单小游戏,在PC端和移动端都能够运行,适应多种平台,今天我们使用原生JS搭配JQuery构建这个小游戏--别踩白板。一、思路分析整体页面是一个大的矩形,...

    番茄西红柿 评论0 收藏2637

发表评论

0条评论

wangbjun

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<