Html/Javascript snake game 贪吃蛇游戏(附全部代码)

article/2025/10/21 15:45:04

以前用pyhton 做了贪吃蛇游戏, 这里发表的是html/javascript 版本。难度差不多, 区别是python 主要用class, 而javascript 主要用function , 他们的功能很相似, 写法稍微有些不同。内容大致是:

1. 蛇由蛇头(红色)和蛇身组成

2.食物随机产生

3.蛇吃到食物后, 会变长, 并且得10分

3.如果蛇头碰到自己得身体或者碰到四周墙壁,则game over

全部代码如下:

<!DOCTYPE html>
<html> <head><style>#gameCanvas {position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);}    </style>
</head>
<body>
<canvas id="gameCanvas" width="600" height="600"  > </canvas>
<script>
//https://www.educative.io/blog/javascript-snake-game-tutorial	
const snakeboard = document.getElementById("gameCanvas");
const snakeboard_ctx = gameCanvas.getContext("2d");const board_background = "black";
const snake_col = 'lightblue';
const snake_border = 'darkblue';
const CELL=10;
let dx=CELL,dy=0;
let startx=200,starty=200,startL=5; //initial position and Length of the snake
let score = 0;let food_x;
let food_y;
let game;
let sn;document.addEventListener("keydown", change_direction);
let direction;
function change_direction(event){  let key = event.keyCode;  if( key == 37 && direction != "RIGHT"){  direction= "LEFT";  dx=-CELL,dy=0;}else if(key == 38 && direction != "DOWN"){  direction = "UP";  dx=0,dy=-CELL;}else if(key == 39 && direction != "LEFT"){  direction = "RIGHT";dx=CELL,dy=0   }else if(key == 40 && direction != "UP"){  direction = "DOWN";  dx=0,dy=CELL;}  
}var snake=function(x0,y0) {this.body=[];this.head={x:x0,y:y0};this.init=function() {for (let i=0;i<startL;i++) {xv=x0-CELL*(i);this.body[i]={x:xv,y:y0};}}this.draw=function() {			snakeboard_ctx.strokestyle = snake_border;		for (let i=0;i<this.body.length;i++) {if (i==0) {snakeboard_ctx.fillStyle='red';}else {snakeboard_ctx.fillStyle=snake_col;}snakeboard_ctx.fillRect(this.body[i].x, this.body[i].y, CELL, CELL);  snakeboard_ctx.strokeRect(this.body[i].x, this.body[i].y, CELL, CELL);}		}	this.move=function() {  this.body.unshift(this.head); //add head to snakethis.head = {x: this.head.x + dx, y: this.head.y+dy}; //dx-horizontal speed//eaten food-> grow, if not pop()->just move  if (this.head.x === food_x && this.head.y === food_y) {        score += 10;	  // Generate new food locationgen_food();} else {// Remove the last part of snake bodythis.body.pop();}  }}	function has_game_ended()
{  for (let i = startL-1; i < sn.body.length; i++){    const has_collided = sn.body[i].x === sn.body[0].x && sn.body[i].y === sn.body[0].y//The head of the snake collides with its bodyif (has_collided) return true}const hitLeftWall = sn.body[0].x < 0;  const hitRightWall = sn.body[0].x > snakeboard.width - 10;const hitToptWall = sn.body[0].y < 0;const hitBottomWall = sn.body[0].y > snakeboard.height - 10;//The head of the snake collides with the canvas boundaryreturn hitLeftWall ||  hitRightWall || hitToptWall || hitBottomWall
}snakeboard_ctx.font = "25px serif";
snakeboard_ctx.strokeStyle="#FFFFFF";
function drawtext(text,x,y){	y=snakeboard_ctx.measureText("M").width*1.5+y;snakeboard_ctx.strokeText(text, x,y); }function clearCanvas() {snakeboard_ctx.fillStyle = board_background;snakeboard_ctx.fillRect(0, 0, snakeboard.width, snakeboard.height);snakeboard_ctx.strokeRect(0, 0, snakeboard.width, snakeboard.height);//snakeboard_ctx.clearRect(0, 0, snakeboard.width, snakeboard.height);}function random_food(min, max)
{  return Math.round((Math.random() * (max-min) + min) / CELL) * CELL;
}function drawFood()
{snakeboard_ctx.fillStyle = 'lightgreen';snakeboard_ctx.strokestyle = 'darkgreen';snakeboard_ctx.fillRect(food_x, food_y, CELL, CELL);snakeboard_ctx.strokeRect(food_x, food_y, CELL, CELL);
}function gen_food() 
{  food_x = random_food(0, snakeboard.width - CELL);food_y = random_food(0, snakeboard.height - CELL);//to ensure that the food is not located where the snake currently is.if (sn.body.filter ((m)=> m.x===food_x && m.y===food_y).length>0) {gen_food();}
}function gameover(){alert("game over");clearInterval(game);new_game();}function main() {			if (has_game_ended()) {gameover();}clearCanvas(); drawtext("score: "+score.toString(),0,0);sn.move();sn.draw();drawFood();//window.requestAnimationFrame(main);}function new_game() {score=0;sn=new snake(200,200);sn.init();gen_food();game=setInterval(main,100);
}new_game();</script>
</body>
<html> 


http://chatgpt.dhexx.cn/article/6QAdiIwq.shtml

相关文章

实验二.贪吃蛇的设计

目录 一.实验内容&#xff1a; 二.贪吃蛇的代码实现 &#xff08;1&#xff09;类的声明 &#xff08;2&#xff09;初始化界面 &#xff08;3&#xff09;游戏界面 &#xff08;4&#xff09;蛇的位置 &#xff08;5&#xff09;键盘监听 &#xff08;6&#xff09;更…

Python贪吃蛇 (完整代码+详细注释+粘贴即食)

文章目录 代码运行截图笔记补充参考博客&#xff08;阿里嘎多&#xff01;&#xff09; 代码 #!/usr/bin/env python # -*- coding: utf-8 -*- # author&#xff1a;Wangdali time:2021年1月20日16:08:44 #python实现&#xff1a;贪吃蛇游戏玩法&#xff1a;回车开始游戏&am…

k-means聚类算法及matlab实现(简单实现)

k-means简介 k-means算法也称k均值算法&#xff0c;是一种常用的聚类算法。聚类算法是研究最多、应用最广的一种无监督学习算法。   聚类试图将数据集中的样本划分为若干个通常是不相交的子集&#xff0c;每个子集称为一个“簇”。通过这样的划分&#xff0c;每个簇里的样本可…

matlab 层次聚类

MATLAB的统计工具箱中的多元统计分析中提供了聚类分析的两种方法&#xff1a; 1.层次聚类 hierarchical clustering 2.k-means聚类 这里用最简单的实例说明以下层次聚类原理和应用发法。 层次聚类是基于距离的聚类方法&#xff0c;MATLAB中通过pdist、linkage、dendrogram、…

K-means聚类算法及其MATLAB实现

参考&#xff1a; http://www.csdn.net/article/2012-07-03/2807073-k-means http://www.cnblogs.com/zhzhang/p/5437778.html http://blog.csdn.net/qll125596718/article/details/8243404/ K-means属于无监督学习方法 K表示类别数&#xff0c;Means表示均值&#xff0c;K…

基于MATLAB的K-means聚类算法

实验数据说明 Iris也称鸢尾花卉数据集&#xff0c;是一类多重变量分析的数据集。通过花萼长度&#xff0c;花萼宽度&#xff0c;花瓣长度&#xff0c;花瓣宽度4个属性预测鸢尾花卉属于&#xff08;Setosa(山鸢尾)&#xff0c;Versicolour(杂色鸢尾)&#xff0c;Virginica(维吉尼…

k-means聚类算法(matlab实现)

k-means聚类算法 文章目录 k-means聚类算法前言一、k-means聚类算法简介二、k-means聚类算法步骤三、代码实现总结 前言 k-means聚类算法是硬聚类算法的一种&#xff0c;即在n纬欧几里得空间把n个样本数据分为k类。首先根据用户要确定聚类的数目k,随机性的选取k个样本&#xf…

Kmeans聚类算法——Matlab

聚类算法 原理步骤代码绘图选取四个迭代步骤进行可视化&#xff08;散点图&#xff0c;条形图&#xff09;聚类结果可视化&#xff08;散点图&#xff09; 原理 聚类算法的基本思想是&#xff1a;以空间中k个点为中心进行聚类&#xff0c;对距离他们最近的对象进行归类。通过迭…

matlab实现聚类算法

simulate2020625数据集 clear;clc load simulate2020625;kmax(subcluster(:,3));%设置聚类数目 data subcluster(:,1:2); cata subcluster; [m,n]size(data); c1subcluster(:,3); c1c1;%% 实际聚类图 figure(1); plot(cata(cata(:,3)1,1),cata(cata(:,3)1,2),r*) hold on pl…

K-means++聚类算法(matlab实现)

K-means聚类算法 文章目录 K-means聚类算法前言一、算法简介二、K-means算法步骤三、K-means算法matlab实现总结 前言 K-means算法&#xff1a;K-means算法是K-means算法的改进版&#xff0c;其在选择初始质心时采用了一种更加聪明的方法&#xff0c;能够有效地避免局部最优解…

MATLAB聚类分析(Cluster Analysis)

使用环境&#xff1a;MATLAB2016a、MATLAB2010a 聚类分析是一种无监督式学习&#xff0c;不像回归分析等需要Inputs 和 Targets &#xff0c;聚类分析是只通过提供一组数据实现分类的算法。下面给出本人在学习聚类分析的MATLAB程序 x15*[randn(500,1)5,randn(500,1)5]; x25*[…

matlab统计与机器学习工具箱中的7种聚类算法

1. matlab中自带聚类算法概述 本文简要概述了matlab统计和机器学习工具箱中可用的聚类方法&#xff0c;并给出了其聚类函数。在使用过程中&#xff0c;直接调用该函数即可&#xff0c;十分方便&#xff0c;不得不感慨matlab的强大。 聚类分析&#xff0c;又称分割分析或分类分…

K-mean(多维度)聚类算法(matlab代码)

申明: 仅个人小记。 Email: officeforcsdn163.com 目录 效果演示二维度三维度 k-mean 算法思想简要说明代码分析二维度k-mean代码三维度k-mean代码多维度k-mean代码功能使用示范后期函数接口改造 (借助matlab中cell结构实现)新的函数接口使用范例 小结 效果演示 二维度 (1) K…

k-Means——经典聚类算法实验(Matlab实现)

聚类算法—k-Means实验 k-平均&#xff08;k-Means&#xff09;&#xff0c;也被称为k-均值&#xff0c;是一种得到最广泛使用的聚类算法[1]. k-Means算法以k为参数&#xff0c;把n个对象分为k个簇&#xff0c;使得簇内具有较高的相似度。 实验目的 了解常用聚类算法及其优缺…

MATLAB K-means聚类的介绍与使用

K-means算法是硬聚类算法 &#xff0c;是典型的基于原型的目标函数 聚类方法的代表&#xff0c;它是数据点到原型的某种距离作为优化的目标函数&#xff0c;利用函数求极值的方法得到迭代运算的调整规则。K-means算法以偶是距离 作为相似度测度&#xff0c;它是求对应某一初…

MatLab Kmeans聚类

机器学习以及人工智能的学习需要扎实的数学功底才能走的更远&#xff0c;爬的更高&#xff0c;所以打好数学基础是关键&#xff0c;但无论工作学习都没有充足的时间去拿着书本一个字一个字的去学习了&#xff0c;这里我建议大家找几个比较靠谱入门的机器学习或者人工智能学习平…

聚类分析(二)k-means及matlab程序

1.介绍 k-means是一种常见的基于划分的聚类算法。划分方法的基本思想是&#xff1a;给定一个有N个元组或者记录的数据集&#xff0c;将数据集依据样本之间的距离进行迭代分裂&#xff0c;划分为K个簇&#xff0c;其中每个簇至少包含一条实验数据。 2.k-means原理分析 2.1工作原…

数据挖掘实验(七)Matlab实现聚类算法【clusterdata / kmeans】

本文代码均已在 MATLAB R2019b 测试通过&#xff0c;如有错误&#xff0c;欢迎指正。 另外&#xff0c;这次实验都是调用Matlab现成的函数&#xff0c;没什么技术含量。 &#xff08;一&#xff09;聚类分析的原理 聚类是将数据分类到不同的类或者簇这样的一个过程&#xff…

K-means聚类 —— matlab

目录 1.简介 2.算法原理 3.实例分析 3.1 读取数据 3.2 原理推导K均值过程 3.3 自带kmeans函数求解过程 完整代码 1.简介 聚类是一个将数据集中在某些方面相似的数据成员进行分类组织的过程&#xff0c;聚类就是一种发现这种内在结构的技术&#xff0c;聚类技术经常被称为…

聚类分析的Matlab 程序—系统聚类(附有案例分析)

聚类分析的Matlab 程序—系统聚类 (1)计算数据集每对元素之间的距离,对应函数为pdistw. 调用格式&#xff1a;Ypdist(X),Ypdist(X,’metric’), Ypdist(X,’distfun’),Ypdist(X,’minkowski’,p) 说明&#xff1a;X是m*n的矩阵&#xff0c;metric是计算距离的方法选项&…