使用js和canvas实现简单的网页贪吃蛇小游戏

devtools/2024/10/16 0:11:56/

玩法介绍

点击开始游戏后,使用键盘上的↑↓←→控制移动,吃到食物增加长度,碰到墙壁或碰到自身就游戏结束
在这里插入图片描述
在这里插入图片描述

代码实现

代码比较简单,直接阅读注释即可,复制即用

html"><!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>Snake Game</title><style>body {margin: 0;overflow: hidden;}canvas {display: block;position: absolute;top: 0;left: 0;z-index: 1;background-color: #000;}.start-screen {position: absolute;top: 0;left: 0;width: 100%;height: 100%;background-color: rgba(0, 0, 0, 0.8);color: white;text-align: center;z-index: 2;display: flex;align-items: center;justify-content: center;font-size: 24px;}button {font-size: 24px;padding: 10px 20px;cursor: pointer;}</style>
</head>
<body><div class="start-screen"><h1>Snake Game</h1><button id="startButton">Start Game</button></div><canvas id="gameCanvas" width="800" height="600"></canvas><script>html" title=javascript>javascript">const canvas = document.getElementById('gameCanvas');const ctx = canvas.getContext('2d');// 设置 Canvas 为全屏canvas.width = window.innerWidth;canvas.height = window.innerHeight;// 方块大小const blockSize = 20;// 游戏状态let snake = [{ x: 100, y: 100 }];let food = { x: 200, y: 200 };let direction = 'right';let score = 0;let isRunning = false;// 游戏速度const speed = 100;// 绘制蛇function drawSnake() {ctx.fillStyle = '#0f0';snake.forEach(segment => {ctx.fillRect(segment.x, segment.y, blockSize, blockSize);});}// 绘制食物function drawFood() {ctx.fillStyle = '#f00';ctx.fillRect(food.x, food.y, blockSize, blockSize);}// 检查碰撞function checkCollision() {// 检查蛇是否撞墙if (snake[0].x < 0 || snake[0].x >= canvas.width || snake[0].y < 0 || snake[0].y >= canvas.height) {alert('Game Over!');isRunning = false;return;}// 检查蛇是否撞到自己for (let i = 1; i < snake.length; i++) {if (snake[0].x === snake[i].x && snake[0].y === snake[i].y) {alert('Game Over!');isRunning = false;return;}}// 检查蛇是否吃到食物if (snake[0].x === food.x && snake[0].y === food.y) {score++;placeFood();} else {snake.pop();}}// 放置新的食物function placeFood() {food = {x: Math.floor(Math.random() * (canvas.width / blockSize)) * blockSize,y: Math.floor(Math.random() * (canvas.height / blockSize)) * blockSize};}// 更新游戏状态function update() {if (!isRunning) return;let newX = snake[0].x;let newY = snake[0].y;if (direction === 'left') newX -= blockSize;if (direction === 'right') newX += blockSize;if (direction === 'up') newY -= blockSize;if (direction === 'down') newY += blockSize;snake.unshift({ x: newX, y: newY });checkCollision();}// 渲染游戏画面function draw() {ctx.clearRect(0, 0, canvas.width, canvas.height);drawSnake();drawFood();}// 游戏主循环function gameLoop() {update();draw();setTimeout(gameLoop, speed);}// 键盘事件function handleKeyPress(event) {if (event.key === 'ArrowLeft' && direction !== 'right') direction = 'left';if (event.key === 'ArrowRight' && direction !== 'left') direction = 'right';if (event.key === 'ArrowUp' && direction !== 'down') direction = 'up';if (event.key === 'ArrowDown' && direction !== 'up') direction = 'down';}// 开始按钮事件document.getElementById('startButton').addEventListener('click', () => {const startScreen = document.querySelector('.start-screen');startScreen.style.display = 'none';// 添加键盘事件监听document.addEventListener('keydown', handleKeyPress);isRunning = true;placeFood();gameLoop();});// 游戏结束时移除键盘事件监听window.addEventListener('beforeunload', () => {document.removeEventListener('keydown', handleKeyPress);});</script>
</body>
</html>

http://www.ppmy.cn/devtools/126433.html

相关文章

el-date-picker绑定数据显示比数据库少一天问题解决记录

问题描述&#xff1a;开发过程中发现数据库存的字段值要比<el-date-picker>绑定的值大一天&#xff0c;说明&#xff1a;数据库为mysql&#xff0c;字段类型为date类型 经过查阅资料&#xff0c;得知问题是因为时区不同步导致的。数据库存储的是UTC时间&#xff0c;而el…

【鱼类识别】Python+卷积神经网络算法+人工智能+深度学习+计算机毕设项目+Django网页界面+TensorFlow

一、介绍 鱼类识别系统。使用Python作为主要编程语言开发&#xff0c;通过收集常见的30种鱼类&#xff08;‘墨鱼’, ‘多宝鱼’, ‘带鱼’, ‘石斑鱼’, ‘秋刀鱼’, ‘章鱼’, ‘红鱼’, ‘罗非鱼’, ‘胖头鱼’, ‘草鱼’, ‘银鱼’, ‘青鱼’, ‘马头鱼’, ‘鱿鱼’, ‘鲇…

一篇文章带你快速了解linux中关于信号的核心内容

1. 信号概念 信号是操作系统用来通知进程某个特定事件已经发生的一种方式。它们是一种软件中断&#xff0c;可以被发送到进程以对其进行异步通知。 2. 信号处理的三种方式 执行默认动作执行自定义动作忽略 signal() 函数&#xff1a;将信号处理设置为 SIG_IGN&#xff0c;可…

MySQL 数据库备份与恢复的全面指南

目录 MySQL 数据库备份与恢复的全面指南1. 引言2. MySQL 数据库基础3. 备份策略4. MySQL 备份工具5. 使用 mysqldump 进行备份6. 使用 MySQL Enterprise Backup7. 使用 Percona XtraBackup 进行备份8. 数据库恢复过程9. 数据完整性验证10. 备份与恢复最佳实践11. 结论 详细内容…

Java入门:11.抽象类,接口,instanceof,类关系,克隆

1 JDK中的包 JDK JRE 开发工具集&#xff08;javac.exe&#xff09; JRE JVM java类库 JVM java 虚拟机 jdk中自带了许多的包&#xff08;类&#xff09; &#xff0c; 常用的有 java.lang 该包中的类&#xff0c;不需要引用&#xff0c;可以直接使用。 例如&#xff1…

【AAOS】Android Automotive 14模拟器源码下载及编译

源码下载 repo init -u https://android.googlesource.com/platform/manifest -b android-14.0.0_r20 repo sync -c --no-tags --no-clone-bundle 源码编译 source build/envsetup.sh lunch sdk_car_x86_64-trunk_staging-eng make -j8 运行效果 emualtor Home All apps …

盒子模型:文档流

1、文档流的概念 HTML网页默认的元素摆放机制 &#xff08;1&#xff09;块元素的文档流&#xff08;自上而下流水线摆放&#xff09; 代码如下&#xff1a; <head><style>div{width: 100px;height: 100px;background-color: gray;border: 2px solid red;}<…

【jQuery】jQuery基本操作(样式操作 内容操作 节点操作 属性操作 节点遍历)

文章目录 1、样式操作2、内容操作2-1 html()2-2 text()2-3 val() 3、节点操作3-1 创建3-2 插入3-3 删除3-4 替换3-5 复制 4、属性操作5、节点遍历6、DOM操作 DOM 操作分为三类&#xff1a; ​ DOM Core&#xff1a;任何一种支持DOM的编程语言都可以使用它&#xff0c;如getElem…