c语言mfc小游戏编程,课内资源 - 基于VC++的MFC类库实现的五子棋小游戏

2024-01-13 02:59

本文主要是介绍c语言mfc小游戏编程,课内资源 - 基于VC++的MFC类库实现的五子棋小游戏,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一、项目基本信息操作系统:Windows 10

开发环境:VS2017 和 MFC 框架

项目基本信息:通过 VS2017 的 MFC 框架编程编制五子棋程序,棋盘 19*19 大小, 执黑先行,黑白交替,当一方出现五个子连成一条线,即判断胜方,弹出消息框,显示胜方,可重新开始游戏

二、 项目基本结构

2.1 程序流程图

62de7e2ba586917daecdaa0ba7ec8389.png

2.2 数据结构// 棋子逻辑结点

structchesspoint{

intchesscolor;// 棋子颜色:1 黑色,-1 白色

boolchessuseflag;// 棋子是否被占用

intchessflag[8];// 棋子标志,一个棋子周围的 8 个位置,标识当前组成 的线段最大长度,0 号为左上角,顺时针计数

};

2.3 主要函数// 绘制棋盘背景

voidDrawBackground();

// 绘制棋子,绘制成功返回 1,失败返回-1

intDrawChessPoint();

// 规格化落子位置,正常返回 1,子越界返回-1,该位置已落子返回-2

intStandardPointPosition();

// 绘制一个特定颜色的棋子

voidDrawPoint(intcolor);

// 添加棋子(logic_x,logic_y)到棋子逻辑数组中,并动态更新棋子连线信息

voidAddChessPoint(intlogic_x,intlogic_y);

2.4 程序结构

程序结构主要分为以下几个部分:

2.4.1 菜单部分游戏(子菜单:19x19)——开始游戏

重新开始(子菜单:初始化)——初始化游戏(棋盘未绘制)

2.4.2 绘制棋盘部分(void DrawBackground())以(500, 500)为中心绘制 19x19 的棋盘,每个棋盘结点间距为 50,共 361 个结点

2.4.3 下子部分设置 blackplayflag、whiteplayflag 作为交替下子的标志位,一真一假, 完成下子后交替互换

设置 CPoint 类型的向量 player_black、player_white 存储鼠标左键下子 的坐标值,用 black_pointNum、white_pointNum、chess_pointNum 分别记录黑 子数,白子数,总棋子数

2.4.4 规格化下子位置部分(int StandardPointPosition())下子位置超出棋盘边界:删除添加的相应颜色的棋子,棋子数相应减一, 返回-1

将棋子位置化成(i*50,j*50)的形式,即下子位置若在某节点为中心, 50 为边长的正方形内时,下子位置更新为该节点位置(将下子位置划归到离散 有限点上),返回 1

由第二步可获得棋子的逻辑位置(i, j),使用自定义数据结构 chesspoint 的 一个 19x19 的数组 chess_logic 存储棋子的 逻辑信息( 在 void AddChessPoint(int logic_x, int logic_y) 函数中进行修改):

intchesscolor;// 棋子颜色:1 黑色,-1 白色

boolchessuseflag;// 棋子是否被占用

intchessflag[8];// 棋子标志

一个棋子周围的 8 个位置,标识当前组成的线段最大长度,0 号为左上角,顺时针计数。若(i, j)位置的 chessuseflag 标志位为 TRUE 则表明该位置已被占用,删除添加的相应颜色的棋子,棋子数相应减一,返回-2

添加棋子到棋子逻辑数组中,并动态更新棋子连线信息(void AddChessPoint(int logic_x, int logic_y))

设置相应 chesspoint 的结点信息:

intchesscolor;//棋子颜色:1 黑色,-1 白色

boolchessuseflag;//棋子是否被占用

intchessflag[8];//棋子标志,一个棋子周围的 8 个位置,标识当前 组成的线段最大长度,0 号为左上角,顺时针计数

动态更新每个逻辑棋子结点的 chessflag[8],用来标识当前连线长度。

以 0 号标志位(左上角)为例,当前棋子位置为(i, j),若(i-1, j-1)位置棋子的 chesscolor 与( i, j)一致,则 chess_logic[i][j].chessflag[0] = chess_logic[i-1][j-1].chessflag[0]+1(即左上方连线长度加一),否则, 置为 1,表示左上方连线长度为 1,其他方向相同。

利用 MFC 绘制特定颜色圆的方法绘制棋子

判断输赢部分;当棋子总数 chess_pointNum 大于 8 时( 即棋盘上至少有五个黑子, 4 个白子时), 开始对最后落下的子进行判断,检查其逻辑棋子中的 chessflag[8]部分,若有 一个大于等于 5,即说明有五个颜色相同的子连成直线,由该子的颜色断定胜利 的是黑方还是白方,弹出消息框

三、项目演示

选择游戏(19x19),开始游戏

d1636a9d598ba69738021109dffe7aab.png

开始下棋,简单演示

3a48d3bffe3fbb162f6c8264af8bc8e4.png

点击确定后

da9e7397d07834ba7dadfdfbbb4d341d.png

重新开始

6c9a42016adb3c31c97d39e9e2a57227.png

四、项目心得

经过本次项目编写,收获如下:

对 MFC 的框架编程更加熟练了,自己的编程能力也有了提升

在添加黑白棋子,绘制棋子的过程中发现了很多逻辑上的问题,通过不断检查调试,发现在重复绘制棋子的过程中绘制完成后没有返回,导致之前 绘制的被覆盖,出现了比较大的问题,通过解决这个问题,对于 MFC 的绘图有了比较深刻的理解

该项目的核心部分是判断哪一方胜利的算法的设计,最开始使用的是遍历算法,通过遍历每一条线,寻找相邻的五个颜色相同的棋子,发现算法思想简单,但时间空间复杂度较高,于是开始算法的改造,设计了特殊的数 据结构 chesspoint,通过动态更新棋子标志位的方法将棋子的连线信息 存储在标志位中,使得遍历寻找的过程变成了查看当前棋子的标志位是否有等于 5 的判断,使得算法的时间复杂度下降,理解起来也比较容易,这样的思考过程对自己的提升也很大

这篇关于c语言mfc小游戏编程,课内资源 - 基于VC++的MFC类库实现的五子棋小游戏的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/600025

相关文章

pytorch自动求梯度autograd的实现

《pytorch自动求梯度autograd的实现》autograd是一个自动微分引擎,它可以自动计算张量的梯度,本文主要介绍了pytorch自动求梯度autograd的实现,具有一定的参考价值,感兴趣... autograd是pytorch构建神经网络的核心。在 PyTorch 中,结合以下代码例子,当你

SpringBoot集成Milvus实现数据增删改查功能

《SpringBoot集成Milvus实现数据增删改查功能》milvus支持的语言比较多,支持python,Java,Go,node等开发语言,本文主要介绍如何使用Java语言,采用springboo... 目录1、Milvus基本概念2、添加maven依赖3、配置yml文件4、创建MilvusClient

JS+HTML实现在线图片水印添加工具

《JS+HTML实现在线图片水印添加工具》在社交媒体和内容创作日益频繁的今天,如何保护原创内容、展示品牌身份成了一个不得不面对的问题,本文将实现一个完全基于HTML+CSS构建的现代化图片水印在线工具... 目录概述功能亮点使用方法技术解析延伸思考运行效果项目源码下载总结概述在社交媒体和内容创作日益频繁的

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

OpenCV图像形态学的实现

《OpenCV图像形态学的实现》本文主要介绍了OpenCV图像形态学的实现,包括腐蚀、膨胀、开运算、闭运算、梯度运算、顶帽运算和黑帽运算,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起... 目录一、图像形态学简介二、腐蚀(Erosion)1. 原理2. OpenCV 实现三、膨胀China编程(

通过Spring层面进行事务回滚的实现

《通过Spring层面进行事务回滚的实现》本文主要介绍了通过Spring层面进行事务回滚的实现,包括声明式事务和编程式事务,具有一定的参考价值,感兴趣的可以了解一下... 目录声明式事务回滚:1. 基础注解配置2. 指定回滚异常类型3. ​不回滚特殊场景编程式事务回滚:1. ​使用 TransactionT

Android实现打开本地pdf文件的两种方式

《Android实现打开本地pdf文件的两种方式》在现代应用中,PDF格式因其跨平台、稳定性好、展示内容一致等特点,在Android平台上,如何高效地打开本地PDF文件,不仅关系到用户体验,也直接影响... 目录一、项目概述二、相关知识2.1 PDF文件基本概述2.2 android 文件访问与存储权限2.

使用Python实现全能手机虚拟键盘的示例代码

《使用Python实现全能手机虚拟键盘的示例代码》在数字化办公时代,你是否遇到过这样的场景:会议室投影电脑突然键盘失灵、躺在沙发上想远程控制书房电脑、或者需要给长辈远程协助操作?今天我要分享的Pyth... 目录一、项目概述:不止于键盘的远程控制方案1.1 创新价值1.2 技术栈全景二、需求实现步骤一、需求