HTML5 貪吃蛇游戲?qū)崿F(xiàn)思路及源代碼
發(fā)布時間:2013-09-03 16:21:21 作者:佚名
我要評論

游戲難點是怎么模擬貪吃蛇的移動。如果只是一個方塊的話顯然很簡單。但是當蛇的長度變長之后要怎么樣控制,下面為大家簡要介紹下具體的實現(xiàn),感興趣的朋友可以參考下,希望對大家有所幫助

游戲操作說明
通過方向鍵控制貪吃蛇上下左右移動。貪吃蛇吃到食物之后會變長一個長度。
游戲具體實現(xiàn)
游戲難點是怎么模擬貪吃蛇的移動。如果只是一個方塊的話顯然很簡單。但是當蛇的長度變長之后要怎么樣控制
每個方塊的移動呢?
如果觀察蛇的移動,可以發(fā)現(xiàn),從蛇的頭部到尾部,每個方塊在下一時刻的位置就是它的前一個方塊在當前時刻
的位置。因此我們需要做的只是控制貪吃蛇的頭部的運動。其他部分的位置都可以依次類推。
另外一個值得注意的問題是
貪吃蛇吃下食物之后,新增加的方塊應該放在哪個位置。
答案就是在下一時刻,新增加的方塊應該出現(xiàn)在當前時刻的尾部位置。
因此,在吃下食物之后應該在更新蛇的每個位置之前,增加一個方塊,并且將其位置設定在當前時刻的尾部位置。
然后在當前時刻更新出了新增方塊之外的所有方塊的位置
index.html

snake.js
復制代碼
代碼如下:var canvas;
var ctx;
var timer;
//measures
var x_cnt = 15;
var y_cnt = 15;
var unit = 48;
var box_x = 0;
var box_y = 0;
var box_width = 15 * unit;
var box_height = 15 * unit;
var bound_left = box_x;
var bound_right = box_x + box_width;
var bound_up = box_y;
var bound_down = box_y + box_height;
//images
var image_sprite;
//objects
var snake;
var food;
var food_x;
var food_y;
//functions
function Role(sx, sy, sw, sh, direction, status, speed, image, flag)
{
this.x = sx;
this.y = sy;
this.w = sw;
this.h = sh;
this.direction = direction;
this.status = status;
this.speed = speed;
this.image = image;
this.flag = flag;
}
function transfer(keyCode)
{
switch (keyCode)
{
case 37:
return 1;
case 38:
return 3;
case 39:
return 2;
case 40:
return 0;
}
}
function addFood()
{
//food_x=box_x+Math.floor(Math.random()*(box_width-unit));
//food_y=box_y+Math.floor(Math.random()*(box_height-unit));
food_x = unit * Math.floor(Math.random() * x_cnt);
food_y = unit * Math.floor(Math.random() * y_cnt);
food = new Role(food_x, food_y, unit, unit, 0, 0, 0, image_sprite, true);
}
function play(event)
{
var keyCode;
if (event == null)
{
keyCode = window.event.keyCode;
window.event.preventDefault();
}
else
{
keyCode = event.keyCode;
event.preventDefault();
}
var cur_direction = transfer(keyCode);
snake[0].direction = cur_direction;
}
function update()
{
//add a new part to the snake before move the snake
if (snake[0].x == food.x && snake[0].y == food.y)
{
var length = snake.length;
var tail_x = snake[length - 1].x;
var tail_y = snake[length - 1].y;
var tail = new Role(tail_x, tail_y, unit, unit, snake[length - 1].direction, 0, 0, image_sprite, true);
snake.push(tail);
addFood();
}
//modify attributes
//move the head
switch (snake[0].direction)
{
case 0: //down
snake[0].y += unit;
if (snake[0].y > bound_down - unit)
snake[0].y = bound_down - unit;
break;
case 1: //left
snake[0].x -= unit;
if (snake[0].x < bound_left)
snake[0].x = bound_left;
break;
case 2: //right
snake[0].x += unit;
if (snake[0].x > bound_right - unit)
snake[0].x = bound_right - unit;
break;
case 3: //up
snake[0].y -= unit;
if (snake[0].y < bound_up)
snake[0].y = bound_up;
break;
}
//move other part of the snake
for (var i = snake.length - 1; i >= 0; i--)
{
if (i > 0)
//snake[i].direction=snake[i-1].direction;
{
snake[i].x = snake[i - 1].x;
snake[i].y = snake[i - 1].y;
}
}
}
function drawScene()
{
ctx.clearRect(box_x, box_y, box_width, box_height);
ctx.strokeStyle = "rgb(0,0,0";
ctx.strokeRect(box_x, box_y, box_width, box_height);
//detection collisions
//draw images
for (var i = 0; i < snake.length; i++)
{
ctx.drawImage(image_sprite, snake[i].x, snake[i].y);
}
ctx.drawImage(image_sprite, food.x, food.y);
}
function init()
{
canvas = document.getElementById("scene");
ctx = canvas.getContext('2d');
//images
image_sprite = new Image();
image_sprite.src = "images/sprite.png";
image_sprite.onLoad = function ()
{}
//ojects
snake = new Array();
var head = new Role(0 * unit, 0 * unit, unit, unit, 5, 0, 1, image_sprite, true);
snake.push(head);
window.addEventListener('keydown', play, false);
addFood();
setInterval(update, 300); //note
setInterval(drawScene, 30);
}
相關閱讀:html5貪吃蛇游戲使用63行代碼完美實現(xiàn)
相關文章
- 一款簡單的使用鍵盤按鍵的游戲效果,游戲規(guī)則:按上下左右鍵控制方向2014-03-17
- 貪吃蛇,最主要的功能點:1、蛇的移動2、改變蛇的方向3、放置食物4、增加舍身5、怎么掛的,具體實現(xiàn)如下,簡單實用就60行,感興趣的朋友可以參考下哈,希望對大家有所幫助2013-06-25
基于html5實現(xiàn)的憤怒的小鳥網(wǎng)頁游戲特效源碼
是一款基于HTML5實現(xiàn)的逼真的憤怒的小鳥網(wǎng)頁游戲的頁面效果代碼,本段代碼適應于所有網(wǎng)頁使用,有興趣的朋友們可以前來下載使用2015-04-04基于HTML5實現(xiàn)的捕魚達人網(wǎng)頁游戲動畫特效源碼
是一段在網(wǎng)頁上實現(xiàn)了經(jīng)典的捕魚達人游戲的代碼,HTML5捕魚達人網(wǎng)頁游戲代碼是一款捕魚達人fishjoy網(wǎng)頁版游戲的源碼。本段代碼適應于有需要的朋友們使用2015-03-23HTML5實現(xiàn)的網(wǎng)頁游戲太空戰(zhàn)機源碼
這是一款制作精良的HTML5網(wǎng)頁游戲,該HTML5游戲的主角是一架英勇威武的太空戰(zhàn)機,進入游戲后按”Z”鍵發(fā)射子彈,消滅敵機,按下“P”鍵暫停游戲。并且該HTML5戰(zhàn)機游戲還具2014-06-27- HTML5驢子跳游戲源碼,制作很漂亮的一款HTML5+CSS3網(wǎng)頁游戲,想研究HTML5技術的朋友,您可不要錯過這款網(wǎng)頁游戲哦,雖然是游戲,但卻考驗了作者很綜合的HTML5編程水平2013-01-03
HTML5 Javascript 五彩連珠網(wǎng)頁游戲 腳本
一款HTML5網(wǎng)頁游戲,結合JavaScript技術共同實現(xiàn),運行截圖如上所示,游戲效果相當界面設計挺漂亮,五彩連珠同時也是一款經(jīng)常玩的小游戲,你可以一邊玩,一邊研究一下HTML52012-05-08- 這篇文章給大家介紹基于html5制作貪吃蛇游戲(手機網(wǎng)頁版),感興趣的朋友一起學習吧2015-11-02