最近初学JavaScript,在这里分享贪吃蛇小游戏的实现过程,
希望能看到的前辈们能指出这个程序的不足之处。

##大致思路

- 首先要解决的问题
- 随着蛇头的前进,尾巴也要前进。
- 用键盘控制蛇的运动方向。
- 初始化食物的时候不能初始化到蛇的身体上。
- 蛇吃食物的时候身体会变长。
- 蛇头碰到“墙”,或者自己的身体游戏结束
- 不影响游戏的实现但是有关于游戏体验的设计
- 界面的美观。
- 分数的设置。
- 等级的设置(随着分数的增加,蛇前进的速度的增加)。
- 暂停与继续的快捷键。



##符号$说明

function $(id){       //在文件base.js中
return document.getElementById(id);
}



##代码

<!DOCTYPE html>
<html>
<head>
<title>Snake</title>
<meta http-equiv="Content-Type" content="text/html;charset=utf-8">
<style type="text/css" >
body{background-color: #eee; font-family: 手札体-简;}
#page{width: 960px; height: 560px; margin: 30px auto; background-color: #fdf5e6;box-shadow: 3px 3px 3px rgba(0,0,0,0.2),10px 10px 20px rgba(0,0,0,0.2); border-radius: 5px;}
#page div{float: left;}
#left{width: 710px; height: 560px; }
table{margin: 20px 100px;background-color: #9cc;}
td{background-color: #cff;} #right{width: 205px; height: 560px;}
#right div{float: none;}
#score{width: 200px; height: 190px;;background-color: #ffffe0; border-radius: 10px;box-shadow: 3px 3px 3px rgba(0,0,0,0.2),5px 5px 10px rgba(0,0,0,0.2);margin-top: 20px;}
#rank{width: 200px; height: 190px; margin-top: 10px;background-color: #ffffe0;border-radius: 10px;box-shadow: 3px 3px 3px rgba(0,0,0,0.2),5px 5px 10px rgba(0,0,0,0.2);} #right .tag{height:30px; width: 200px ;font-size: 40px;color: #9cf;font-weight: bolder; }
#score_num{height: 130px; width: 200px; text-align: center;color: #9cf; font-size: 100px;}
#rank_num{height: 130px; width: 200px; text-align: center;color: #9cf; font-size: 100px;}
#notice{width: 200px;color: #9cf; margin-top: 5px;box-shadow: 3px 3px 3px rgba(0,0,0,0.2),5px 5px 10px rgba(0,0,0,0.2);background-color: #ffffe0; border-radius: 5px;margin-top: 90px;}
</style>
<script type="text/javascript" src="base.js"></script>
<script type="text/javascript">
//全局变量
var max_scope = 30;//贪吃蛇的移动范围
var unit = 13;//每一个单元格的大小
var speed = 300;//贪吃蛇移动速度
var direction = 'left';//贪吃蛇移动方向
var snake_body = null;
var interval = null;//计时器
var food = null;
var score = 0;//分数(每吃一次,分数加一)
var rank = 1;//随着分数的增加,等级逐渐增加,速度逐渐增加 //初始化游戏,使用表格做贪吃蛇移动的范围
function initGame(){
snake_body = new Array(); for(i = 0 ; i < max_scope; i++)
{
var row = document.createElement("tr");
for( j = 0 ; j < max_scope; j++)
{
var cell = document.createElement("td");
cell.id = i + "-" + j;
cell.width = unit;
cell.height = unit;
row.appendChild(cell);
}
$("tbody").appendChild(row);
}
initSnake();
snakeInterval();
initFood();
} //贪吃蛇身体初始化(随机生成)
function initSnake(){
var x = parseInt(Math.random()*(max_scope-2));
var y = parseInt(Math.random()*(max_scope-2));
var now_position = x + "-" + y;
snake_body.push(now_position); setCellState(now_position); } // 贪吃蛇身体染色
function setCellState(id){
$(id).style.background = "#000";
} // 食物染色
function setFootState(id){
$(id).style.background = "#b10000";
} // 贪吃蛇尾巴离开位置染色
function setCellStateBack(id){
$(id).style.background = "";
} // 获取贪吃蛇坐标
function getSnakePos(i){
switch(i){
case 'x':
return snake_body[0].split('-')[0];
case 'y':
return snake_body[0].split('-')[1];
} } // 计时器
function snakeInterval(){ interval = window.setInterval('snakeMove()',speed); } // 初始化计时器
function resetSnakeInterval(){
window.clearInterval(interval);
interval = window.setInterval('snakeMove()',speed);
} // 设置蛇的移动与移动过程中发生的事件
function snakeMove(){ foodx = food.split('-')[0];
foody = food.split('-')[1]; switch(direction){ case 'left':
_x = getSnakePos('x');
_y = parseInt(getSnakePos('y')) -1;
break;
case 'right':
_x = getSnakePos('x');
_y = parseInt(getSnakePos('y')) +1;
break; case 'up':
_x = parseInt(getSnakePos('x')) -1;
_y = getSnakePos('y');
break;
case 'down':
_x = parseInt(getSnakePos('x')) +1;
_y = getSnakePos('y');
break;
default:
_x = getSnakePos('x');
_y = parseInt(getSnakePos('y')) -1;
break;
} //撞到墙游戏结束
if (_x < 0 || _x >= max_scope|| _y < 0 || _y >= max_scope){
alert("Game Over! Stupid!");
window.clearInterval(interval);
} //撞到自己游戏结束
else if (eatItself(_x, _y))
{
alert("Game Over! Stupid!");
window.clearInterval(interval);
} //蛇吃到食物与吃到食物以后加一分,并设置相应的等级
else if (foodx == _x && foody == _y)
{
snake_body.unshift(foodx + '-' + foody);
setCellState(snake_body[0]);
initFood();
score+=1;
$('score_num').innerText = score;
if (score == 3) {
speed = 250;
resetSnakeInterval();
rank = 2;
}
if (score == 6) {
speed = 200;
resetSnakeInterval();
rank = 3;
}
if (score == 10) {
speed = 150;
resetSnakeInterval();
rank = 4;
}
if (score == 20) {
speed = 100;
resetSnakeInterval();
rank = 5;
}
if (score == 30) {
speed = 70;
resetSnakeInterval();
rank = 6;
}
//将等级写到层中
$('rank_num').innerText = rank;
} //普通的移动
else {
snake_body.unshift(_x + '-' + _y);
setCellState(snake_body[0]);
setCellStateBack(snake_body.pop());
}
} // 判断贪吃蛇头碰到身体的函数
function eatItself( x,y){
var nowpos = x + '-' + y;
for (i = 1 ; i < snake_body.length; i++){
if (nowpos == snake_body[i])
return true; }
} // 设置蛇的移动方向以及键盘控制暂停与继续
function setDirction(){
// alert(event.keyCode);
if (event.keyCode == 81) window.clearInterval(interval);
if (event.keyCode == 82) interval = window.setInterval('snakeMove()',speed); switch (event.keyCode){
case 37:
if (direction != "right")
direction = "left";
break;
case 38:
if (direction != "down")
direction = "up";
break;
case 39:
if (direction != "left")
direction = "right";
break;
case 40:
if (direction != "up")
direction = "down";
break;
} } // 初始化食物
function initFood(){
var temp = new Array();
for (i = 0 ; i < max_scope ; i++){
for (j = 0 ; j < max_scope; j++){
temp.push(i + '-' + j);
}
} var addFoodString = temp.join(',')+','; for(k = 0 ; k <snake_body.length; k++){
addFoodString = addFoodString.replace(snake_body[k]+',',"")
} var food_array = addFoodString.split(','); food = food_array[parseInt(Math.random()*(food_array.length - 1))]
setFootState(food);
// $('display').innerText = addFoodString; } // function pause(){
// if (event.keyCode == 81)
// window.clearInterval(interval);
// } </script>
</head>
<body onload="initGame()" onkeydown="setDirction()" >
<div id = "page">
<div id = "left">
<table>
<tbody id = "tbody">
</tbody>
</table>
</div> <div id = "right">
<div id = "score">
<div class = "tag">Score</div>
<div id = "score_num">0</div>
</div>
<div id = "rank">
<div class = "tag">Rank</div>
<div id = "rank_num">1</div>
</div>
<div id = "notice">NOTICE:按'Q'暂停,'E'继续</div>
</div>
</div>
<!-- <div id = "display"> </div> -->
</body>
</html>



以下是效果图:
![](http://images2017.cnblogs.com/blog/885599/201708/885599-20170828144621249-460981364.png)

使用JavaScript实现简单的小游戏-贪吃蛇的更多相关文章

  1. JavaScript面向对象编程小游戏---贪吃蛇

    1 面向对象编程思想在程序项目中有着非常明显的优势: 1- 1 代码可读性高.由于继承的存在,即使改变需求,那么维护也只是在局部模块 1- 2 维护非常方便并且成本较低. ​ 2 这个demo是采用了 ...

  2. 手把手教学h5小游戏 - 贪吃蛇

    简单的小游戏制作,代码量只有两三百行.游戏可自行扩展延申. 源码已发布至github,喜欢的点个小星星,源码入口:game-snake 游戏已发布,游戏入口:http://snake.game.yan ...

  3. 第一个windows 小游戏 贪吃蛇

    最近用dx尝试做了一个小的贪吃蛇游戏,代码放到github上面:https://github.com/nightwolf-chen/MyFreakout 说一下自己实现的过程: 首先,我把蛇这个抽象成 ...

  4. JavaScript 小游戏 贪吃蛇

    贪吃蛇 代码: <!DOCTYPE html><html><head> <meta charset="UTF-8"> <met ...

  5. Java经典小游戏——贪吃蛇简单实现(附源码)

    一.使用知识 Jframe GUI 双向链表 线程 二.使用工具 IntelliJ IDEA jdk 1.8 三.开发过程 3.1素材准备 首先在开发之前应该准备一些素材,已备用,我主要找了一个图片以 ...

  6. 用Canvas制作小游戏——贪吃蛇

    今天呢,主要和小伙伴们分享一下一个贪吃蛇游戏从构思到实现的过程~因为我不是很喜欢直接PO代码,所以只copy代码的童鞋们请出门左转不谢. 按理说canvas与其应用是老生常谈了,可我在准备阶段却搜索不 ...

  7. Win32小游戏--贪吃蛇

    近日里学习了关于win32编程的相关知识,利用这些知识制作了一款贪吃蛇小游戏,具体细节还是分模块来叙述 前期准备:在网上找到一些贪吃蛇的游戏素材图片,以及具体的逻辑框图 在正式写功能之前,先把一系列环 ...

  8. Java_GUI小游戏--贪吃蛇

    贪吃蛇游戏:是一条蛇在封闭围墙里,围墙里随机出现一个食物,通过按键盘四个光标键控制蛇向上下左右四个方向移动,蛇头撞倒食物,则食物被吃掉,蛇身体长一节,接着又出现食物,等待蛇来吃,如果蛇在移动中撞到墙或 ...

  9. 用Python实现童年小游戏贪吃蛇

    贪吃蛇作为一款经典小游戏,早在 1976 年就面世了,我最早接触它还是在家长的诺基亚手机中.

随机推荐

  1. AE开发

    using System;using System.Collections.Generic;using System.ComponentModel;using System.Data;using Sy ...

  2. 电脑分辨率与pc端页面布局

    在电脑设置中选择:控制面板->外观和个性化->显示 可以设置页面的显示比例,原因是在1920*1080的分辨率下页面的图标就会变得比较小,方便用户看,这个功能就是把页面内容变大(默认是中等 ...

  3. [日常] Go语言圣经-文本和HTML模板习题

    Go语言圣经-文本和HTML模板 练习 4.14: 创建一个web服务器,查询一次GitHub,然后生成BUG报告.里程碑和对应的用户信息. 1.查看下文档godoc net/http |grep H ...

  4. java工具包一:日期处理

    作者:NiceCui 本文谢绝转载,如需转载需征得作者本人同意,谢谢. 本文链接:http://www.cnblogs.com/NiceCui/p/7846812.html 邮箱:moyi@moyib ...

  5. 【学习笔记】--- 老男孩学Python,day6 字典

    详细方法:http://www.runoob.com/python/python-dictionary.html 1. dict 用大括号{} 括起来. 内部使用key:value的形式来保存数据 { ...

  6. PHP中按值传递和引用传递的区别

    有次跟朋友讨论对象传值的方式时提到引用传值时,在大脑中搜索五秒钟,果断确定在这两个项目当中并没有用到.今天去问了一下度娘,顺便做了个小测试: 按值传递: 引用传递: 按值传递中原来参数的值在调用其他函 ...

  7. js formData图片上传(单图上传、多图上传)后台java

    单图上传 <div class="imgUp">     <label>头像单图</label>     <input type=&quo ...

  8. Codeforces Round #545 (Div. 1) 简要题解

    这里没有翻译 Codeforces Round #545 (Div. 1) T1 对于每行每列分别离散化,求出大于这个位置的数字的个数即可. # include <bits/stdc++.h&g ...

  9. 华为5G折叠屏幕适配

    华为5G折叠屏幕的发布,迎来新的一个设备——移动端的折叠设备华为Max;华为Max设备分辨率有以下几种 8.0,6.8,6.38,这三种场景下页面展示都是不一样的表现,需要我们在开发中注意监听屏幕变化 ...

  10. [性能调优]在PeopleSoft中使用函数索引

    那些没有在PeopleSoft系统遇到性能问题的人,特别是基于Oracle数据库的PeopleSoft,可能不知道基于函数的索引. 根据定义,基于函数的索引是使用如下方法定义的: 基于表达式,例如算术 ...