《重温JavaScript五子棋小游戏》

目录

      • 全部运行代码:
      • 五子棋游戏的基本步骤:
      • 代码剖析:
        • 1. 初始化游戏界面
        • 2. 管理游戏状态
        • 3. 玩家交互
        • 4. 电脑AI
        • 5. 胜负判定
        • 6. 游戏控制

本文通过实现一个基本的五子棋游戏,展示了如何使用HTML、CSS和JavaScript来构建一个简单的交互式游戏。虽然这里提供的实现较为基础,但它为理解和进一步开发更复杂的版本打下了良好的基础。
在这里插入图片描述

未来还可以考虑添加以下功能:

  1. 更复杂的AI算法,如Minimax算法或Alpha-Beta剪枝。
  2. 多个难度级别的选择。
  3. 用户界面改进,如动画效果和音效。
  4. 在线多人游戏支持。

全部运行代码:

五子棋游戏的基本步骤:

  1. 初始化游戏界面

    • 创建棋盘画布(Canvas)。
    • 设置画布的尺寸和样式。
    • 绘制棋盘。
  2. 管理游戏状态

    • 创建数据结构来存储棋盘的状态。
    • 定义玩家顺序和当前玩家。
    • 管理游戏是否结束。
  3. 玩家交互

    • 监听鼠标点击事件。
    • 计算点击位置对应的棋盘坐标。
    • 验证点击位置是否合法。
    • 更新棋盘状态,并绘制棋子。
  4. 电脑AI

    • 实现简单的AI算法,如随机选择落子位置。
    • 更新棋盘状态,并绘制棋子。
  5. 胜负判定

    • 检查是否有玩家获胜。
    • 如果有玩家获胜,则显示胜利消息,并提供重新开始游戏的选项。
  6. 游戏控制

    • 提供重新开始游戏的功能。
    • 清除画布,重置游戏状态。

代码剖析:

1. 初始化游戏界面
// 获取画布元素
const canvas = document.getElementById('board');
const context = canvas.getContext('2d');// 设置画布尺寸
canvas.width = 450; // 15格 * 30px每格 + 15px边距
canvas.height = 450; // 同上// 定义棋盘格子的大小
const gridSize = 30;
const boardSize = 15;// 绘制棋盘
function drawBoard() {context.strokeStyle = '#000';context.lineWidth = 1;// 绘制垂直线for (let i = 0; i <= boardSize; i++) {context.beginPath();context.moveTo(15 + i * gridSize, 15); // 增加15px边距context.lineTo(15 + i * gridSize, boardSize * gridSize + 15); // 增加15px边距context.stroke();}// 绘制水平线for (let i = 0; i <= boardSize; i++) {context.beginPath();context.moveTo(15, 15 + i * gridSize); // 增加15px边距context.lineTo(boardSize * gridSize + 15, 15 + i * gridSize); // 增加15px边距context.stroke();}
}// 调用绘制函数
drawBoard();
2. 管理游戏状态
// 创建数据结构来存储棋盘的状态
let board = Array.from({length: boardSize}, () => Array(boardSize).fill(null));// 定义玩家顺序和当前玩家
let currentPlayer = 'black';// 游戏是否结束
let gameEnded = false;// 重置游戏
function resetGame() {board = Array.from({length: boardSize}, () => Array(boardSize).fill(null));currentPlayer = 'black';gameEnded = false;context.clearRect(0, 0, canvas.width, canvas.height);drawBoard();
}
3. 玩家交互
// 添加鼠标点击事件监听器
canvas.addEventListener('click', (event) => {if (!gameEnded && currentPlayer === 'black') { // 只有在游戏未结束且当前玩家是黑方时才允许点击const x = Math.floor((event.offsetX - 15) / gridSize); // 减去15px边距const y = Math.floor((event.offsetY - 15) / gridSize); // 减去15px边距if (board[x][y] === null) {drawChess(x * gridSize + 15, y * gridSize + 15, currentPlayer); // 加上15px边距board[x][y] = currentPlayer;if (checkWin(x, y, currentPlayer)) {gameEnded = true;} else {currentPlayer = 'white'; // 切换到白方computerMove(); // 电脑自动下棋}}}
});// 绘制棋子
function drawChess(x, y, color) {context.fillStyle = color;context.beginPath();context.arc(x, y, 13, 0, Math.PI * 2, false);context.fill();
}// 检查是否有五个连续的棋子
function checkWin(x, y, player) {// 这里可以实现一个简单的检查方法// 例如,检查行、列、对角线上是否有五个连续的棋子// 本例中省略具体实现return false;
}
4. 电脑AI
// 电脑自动下棋
function computerMove() {if (!gameEnded && currentPlayer === 'white') {let bestMove = findBestMove();if (bestMove) {drawChess(bestMove.x * gridSize + 15, bestMove.y * gridSize + 15, currentPlayer); // 加上15px边距board[bestMove.x][bestMove.y] = currentPlayer;if (checkWin(bestMove.x, bestMove.y, currentPlayer)) {gameEnded = true;} else {currentPlayer = 'black'; // 切换到黑方}}}
}// 找到最佳移动位置
function findBestMove() {// 简单的随机选择一个空位const availableMoves = [];for (let x = 0; x < boardSize; x++) {for (let y = 0; y < boardSize; y++) {if (board[x][y] === null) {availableMoves.push({x, y});}}}return availableMoves[Math.floor(Math.random() * availableMoves.length)];
}
5. 胜负判定
// 检查是否有五个连续的棋子
function checkWin(x, y, player) {// 检查行let count = 1;for (let i = 1; i < 5; i++) {if (x - i >= 0 && board[x - i][y] === player) count++;if (x + i < boardSize && board[x + i][y] === player) count++;}// 检查列for (let i = 1; i < 5; i++) {if (y - i >= 0 && board[x][y - i] === player) count++;if (y + i < boardSize && board[x][y + i] === player) count++;}// 检查正对角线for (let i = 1; i < 5; i++) {if (x - i >= 0 && y - i >= 0 && board[x - i][y - i] === player) count++;if (x + i < boardSize && y + i < boardSize && board[x + i][y + i] === player) count++;}// 检查反对角线for (let i = 1; i < 5; i++) {if (x - i >= 0 && y + i < boardSize && board[x - i][y + i] === player) count++;if (x + i < boardSize && y - i >= 0 && board[x + i][y - i] === player) count++;}return count >= 5;
}
6. 游戏控制
// 胜利消息
function showVictoryMessage(player) {alert(`玩家 ${player} 获胜!`);resetGame();
}

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

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

相关文章

GIS应用水平考试一级真题和答案分享~

2012年-2018年完整真题和答案 GIS应用水平考试资料分享https://docs.qq.com/doc/DRmxxaVhpbGJXSGho?u5295a88d71d8480d971da4e3334ee913

ES高级查询Query DSL查询详解、term术语级别查询、全文检索、highlight高亮

文章目录 ES高级查询Query DSLmatch_all返回源数据_source返回指定条数size分页查询from&size指定字段排序sort 术语级别查询term query术语查询terms query多术语查询range query范围查询exists queryids queryprefix query前缀查询wildcard query通配符查询fuzzy query模…

可视化大屏-实现自动滚动

一、背景&#xff1a;可视化大屏通常需要用到自动滚动的效果&#xff0c;本文主要采用的是vue-seamless-scroll组件来实现&#xff08;可参考官方文档&#xff09; 二、实现效果&#xff1a; 自动滚动 三、代码实现&#xff1a; 解题思路&#xff1a; 1.先安装依赖包 npm inst…

亲测解决Verifying shim SBAT data failed: Security Policy Violation

在小虎用u盘安装ubuntu系统的时候&#xff0c;笔记本出现了这个问题&#xff0c;解决方法是管关闭security boot。 解决方法 利用F2\F10\F12进入Bios设置&#xff0c;关闭security boot即可。 Use F2 to enter the bios security settings, close it. 参考 Verifying shim…

基于YOLOv8的船舶目标检测与分割(ONNX模型)

项目背景 需求分析&#xff1a;在海洋监控、港口管理、海事安全等领域&#xff0c;自动化的船只检测与分割技术对于提高效率和安全性至关重要。技术选型&#xff1a;YOLOv8是YOLO系列的一个较新版本&#xff0c;以其速度快、准确率高而著称。使用ONNX&#xff08;Open Neural …

亲测好用,吐血整理 ChatGPT 3.5/4.0 新手使用手册~ 【2024年8月 更新】

废话不多说&#xff0c;直接分享正文~ 以下是小编为大家搜集到的最新的ChatGPT国内站&#xff0c;各有优缺点。 1、AI Plus&#xff08;稳定使用&#xff09; 推荐指数&#xff1a;⭐⭐⭐⭐⭐ yixiaai.com 该网站已经稳定运营了1年多了。2023年3月份第一批上线的网…

产品经理原型设计工具 Axure 的使用

原型设计工具 Axure 中文学习网&#xff1a;https://www.axure.com.cn/ 1、安装 2023年Axure RP9最新安装、汉化教程&#xff08;附带安装包下载&#xff09; 2、基本使用 Axure rp9入门图文教程——基操及介绍&#xff08;看完就能上手&#xff0c;人人都是产品经理&#x…

Thymeleaf+Bootstrap封装分页组件

效果 代码 templates/components/pagination.html <!doctype html> <html lang"zh-CN" xmlns:th"http://www.thymeleaf.org"> <body> <div class"d-flex justify-content-between align-items-center mb-3" th:fragment&…

【C++】string类:模拟实现(适合新手的手撕string)

上次介绍了标准库里的string类以及常用接口&#xff1a;【C】String类&#xff1a;标准库介绍-CSDN博客 本次就来亲自动手来模拟实现下 目录 一.基本结构 二.构造函数&#xff08;constructor&#xff09; 1.构造函数 2.拷贝构造 3.c_str() 三.析构函数&#xff08;destr…

linux PXE批量网络装机及Kickstart无人值守安装

目录 一、PXE基本概述 1.1 什么是PXE 1.2 PXE批量部署的优点 1.3 PXE部署的前置条件 二、部署PXE远程安装服务器 2.1 安装并启动TFTP服务 2.2 安装并启动DHCP服务 2.3 准备linux内核、初始化镜像文件 2.4 准备PXE引导程序 2.5 安装FTP服务&#xff0c;准备CentOS 7 安…

Solidworks 创建工程图纸,工程图纸不显示解决

当完成三维零件&#xff0c;制作工程图纸时&#xff0c;发现右侧“工程图图纸”不显示了&#xff0c;不能像以前那样方便的拖拽了。如下图&#xff1a; 解决办法&#xff1a; 步骤1:点击这 ...&#xff0c;打开需要的三维图文件&#xff0c;如“公头主体” 步骤2&#xff1a;…

VisualStudio|开发环境相关技巧及问题

哈喽&#xff0c;你好啊&#xff0c;我是雷工&#xff01; 本节继续学习VisualStudio相关内容&#xff0c;以前学习都是以能用为主&#xff0c;没有系统的学习&#xff0c;接下来会系统的学习相关内容&#xff0c; 以下为学习笔记。 01 第三方dll调用 ①&#xff1a;如果第三…

希尔排序

希尔排序是直接排序的优化版本。 希尔排序是将庞大的数据进行分组&#xff0c;通过定义一个gap值&#xff0c;将数组里面间隔为这个gap值的元素分在一个小组里面&#xff0c;把每个小组通过插入排序的方式分别排成有序 在一组组排成有序的这个过程中&#xff0c;原来无序的数…

快速上手体验MyPerf4J监控springboot应用(docker版快速开始-本地版)

使用MyPerf4J监控springboot应用 快速启动influxdb时序数据库日志收集器telegrafgrafana可视化界面安装最终效果 项目地址 项目简介: 一个针对高并发、低延迟应用设计的高性能 Java 性能监控和统计工具。 价值 快速定位性能瓶颈快速定位故障原因 快速启动 监控本地应用 idea配…

M8020A J-BERT 高性能比特误码率测试仪

M8020A 比特误码率测试仪 J-BERT M8020A 高性能 BERT 产品综述 Keysight J-BERT M8020A 高性能比特误码率测试仪能够快速、准确地表征传输速率高达 16 或 32 Gb/s 的单通道和多通道器件中的接收机。 M8020A 综合了更广泛的功能&#xff0c;可以简化您的测试系统。 自动对信…

qiankun微前端

qiankun微前端 主项目1、安装qiankun2、main.js引入注册 二、子项目1、安装sh-winter/vite-plugin-qiankun2、main.js配置3、vite.config.js配置 三、问题解决四、一键启动 主项目 1、安装qiankun npm i qiankun -S2、main.js引入注册 import { createApp } from vue import…

健身房管理系统--论文pf

TOC springboot542健身房管理系统--论文pf 第1章 绪论 1.1选题动因 当前的网络技术&#xff0c;软件技术等都具备成熟的理论基础&#xff0c;市场上也出现各种技术开发的软件&#xff0c;这些软件都被用于各个领域&#xff0c;包括生活和工作的领域。随着电脑和笔记本的广泛…

C语言之字节对齐

目录 1. 引言2.字节对齐原理3.字节对齐应用4.总结 1. 引言 字节对齐属于编译器的内容&#xff0c;决定数据实际的存放方式。主要有两个作用&#xff1a;1.优化数据储存&#xff0c;减少空间浪费 2.增加数据读取速率&#xff0c;本文将于以上两点展开&#xff0c;简述字节对齐的…

VLM调研记录

Visual Autoregressive Modeling: Scalable Image Generation via Next-Scale Prediction 北大和字节团队的一篇VLM&#xff0c;在生成任务上&#xff0c;用GPT范式&#xff0c;声称在FID上超过了DIT&#xff0c;SD3和SORA。开源。首先是multi-scale的VQVAE&#xff0c;然后是…

一起学习LeetCode热题100道(52/100)

52.腐烂的橘子(学习) 在给定的 m x n 网格 grid 中&#xff0c;每个单元格可以有以下三个值之一&#xff1a; 值 0 代表空单元格&#xff1b; 值 1 代表新鲜橘子&#xff1b; 值 2 代表腐烂的橘子。 每分钟&#xff0c;腐烂的橘子 周围 4 个方向上相邻 的新鲜橘子都会腐烂。 返…