JavaScript实现简单贪吃蛇效果
作者:huangfuyk. 发布时间:2023-08-13 05:48:08
标签:js,贪吃蛇
本文实例为大家分享了js实现简单贪吃蛇效果的具体代码,供大家参考,具体内容如下
上代码之前,先给大家看一下效果:
是不是想说:我能这样玩一天…
话不多说,代码如下:
<script>
class Map{
constructor(){
// 提前设定将来的地图的样式数据
this.w = 450;
this.h = 250;
this.c = "#DDD";
// 执行创建地图方法
this.createEle();
}
createEle(){
this.mapEle = document.createElement("div");
this.mapEle.style.cssText = `width:${this.w}px;height:${this.h}px;background:${this.c};margin:100px auto;position:relative;border:solid 10px #AAA;`;
document.body.appendChild(this.mapEle);
}
}
class Food{
constructor(){
// 提前设定将来的食物的样式数据
this.w = 10;
this.h = 10;
this.c = "red";
this.x = 0;
this.y = 0;
// 执行创建食物方法
this.createEle();
}
createEle(){
this.foodEle = document.createElement("div");
this.foodEle.style.cssText = `width:${this.w}px;height:${this.h}px;background:${this.c};position:absolute;left:${this.x * this.w}px;top:${this.y * this.h}px;border-radius:10px`;
m.mapEle.appendChild(this.foodEle);
}
randomPos(){
// 随机位置,随机产生的是格子的位置,不是真正的像素
this.x = random(0,(m.w-this.w) / this.w);
this.y = random(0,(m.h-this.h) / this.h);
// 设置位置时,要换算成像素,然后再生效
this.foodEle.style.left = this.x * this.w + "px";
this.foodEle.style.top = this.y * this.h + "px";
}
}
class Snake{
constructor(){
// 提前设定将来的蛇节的样式数据
this.w = 10;
this.h = 10;
// 因为蛇由多个设计组成,每个蛇节都有自己的独立信息,所以数据结构设计成如下格式
this.body = [{
ele:null,
x:4,
y:3,
c:randomColor()
},{
ele:null,
x:3,
y:3,
c:randomColor()
},{
ele:null,
x:2,
y:3,
c:randomColor()
}];
// 提前设置默认方向
this.d = "right";
// 开始创建蛇节元素,设置样式
this.createEle();
}
createEle(){
// 使用循环多次创建,因为有多个蛇节
for(var i=0;i<this.body.length;i++){
// 创建之前,需要判断元素是否已经存在,如果已经存在,不需要创建
if(!this.body[i].ele){
this.body[i].ele = document.createElement("div");
m.mapEle.appendChild(this.body[i].ele);
}
this.body[i].ele.style.cssText = `width:${this.w}px;height:${this.h}px;background:${this.body[i].c};position:absolute;left:${this.body[i].x * this.w}px;top:${this.body[i].y * this.h}px;border-radius: 10px`;
}
// 延迟之后,开始移动
setTimeout(()=>{
this.move();
},200);
}
move(){
// 从最后一个元素向前找前一个元素的坐标,直到第一个
for(var i=this.body.length-1; i>0; i--){
this.body[i].x = this.body[i-1].x;
this.body[i].y = this.body[i-1].y;
}
// 第一个元素根据默认方向,决定想哪走
switch(this.d){
case "left":
this.body[0].x -= 1;
break;
case "right":
this.body[0].x += 1;
break;
case "top":
this.body[0].y -= 1;
break;
case "bottom":
this.body[0].y += 1;
break;
}
// 移动过程中,判断是否撞到边界,任意一个边界都不行
if(this.body[0].x < 0 || this.body[0].y < 0 || this.body[0].x > ((m.w-this.w) / this.w) || this.body[0].y > ((m.h-this.h) / this.h)){
alert("撞墙了");
return;
}
// 移动过程中,判断是否与食物的坐标重复,如果重复
if(this.body[0].x === f.x && this.body[0].y === f.y){
// 给蛇增加一个蛇节
this.body.push({
ele:null,
x:this.body[this.body.length-1].x,
y:this.body[this.body.length-1].y,
c:randomColor()
})
// 刷新食物的坐标
f.randomPos();
}
// 移动过程中,判断蛇头的坐标是否与某个任意一个蛇节的坐标重复
for(var i=1;i<this.body.length;i++){
if(this.body[0].x == this.body[i].x && this.body[0].y == this.body[i].y){
// 如果重复,撞到自己,结束程序
alert("撞到自己了");
return;
}
}
this.createEle();
}
direct(type){
switch(type){
case 37:
if(this.d === "right") break;
this.d = "left";
break;
case 38:
if(this.d === "bottom") break;
this.d = "top";
break;
case 39:
if(this.d === "left") break;
this.d = "right";
break;
case 40:
if(this.d === "top") break;
this.d = "bottom";
break;
}
}
}
function random(a,b){
return Math.round(Math.random()*(a-b)+b)
}
function randomColor(){
return `rgb(${random(0,255)},${random(0,255)},${random(0,255)})`
}
var m = new Map();
var f = new Food();
f.randomPos();
var s = new Snake();
// 当按下键盘时,将按下的键盘的code值,传给蛇的专属处理方法
document.onkeydown = function(eve){
var e = eve || window.event;
var code = e.keyCode || e.which;
s.direct(code);
}
</script>
来源:https://blog.csdn.net/weixin_42881768/article/details/104730982
0
投稿
猜你喜欢
- 使用SQLSERVER的应该经常遇到“Unable to read local eventlog (reason:事件日志文件已在读取时间更
- 在做视觉设计时,如何高效地使用图标是一门学问:该使用什么样的图标?图标该放在哪里?大小如何?图标的使用是否帮助用户更好更快的理解内容,亦或是
- 在开始聊我在阿里四个月的网页推广设计之前,我想先来说说我对平面设计和网页设计的认识。它们之间的交集。1.它们都是集艺术创作、电脑技术和数字技
- SQL Server有两种备份方式,一种是使用BACKUP DATABASE将数据库文件备份出去,另外一种就是直接拷贝数据库文件mdf和日志
- 我准备在ASP中连接MYSQL了,请问如何做?首先要正确安装MYSQLX,装好之后,可调用以下程序即可正常访问MYSQL:<%@&nb
- php二维数组排序测试数据 $arr = [
- MySql5.0以后均支持存储过程,最近有空,研究了一把这个。格式:以下为引用的内容:CREATE PROCEDURE
- 程序设计中我们时常需要检测用户输入是否正确,特别是姓名,地址等等是不是输入的汉字。那么,如何判断一个字符是不是汉字呢?其实在asp中至少有两
- -- 任意的测试表 代码如下:CREATE TABLE test_delete( name varchar(10), value INT )
- 如何显示一个文本文件?完整显示文本文件的代码如下: Write(STRING) WriteLine(STRING) WriteBlan
- 在现在的项目里,不管是电商项目还是别的项目,在管理端都会有导出的功能,比方说订单表导出,用户表导出,业绩表导出。这些都需要提前生成excel
- Microsoft SQL Server 2008将包含用于合并两个行集(rowset)数据的新句法。根据一个源数据表对另一个数据表进行确定
- 前言21世纪是信息的世纪,综合国力的竞争在很大程度上是信息的竞争,更是信息利用率的竞争。近年来,随着“数字地球”和“数字国土”战略的提出和实
- 本文实例为大家分享了python实现图像拼接的具体代码,供大家参考,具体内容如下1.待拼接的图像2. 基于SIFT特征点和RANSAC方法得
- 内容摘要:有很多朋友虽然安装好了mysql但却不知如何使用它。在这篇文章中我们就从连接mysql、修改密码、增加用户等方面来学习一些mysq
- 终于开始做用户部分了,先做注册一用户 1.1用户注册 首先在Models里添加用户注册模型类UserRegister 继
- 可以使用 XDR(简化 XML-Data)架构创建关系数据的 XML 视图。然后可以使用 XPath 查询来查询这些视图。这类似于使用 CR
- 我参与了IE7的开发过程,看到了在IE浏览器中形形色色使用MSXML的方法。显然有一些东西困扰着开发者:MSXML“混乱”的版本以及如何创建
- 如何最大限度地实现安全登录功能? 具体方法如下(这是一个程序,为便于说明,中间用虚线“------”将代
- 下面的asp函数实现了对站点的所有缓存Application的清理,释放!Sub RemoveAllCache() D