HTML实战演练之贪吃蛇美食大作战

导入: 



一 :粉丝要求

今天一位小伙伴私信我说,想玩HTML贪吃蛇美食大作战,自己也是学HTML的,希望我能安排一下,那么好它来了




 需知:


一:别着急先看需要知道的 

要用HTML开发贪吃蛇美食大作战,你需要创建一个HTML文件,然后在其中添加JavaScript代码来实现游戏逻辑。




二:什么是游戏逻辑,今天一起讲讲吧

游戏逻辑是指游戏中的规则、流程和交互方式。它决定了游戏的可玩性和趣味性,是游戏开发中非常重要的一部分,下面是我更具常见的游戏逻辑来定义




1. 规则逻辑:

定义了游戏中各种行为的规则,例如足球比赛中的越位规则、扑克牌游戏中的出牌规则等。

2. 流程逻辑:

决定了游戏的进程和关卡设计,包括起点、终点、障碍物、道具等元素。

3. 交互逻辑:

定义了玩家与游戏之间的互动方式,包括输入、输出、反馈等。

4. 奖励逻辑:

决定了玩家在游戏中获得的奖励和惩罚,包括得分、升级、道具等。

5. AI逻辑:

定义了游戏中非玩家角色的行为和决策方式,例如敌人的行为模式、NPC的交互方式等。




以下是一个简单的案例引导学习

<!DOCTYPE html>
<html lang="zh">
<head><meta charset="UTF-8"><title>贪吃蛇美食大作战</title><style>canvas {border: 1px solid black;}</style>
</head>
<body><canvas id="game" width="400" height="400"></canvas><script>const canvas = document.getElementById('game');const context = canvas.getContext('2d');const box = 20;let snake = [];snake[0] = {x: 9 * box,y: 10 * box};let food = {x: Math.floor(Math.random() * 19 + 1) * box,y: Math.floor(Math.random() * 19 + 1) * box};let d;document.addEventListener("keydown", direction);function direction(event) {if (event.keyCode == 37 && d != "RIGHT") {d = "LEFT";} else if (event.keyCode == 38 && d != "DOWN") {d = "UP";} else if (event.keyCode == 39 && d != "LEFT") {d = "RIGHT";} else if (event.keyCode == 40 && d != "UP") {d = "DOWN";}}function draw() {context.fillStyle = "white";context.fillRect(0, 0, canvas.width, canvas.height);for (let i = 0; i < snake.length; i++) {context.fillStyle = (i == 0) ? "black" : "gray";context.fillRect(snake[i].x, snake[i].y, box, box);}context.fillStyle = "red";context.fillRect(food.x, food.y, box, box);let snakeX = snake[0].x;let snakeY = snake[0].y;if (d == "LEFT") snakeX -= box;if (d == "UP") snakeY -= box;if (d == "RIGHT") snakeX += box;if (d == "DOWN") snakeY += box;if (snakeX == food.x && snakeY == food.y) {food = {x: Math.floor(Math.random() * 19 + 1) * box,y: Math.floor(Math.random() * 19 + 1) * box};} else {snake.pop();}let newHead = {x: snakeX,y: snakeY};if (snakeX < 0 || snakeX > 19 * box || snakeY < 0 || snakeY > 19 * box || collision(newHead, snake)) {clearInterval(game);}snake.unshift(newHead);}function collision(head, array) {for (let i = 0; i < array.length; i++) {if (head.x == array[i].x && head.y == array[i].y) {return true;}}return false;}let game = setInterval(draw, 100);</script>
</body>
</html>

最后提醒:

将上述代码保存为HTML文件,然后浏览器打开贪吃蛇美食大作战即可玩

拜拜啦小伙伴们

今天的分享就到这里啦

有问题的小伙伴

可以微信呦,也可以进去微信学习群,要是有企业微信的小伙伴可以加入我们总群

下方是二维码

微信名片:

d7e6c510b5a04d3b8f052775e626b71d.png

微信DL编程培训营名片:

633182877ba0493185ffb2e8dc71f3b7.png

 企业微信DL编程培训营总群名片:

1a7345ead50c46649830d6e1ef84867d.png

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/308497.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SparkStreaming_window_sparksql_reids

1.5 window 滚动窗口滑动窗口 window操作就是窗口函数。Spark Streaming提供了滑动窗口操作的支持&#xff0c;从而让我们可以对一个滑动窗口内的数据执行计算操作。每次掉落在窗口内的RDD的数据&#xff0c;会被聚合起来执行计算操作&#xff0c;然后生成的RDD&#xff0c;会…

OfficeWeb365 Indexs 任意文件读取漏洞复现

0x01 产品简介 OfficeWeb365 是专注于 Office 文档在线预览及PDF文档在线预览云服务,包括 Microsoft Word 文档在线预览、Excel 表格在线预览、Powerpoint 演示文档在线预览,WPS 文字处理、WPS 表格、WPS 演示及 Adobe PDF 文档在线预览。 0x02 漏洞概述 OfficeWeb365 /Pi…

【软件工程】走进瀑布模型:传统软件开发的经典之路

&#x1f34e;个人博客&#xff1a;个人主页 &#x1f3c6;个人专栏&#xff1a; 软件工程 ⛳️ 功不唐捐&#xff0c;玉汝于成 目录 前言&#xff1a; 正文 主要阶段&#xff1a; 优点&#xff1a; 缺点&#xff1a; 应用范围&#xff1a; 结语 我的其他博客 前言&am…

楼宇智慧能源消耗监测管理系统,楼宇中的能源“管家”

随着人口的增加&#xff0c;楼宇数据呈上涨趋势&#xff0c;但是楼宇智能建设在我国普及性远远不足&#xff0c;相比传统楼宇控制&#xff0c;智能楼宇控制系统对于楼宇内部的用电设备控制&#xff0c;能够更加的节约能源&#xff0c;降低成本。对于现代化楼宇而言&#xff0c;…

uniapp多级动态表单规则

最近有个新的业务、主要涉及多层级的动态表单提交&#xff0c;其中又涉及很多类型&#xff0c;踩了很多坑之后&#xff0c;终于研发完毕。 传来的数据格式处理 传来的数据格式涉及比较多的内容&#xff0c;以下举例一个&#xff0c;涉及到规则的填写 规则写法有两种&#xff…

【Java 进阶篇】Redis 缓存优化:提升应用性能的不二选择

在现代的软件开发中&#xff0c;性能一直是开发者们追求的目标之一。对于数据库访问频繁、数据读取较慢的场景&#xff0c;使用缓存是提升性能的有效手段之一。而 Redis 作为一款高性能的内存数据库&#xff0c;被广泛用作缓存工具。本文将围绕 Redis 缓存优化进行详解&#xf…

流量不够?腾讯云轻量应用服务器“月流量不够用”收费价格表

腾讯云轻量应用服务器流量价格&#xff1a;轻量应用服务器是限制月流量的&#xff0c;每台轻量服务器均自带月流量包&#xff0c;如果当月自带的免费月流量用完了&#xff0c;超额部分需要另外支付流量费&#xff0c;价格为0.8元/BG&#xff08;地域不同&#xff0c;流量价格也…

MySQL入门教程-触发器

9.触发器 什么是触发器 触发器(trigger)&#xff1a;监视某种情况&#xff0c;并进行某种操作&#xff0c;它的执行并不是程序调用&#xff0c;也不是手工启动&#xff0c;而是由事件来触发&#xff0c;例如&#xff1a;对一张表进行操作&#xff08;插入&#xff0c;更新&…

再见2023,你好2024

再见2023&#xff0c;你好2024 生活1月 悲伤与治愈2~4月 运动与偏爱5月 体验与美食6月 婚礼与热爱7~8月 就医与别离9~11月 陪伴与暖房12月 体验&新生 运动追剧读书总结 生活 生活是一个修罗场&#xff0c;来世间一场&#xff0c;要经历丰腴有趣的人生。去体验各种滋味&…

网络安全应急响应工具之-流量安全取证NetworkMiner

在前面的一些文章中&#xff0c;用了很多的章节介绍流量分析和捕获工具wireshark。Wireshark是一款通用的网络协议分析工具&#xff0c;非常强大&#xff0c;关于wireshark的更多介绍&#xff0c;请关注专栏&#xff0c;wireshark从入门到精通。本文将介绍一个专注于网络流量取…

C语言编写Windows程序:组合启用/禁用Telnet客户端,并Telnet指定ip和端口

本文程序是将启用/禁用Telnet客户端的命令进行组合&#xff0c;单个命令的解析可参考文章&#xff1a; 启用/禁用Windows功能中的Telnet客户端的命令_()命令将阻止使用telnintel-CSDN博客 源代码如下&#xff1a; #include <stdio.h> #include <stdlib.h> #include…

RabbitMQ消息存储JSON格式反序列化

如果发送消息消息体为实体类对象数据&#xff0c;交换机接收消息经由路由键发送给队列。需要实现数据反序列化操作。实现JSON格式的反序列化操作 Rabbitmq的反序列化接口 MessageConverter&#xff0c;它的实现类有 Jackson2JsonMessageConverter的反序列化实现类&#xff0c…