IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> 纯新手HTML5运用canvas制作贪吃蛇小游戏 -> 正文阅读

[游戏开发]纯新手HTML5运用canvas制作贪吃蛇小游戏

纯新手HTML5运用canvas制作贪吃蛇小游戏

以下运用notpad++示例:

一、创建一个html文件

  1. 桌面新建文件夹;
  2. 运行notpad++新建文件,并保存在该文件夹中,命名index.html文件;
  3. 开始在index.html中编写我们的代码,如下:
    <!doctype html>
    <html>
    <head>
    <meta charset="utf-8">
    <title>贪吃蛇</title>
    </head>
    
    <body>
    //内容..
    
    </body>
    </heml>
    

1.我们要了解什么是canvas,该如何用canvas来进行画图

<canvas> 标签在Html5中只是图形容器,必须通过脚本来绘制图形 (通常是JavaScript)。

2.了解之后接着开始编写我们的代码

1、在<body> </body>中间添加一下代码,创建一个宽480px和高320px大小的canvas,id属性为canvas
//创建canvas
<canvas id="canvas" width="480" height="320" style="border:solid; position:absolute; left:200px; top:50px;">
	canvas画图!!
</canvas>;

3.canvas创建好之后要通过脚本来进行绘制-----创建绘制脚本文件

新建文件并保存,命名为snakeJS.js 创建之后 我们在html中引用
//引用JavaScript
<script language="javascript" src="snakeJS.js"></script>

以上index.html中的代码已完成,接下来开始编写JS 文件中的代码

二、绘制canvas并编写游戏逻辑

1、在JS文件中绘制canvas,如下:
创建
// JavaScript Document
var canvas = document.getElementById("canvas");
var context = canvas.getContext('2d');

2、创建活动范围(范围自定),游戏蛇以及食物
1-->墙壁  0-->活动范围
//墙壁 10行15列
var map = [
	[1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,0,0,0,0,0,0,0,0,0,0,0,0,0,1,],
	[1,1,1,1,1,1,1,1,1,1,1,1,1,1,1,],
];

//游戏蛇
function gameObject()
{
	this.iRow = -1;     // 当前坐标
	this.iCol = -1;
	this.iRowBk = 1;   // 备份坐标(前一步)
	this.iColBk = 1;
	this.iDir = 1; // 0 左边  1 右边  2 上边  3 下边
};

//蛇头
var snake = [];
snake[0] = new gameObject();
snake[0].iRow = 1;
snake[0].iCol = 1;

//食物
var food = new gameObject();
//让食物随机出现
randFoodPos();
function randFoodPos()
{
	food.iRow = getRand(1, 8);
	food.iCol = getRand(1, 13);
};
function getRand(begin, end)
{
	return Math.floor(Math.random()*(end-begin) + begin);
};
3、画出所定义的墙壁、蛇头和食物
//没过10ms刷新界面
window.setInterval("drawGame();", 10);
drawGame = function(){
	//范围 480-320
	context.clearRect(0,0,480,320);
	context.save();
	
	context.strokeStyle="#000000";
	//墙壁--10行15列
	for(var i = 0; i < 10; i++)
	{
		for(var j = 0; j < 15; j++)
		{
			if(map[i][j] == 1)
				context.strokeRect(j*32, i*32, 32, 32);
		}
	}
	
	for(var i = 0; i < snake.length; i++)
	{
		//蛇头
		if(i == 0){
			context.fillStyle = "#FF0000";	
			context.fillRect(snake[i].iCol*32, snake[i].iRow*32, 32, 32);
		}
		else{
			if(snake[i].iRow <= 0)
				break;
			
			//蛇身	
			context.strokeStyle = "#00FF00";
			context.strokeRect(snake[i].iCol*32, snake[i].iRow*32, 32, 32);
		}
		
	}
	//食物
	context.strokeStyle = "#0000ff";
	context.beginPath();
	context.arc(food.iCol*32+16, food.iRow*32+16, 16, 0, Math.PI*2, true);
	context.stroke();
};
4、重点-> 游戏思路:  
	1、 控制蛇头的移动
	2、 吃食物
	3、 增长身体
	4、 随机刷新食物
//键盘控制蛇头移动-->iDir
window.addEventListener('keydown', dokeyDown, true);
function dokeyDown(e) {
	var keyID = e.keyCode ? e.keyCode : e.which;

	if(keyID == 37 || keyID == 65) // left 和 A
	{
		snake[0].iDir = 0;
	}
	else if(keyID == 39 || keyID == 68) // right 和 D
	{
		snake[0].iDir = 1;
	}
	else if(keyID == 38 || keyID == 87) // up 和 w
	{
		snake[0].iDir = 2;
	}
	else if(keyID == 40 || keyID == 83) // down 和 S
	{
		snake[0].iDir = 3;
	}	
};

// iRowBk和iColBk备份移动过得坐标
moveSnake = function()
{
	snake[0].iRowBk = snake[0].iRow;
	snake[0].iColBk = snake[0].iCol;
	if(snake[0].iDir == 0)
		snake[0].iCol--;
	else if(snake[0].iDir == 1)
		snake[0].iCol++;
	else if(snake[0].iDir == 2)
		snake[0].iRow--;
	else if(snake[0].iDir == 3)
		snake[0].iRow++;
		
	if(snake[0].iRow <= 0 
	|| snake[0].iRow >= 9
	|| snake[0].iCol <= 0
	|| snake[0].iCol >= 14)
	{
		alert("你已死亡,单击《确定》重新游戏!");
		//死亡之后清除蛇身
		snake.splice(1, snake.length-1);
		snake[0].iRow = 1;
		snake[0].iCol = 1;
		snake[0].iDir = 1;
		//死亡之后重新开始并刷新食物
		randFoodPos();
	}
	
	//移动备份产生移动
	for(var i = 1; i < snake.length; i++)
	{
		snake[i].iRowBk = snake[i].iRow;
		snake[i].iColBk = snake[i].iCol;
		
		snake[i].iRow = snake[i-1].iRowBk;
		snake[i].iCol = snake[i-1].iColBk;
	}
	
};

//吃食物 食物和蛇头的坐标重合
eatFood = function()
{
	if(snake[0].iRow == food.iRow
	&& snake[0].iCol == food.iCol)
	{
		randFoodPos();  // 食物在其他地方出现
		snake[snake.length] = new gameObject();  // 来一截蛇身,长身体
	}
};
5、最后当让是让它运动起来啦
//实时更新
window.setInterval("upDate();", 200);
upDate = function()
{
	moveSnake();	
	eatFood();
};

三、结束

以上,有很多改进的地方,有需要的童鞋可以自行去添加美化。
感谢阅读

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2021-08-14 14:25:30  更:2021-08-14 14:25:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/1 11:57:41-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码