iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >如何使用Vue3及Canvas实现简易的贪吃蛇游戏
  • 755
分享到

如何使用Vue3及Canvas实现简易的贪吃蛇游戏

2023-07-06 11:07:07 755人浏览 八月长安
摘要

这篇“如何使用vue3及canvas实现简易的贪吃蛇游戏”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何使用Vue3及Ca

这篇“如何使用vue3canvas实现简易的贪吃蛇游戏”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何使用Vue3及Canvas实现简易的贪吃蛇游戏”文章吧。

    如何使用Vue3及Canvas实现简易的贪吃蛇游戏

    规则

    玩法:玩家使用方向键操控一条长长的蛇不断吞下豆子,同时蛇身随着吞下的豆子不断变长,当蛇头撞到蛇身或障壁时游戏结束。

    思路

    元素:边界、蛇头、蛇身、食物

    边界:输入 行数 x, 列数 y 生成边界地图,用二维坐标标识每个点的位置;

    蛇头、蛇身:蛇头和蛇身分离,当吃到食物后,蛇身尾部加一

    食物:位置随机生成;

    流程图

    如何使用Vue3及Canvas实现简易的贪吃蛇游戏

    代码实现

    技术栈

    选择 vue3、vite 基础架构; 视图选用 canvas 技术来实现,相比 dom 来说性能更好;

    基本变量定义
    <script setup lang="ts">  import { ref, onMounted } from 'vue'    let width = ref(600) // 地图默认宽度  let height = ref(400) // 地图默认高度  let canvas: any = null // canvas 对象  let ctx: any = null // canvas 渲染上下文对象  let snakeList = [[0, 100], [10, 100],] // 蛇的点位坐标  let direction = 'right' // top | down | left | right // 当前方向  let elementWidth = 10 // 元素尺寸  let step = 10 // 速度  let store = ref(0) // 分数  let status = ref('start') // unStart | start | pause | over | success(通关) // 状态  let foodCoordinate: any = [    ((Math.random() * width.value) / 10) | 0,    ((Math.random() * height.value) / 10) | 0,  ] // 食物坐标  let process: any = null // 定时器 Id</script>
    初始化

    在 onMounted 里执行,主要做 地图绘制、鼠标坐标检测、方向监测、食物绘制、定时器启用等操作。

    function handleInit() {  canvas = document.getElementById('canvas')  if (canvas?.getContext) {    ctx = canvas?.getContext('2d')    canvas.addEventListener('mousemove', e => {      ctx.clearRect(10, height.value - 20, 120, 40)      ctx.fillText(`当前鼠标位置:${e.offsetX}, ${e.offsetY}`, 10, height.value - 10)    })    document.addEventListener('keydown', e => {      e.preventDefault()      if (Direction[e.keyCode]) {        direction = Direction[e.keyCode]      }    })    process = setInterval(handleRenderSnake, 150)    handleRenderFood()    // window.requestAnimationFrame(handleRenderSnake)  } else {    alert('您的浏览器不支持 canvas')  }}
    食物绘制

    当食物被吃掉后,需要销毁和重新生成

    // 绘制食物function handleRenderFood() {  ctx.clearRect(foodCoordinate[0], foodCoordinate[1], 10, 10)  foodCoordinate = [(Math.random() * width.value) | 0, (Math.random() * height.value) | 0]  ctx.fillStyle = '#eb2f96'  ctx.fillRect(foodCoordinate[0], foodCoordinate[1], 10, 10)}
    蛇头/蛇身绘制

    蛇是通过二维数组来表示的,每个节点代表身体的一部分,第一个节点代表蛇头,蛇的移动是通过 删除尾部节点,添加头部节点来实现,中间节点不用动,在四个方向上的处理略有不同。 注意当吃到食物时,当前帧尾部节点不再删除,即可实现蛇身长度加 1。

    function handleRenderSnake() {  switch (direction) {    case 'top':      if (snakeList.slice(-1)[0][1] <= 0) {        status.value = 'over'        return      }      snakeList.push([        snakeList[snakeList.length - 1][0],        snakeList[snakeList.length - 1][1] - step,      ])      handleUpdateVerify()      break    case 'down':      if (snakeList.slice(-1)[0][1] >= height.value - 1) {        status.value = 'over'        return      }      snakeList.push([        snakeList[snakeList.length - 1][0],        snakeList[snakeList.length - 1][1] + step,      ])      handleUpdateVerify()      break      ...
    碰撞算法、边界条件

    当蛇头触碰到地图边缘,将 game over, 只需根据蛇头当前坐标、当前方向,计算下一步的坐标是否会超出地图尺寸即可。

    吃到食物的计算方法:分别对蛇头坐标和食物坐标的 x、y 轴进行绝对值计算,小于元素尺寸时认为已接触。

    // 更新校验function handleUpdateVerify() {  if (status.value === 'pause') {    clearInterval(process)  }  if (store.value >= 100) {    status.value = 'success'    return  }  for (let i of snakeList) {    ctx.clearRect(i[0], i[1], elementWidth, elementWidth)  }  let currentSnake = snakeList.slice(-1)[0]  if (    Math.abs(currentSnake[0] - foodCoordinate[0]) < 10 &&    Math.abs(currentSnake[1] - foodCoordinate[1]) < 10  ) {    store.value++    handleRenderFood()  } else {    snakeList.shift()  }}
    积分计算、暂停,继续等功能

    全局变量 status 代表当前局势的状态,当 status === 'pause' 时,触发暂停操作,删除 定时器变量,点击重新开始按钮,生成新的定时器。

    当吃到食物时,全局变量 store ++, 双向绑定到页面上显示,暂时设置积分超过 100 即可通关。

    以上就是关于“如何使用Vue3及Canvas实现简易的贪吃蛇游戏”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

    --结束END--

    本文标题: 如何使用Vue3及Canvas实现简易的贪吃蛇游戏

    本文链接: https://www.lsjlt.com/news/357972.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    本篇文章演示代码以及资料文档资料下载

    下载Word文档到电脑,方便收藏和打印~

    下载Word文档
    猜你喜欢
    • 如何使用Vue3及Canvas实现简易的贪吃蛇游戏
      这篇“如何使用Vue3及Canvas实现简易的贪吃蛇游戏”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“如何使用Vue3及Ca...
      99+
      2023-07-06
    • Vue3+Canvas实现简易的贪吃蛇游戏
      目录前言规则思路流程图代码实现技术栈基本变量定义初始化食物绘制蛇头/蛇身绘制碰撞算法、边界条件积分计算、暂停,继续等功能后记前言 贪吃蛇作为一个经典的小游戏,是很多人儿时的记忆,当时...
      99+
      2024-04-02
    • 怎么使用Vue3+Canvas实现简易的贪吃蛇游戏
      规则玩法:玩家使用方向键操控一条长长的蛇不断吞下豆子,同时蛇身随着吞下的豆子不断变长,当蛇头撞到蛇身或障壁时游戏结束。思路元素:边界、蛇头、蛇身、食物边界:输入 行数 x, 列数 y 生成边界地图,用二维坐标标识每个点的位置;蛇头、蛇身:蛇...
      99+
      2023-05-14
      Canvas Vue3
    • C++实现简易贪吃蛇游戏
      C++实现建议贪吃蛇(不会闪屏幕) 使用vs2013完成。记录踏上游戏开发的道路。 效果图 代码 // 2021.7.24.1贪吃蛇.cpp : 定义控制台应用程序的入口点。 ...
      99+
      2024-04-02
    • C++如何实现简易贪吃蛇游戏
      这篇文章主要介绍C++如何实现简易贪吃蛇游戏,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!C++实现建议贪吃蛇(不会闪屏幕)使用vs2013完成。记录踏上游戏开发的道路。效果图代码// 2021.7.24....
      99+
      2023-06-20
    • H5如何使用canvas实现贪吃蛇小游戏
      小编给大家分享一下H5如何使用canvas实现贪吃蛇小游戏,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!具体如下:实现效果如下实现思路:ps:这个只是思路,详细可...
      99+
      2023-06-09
    • Java实现简易GUI贪吃蛇小游戏
      本文实例为大家分享了Java实现贪吃蛇小游戏的具体代码,供大家参考,具体内容如下 主启动类 import javax.swing.*; //主启动类 public class...
      99+
      2024-04-02
    • JS+Canvas实现贪吃蛇小游戏
      今天呢,主要和小伙伴们分享一下一个贪吃蛇游戏从构思到实现的过程~因为我不是很喜欢直接PO代码,所以只copy代码的童鞋们请出门左转不谢。 按理说canvas与其应用是老生常谈了,可我...
      99+
      2024-04-02
    • Java实现简单的贪吃蛇游戏
      本文实例为大家分享了Java实现简单贪吃蛇游戏的具体代码,供大家参考,具体内容如下 代码 启动类 package snake; import javax.swing.*; /...
      99+
      2024-04-02
    • python实现简单的贪吃蛇游戏
      本文实例为大家分享了python实现贪吃蛇游戏的具体代码,加入按钮、难度、音乐、得分功能,供大家参考,具体内容如下 贪吃蛇小游戏,可以显示出得分,又背景音乐,难度选择和开始重启按钮设...
      99+
      2024-04-02
    • 如何使用Canvas写一个贪吃蛇游戏
      这篇文章主要介绍了如何使用Canvas写一个贪吃蛇游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。之前在慕课网看了几集Canvas的视频,一直想着写点东西练练手。感觉贪吃蛇...
      99+
      2023-06-09
    • 如何使用HTML5实现贪吃蛇游戏
      这篇文章将为大家详细讲解有关如何使用HTML5实现贪吃蛇游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。 游戏操作说明 通过方向键控制贪吃蛇上下左右移动。贪吃蛇吃到...
      99+
      2024-04-02
    • unity实现简单的贪吃蛇游戏
      本文实例为大家分享了unity实现简单贪吃蛇游戏的具体代码,供大家参考,具体内容如下 SatUIController代码 using UnityEngine; using Un...
      99+
      2024-04-02
    • python如何实现简单贪吃蛇小游戏
      本篇内容介绍了“python如何实现简单贪吃蛇小游戏”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1. 导入游戏库import p...
      99+
      2023-07-02
    • QT如何实现贪吃蛇游戏
      这篇文章主要介绍了QT如何实现贪吃蛇游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。为了熟悉QT的相关知识,我用了大约8个小时的时间用QT再次写了一遍贪吃蛇。因为QT的机制...
      99+
      2023-06-15
    • Java实现简单版贪吃蛇游戏
      本文实例为大家分享了Java实现简单版贪吃蛇游戏的具体代码,供大家参考,具体内容如下 这是一个比较简洁的小游戏,主要有三个类,一个主类,一个食物类,一个贪吃蛇类。 1、首先定义主类...
      99+
      2024-04-02
    • python实现简单贪吃蛇小游戏
      本文实例为大家分享了python实现简单贪吃蛇的具体代码,供大家参考,具体内容如下 1. 导入游戏库 import pgzrun import random 2.游戏初始化 # 窗口...
      99+
      2024-04-02
    • java如何实现简单贪吃蛇小游戏
      这篇文章给大家分享的是有关java如何实现简单贪吃蛇小游戏的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下有两个类,放在同一文件下下即可,背景图片,标题,蛇尾可自行更改import java....
      99+
      2023-06-15
    • java实现简单贪吃蛇小游戏
      本文实例为大家分享了java实现贪吃蛇小游戏,供大家参考,具体内容如下 有两个类,放在同一文件下下即可,背景图片,标题,蛇尾可自行更改 import java.awt.*; im...
      99+
      2024-04-02
    • 如何使用JavaScript实现贪吃蛇小游戏
      这篇文章将为大家详细讲解有关如何使用JavaScript实现贪吃蛇小游戏,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。JavaScript实现贪吃蛇小游戏功能概述本程序实...
      99+
      2024-04-02
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作