canvas游戏之贪食蛇

直接上效果图:

这个贪食蛇关键地方在于数组,它的长度增加其实是数组的增长,就是数组的向前追加等操作,核心就是数组的操作。

完整代码:

<!DOCTYPE html>
<html>

    <body>
        <canvas id="myCanvas" width="240" height="240" style="border:1px solid #d3d3d3;">
            Your browser does not support the HTML5 canvas tag.
        </canvas>
        <script>
        //r数组表示蛇 ; co表示蛇前进的方向,默认向下 ; e表示食物
var ctx = document.getElementById("myCanvas").getContext("2d"),
    r = [{
        x: 10,
        y: 9
    }, {
        x: 10,
        y: 8
    }],
    co = 40,
    e = null;
    /*为了避免按键太快,使定时器没有反应过来,出现bug*/
    var offOn=true;
    /*这是关卡的开关*/
    var offOn01=true;
    /*关卡倒计开始值*/
    var num=3;
//循环,间隔为200毫秒
var timer=setInterval(doMove, 200);

function doMove() {

    //给蛇加上阴影效果
    ctx.shadowBlur = 20, ctx.shadowColor = "black";

    //游戏是否已经结束
    if (check(r[0], 0) || r[0].x < 0 || r[0].x >= 24 || r[0].y < 0 || r[0].y >= 24) return;

    //如果有食物,则根据蛇前进的方向判断是否吃到了食物,并且将蛇数组中最后一个元素换到首部
    e != null && ((co == 40 && r[0].x == e.x && r[0].y + 1 == e.y) ||
        (co == 38 && r[0].x == e.x && r[0].y - 1 == e.y) ||
        (co == 37 && r[0].x - 1 == e.x && r[0].y == e.y) ||
        (co == 39 && r[0].x + 1 == e.x && r[0].y == e.y)) ?
    (r.unshift(e), e = null, r.unshift(r.pop())) : (r.unshift(r.pop()));

    //根据方向,重新设定蛇数组首元素的坐标,从而进行移动
    (co == 40 || co == 38) ? (r[0].x = r[1].x, r[0].y = r[1].y + (co == 40 ? 1 : -1)) : (r[0].x = r[1].x + (co == 39 ? 1 : -1), r[0].y = r[1].y);

    //清空屏幕
    ctx.clearRect(0, 0, 240, 240);

    //如果有食物,则绘制食物
    if (e) ctx.fillRect(e.x * 10, e.y * 10, 10, 10);

    //绘制蛇
    for (var i = 0; i < r.length; i++) ctx.fillRect(r[i].x * 10, r[i].y * 10, 10, 10);

    //如果没有食物,则在随机位置上加入一粒食物
    while (e == null || check(e)) e = {
        y: (Math.floor(Math.random() * 24)),
        x: (Math.floor(Math.random() * 24))
    };

    /*分数*/
    ctx.shadowBlur=0;
    ctx.font="12px Arial";
    ctx.fillText("分数:"+(r.length - 2),10,10);
    ctx.textBaseline="top";

    //判断游戏是否结束
    if (check(r[0], 0) || r[0].x < 0 || r[0].x >= 24 || r[0].y < 0 || r[0].y >= 24)
        alert("game over\n你获得:" + (r.length - 2) + "分");

    /*设置一个关卡,就是分数到10分后进入下一关,只设置一个关卡*/
    if((r.length-2)==10){
    if(offOn01){
        clearInterval(timer);
        offOn01=false;
        var timer0=setInterval(function(){
            if(num<=0){
                clearInterval(timer0);
            }
            ctx.clearRect(0, 0, 240, 240);
            ctx.font="20px Arial";
            ctx.textBaseline="middle";
            ctx.textAlign="center";
            ctx.fillText("下一关:"+num,120,120);
            num=--num<0?0:num;
        },1000);
            setTimeout(function(){
                timer=setInterval(doMove, 100);
            },4000);
        }
    }

    offOn=true;
}

//加入键盘事件,用方向键来控制蛇前进的方向
/*(Math.abs(event.keyCode - co) != 2判断不能向后走
left:37,top:38,right:39,bottom:40
反方向刚刚好是相差2
*/

document.onkeydown = function(event) {
    if(offOn){
        offOn=false;
        co = event.keyCode >= 37 &&
        event.keyCode <= 40 &&
        (Math.abs(event.keyCode - co) != 2) ? event.keyCode : co;
    }
    }
    //判断指定位置是否与蛇重叠
    /*这是为了检测自己撞到自己或检测食物在贪食蛇里面的*/
function check(e, j) {
    for (var i = 0; i < r.length; i++)
        if (j != i && r[i].x == e.x && r[i].y == e.y) return true;
    return false;
}</script>
    </body>

</html>

可以直接复制上面代码看效果;

上面的核心代码:

//如果有食物,则根据蛇前进的方向判断是否吃到了食物,并且将蛇数组中最后一个元素换到首部
    e != null && ((co == 40 && r[0].x == e.x && r[0].y + 1 == e.y) ||
        (co == 38 && r[0].x == e.x && r[0].y - 1 == e.y) ||
        (co == 37 && r[0].x - 1 == e.x && r[0].y == e.y) ||
        (co == 39 && r[0].x + 1 == e.x && r[0].y == e.y)) ?
    (r.unshift(e), e = null, r.unshift(r.pop())) : (r.unshift(r.pop()));

    //根据方向,重新设定蛇数组首元素的坐标,从而进行移动
    (co == 40 || co == 38) ? (r[0].x = r[1].x, r[0].y = r[1].y + (co == 40 ? 1 : -1)) : (r[0].x = r[1].x + (co == 39 ? 1 : -1), r[0].y = r[1].y);

这是贪食蛇的核心代码,就是数组长度添加,和数组里的值怎么改变。

时间: 2024-10-09 23:30:44

canvas游戏之贪食蛇的相关文章

websocket实战(4) websocket版贪食蛇游戏(tomcat官方自带)

websocket实战(1) 入门 websocket实战(2) 信息处理发送.接收和编码 websocket实战(3) 错误处理及配置管理 通过前面3篇的阐述,相信可以构建一个简单的socket应用了.当然,也会遗漏了许多知识点,相信会在以后分享的实例中捎带说明下. 本文的主要是分析下tomcat官方自带的贪食蛇游戏.为什么选择分析这个项目呢. 贪食蛇游戏规则,人人明白,业务方面不需要过多解释(当然这款websocket版的游戏规则也有一定特色). 游戏设计简单,一个对象足以完成游戏,但不涉及

Javascript贪食蛇小游戏

试玩:http://hovertree.com/game/9/ 贪吃蛇是一种风靡全球的小游戏,就是一条小蛇,不停地在屏幕上游走,吃各个方向出现的蛋,越吃越长.只要蛇头碰到屏幕四周,或者碰到自己的身子,小蛇就立即毙命.和别的游戏不同,贪食蛇是一个悲剧性的游戏.许多电子游戏都是打通关到底,游戏操作者以胜利而告终.而贪食蛇的结局却是死亡.“贪食蛇”,要命的就在一个“贪”字上.所以,有时候真的需要及时收手,不要逼人太甚.如果没有余地,就算你的手再快,面临的结局也是——崩盘. HTML代码如下: <!DO

8086汇编双人贪食蛇游戏

突然找到4年前自己写的纯8086汇编语言双人贪食蛇游戏,绝对原创代码纯手打.分享给有需要参考的童鞋! Download : http://download.csdn.net/detail/yarkey09/7415405 源码:game1205.asm 可运行文件:GAME1205.EXE ( Windows XP 32bit 环境下测试成功 ) 字库文件:HZK24 位图图片:256.bmp 主要涉及以下几大难点: 1,8086汇编语言语法 2,BIOS/DOS系统中断功能调用 3,中断向量表

js贪食蛇

<!DOCTYPE html><head><title>canvas贪食蛇</title><style>.canvas{    background:black;}</style></head><body><canvas class="canvas" id="canvas" width='400' height='400'></canvas><

OS X下开发!ios系统贪食蛇!——from cocos2d-x 3.0

前几天用cocos2d-x写了个贪食蛇!这次是全然在osx下开发的.基本的思路是这种我建立了一个Snake类,当中有两个构造函数一个是用于存放蛇身体sprite的图片和Snake的X坐标和Y坐标.另外一个是用于存放蛇头的sprite图片和Snake的X坐标和Y坐标dir方向,还有snake的生命.再在helloword类中建立一个容器 vector<Snake *> snake; 在helloword中的init中先建立蛇头和两节蛇身体而且添?到snake中 Snake *_head_1= n

Cocos2dx 3.0 过渡篇(二十五)死不了的贪食蛇(触摸版)

上一篇写的贪食蛇的重力感应控制版,这一篇就讲下触摸控制版吧.额,也不知道写了那个贪食蛇教程究竟有没有获得沈老师的书,假设没有的话,看我不拿西瓜刀砍掉 偶尔E往事 的那啥! 重力版链接:http://blog.csdn.net/start530/article/details/23707985 触摸版与重力版的代码大部分都一样,不一样的地方就是要将打开重力感应换成创建一个触摸监听.步骤例如以下: 1.在GameLayer的init()中创建一个触摸监听事件 [cpp] view plaincopy

【原创】只学到二维数组和结构体,不用链表也能写一个C贪食蛇?(一)

先扯几句闲话 往往非科班出身的编程爱好者,以C作为入门语言时,往往会问:“我学了这个XX,能做些什么?” 其实,配合Google,基本上啥都能做了. 你甚至连链表都不需要,就可以写一个贪食蛇小游戏 :) 本系列将分4个部分,让任何一个仅仅会二维数组合结构体的初学者写出自己的贪食蛇 进入正题.我们先分析一下问题,确定下四个部分. 0.分析游戏的本质以及在控制台中的表现形式 1.分析贪食蛇游戏的基本结构 2.确定实现方案 3.全部源代码 一.游戏,或者视频游戏的本质是什么? 0.游戏的本质是程序 对

JavaScript强化教程 - 六步实现贪食蛇

本文为H5EDU机构官方的HTML5培训教程,主要介绍贪食蛇JavaScript强化教程 1.首先创建div 并且给div加样式 <div id="pannel" style="width: 500px;height: 500px;z-index: 1;opacity: 0.5"></div> 给 <style...> 地图(div和表格).所有的块(蛇头,食物身体加样式) 2.创建地图     document.write(&q

编写小游戏《贪头蛇》第三篇

源码下载地址:http://download.csdn.net/detail/oyangyufu/7492917 点击NEW GAME按钮,进入游戏主场景 代码: 游戏背景 layer = (CCLayer*)this->getChildren()->objectAtIndex(SnakeConstants::LAYER_BACKGROUND); layer->setTouchEnabled(false); //游戏背景 CCSize size = CCDirector::sharedD