下载安卓APP箭头
箭头给我发消息

客服QQ:3315713922

贪食蛇小游戏开发设计基础教程

作者:课课家教育     来源: http://www.kokojia.com点击数:972发布时间: 2016-04-03 08:00:26

标签: 小游戏开发游戏设计游戏设计教程

   贪吃蛇是家喻户晓的益智类小游戏,大家小时候应该都有玩过,课课家这里就不多介绍了,本教程将教你用MicrosoftVisualC++来制作它。

   要求如下:

  (1)应用MFC单文档制作

  (2)能够记录游戏时间,游戏成绩

  (3)可暂停/继续并在玩家不愿游戏时停止游戏

  (4)蛇的身体能够随着蛇的长度变色

  (5)能够显示英雄榜

  (6)有背景音乐和音效

  1、关于编译软件

  本程序采用MicrosoftVisualC++6.0的英文版本进行编译。VisualC++6.0是Microsoft公司推出的基于Windows操作系统的可视化C++编程工具,尽管Microsoft公司推出了.NET平台的集成开发环境,但由于其良好的界面和可操作性,加上支持标准C/C++规范,但仍有相当多的编程人员使用VisualC++6.0进行应用系统的开发。

  2、关于兼容性

  本程序经过调试,可以在XP系统下编译运行,也可以在Vista下运行,界面稍有不同,但不影响运行结果。

  3、程序结构

  根据分析,贪吃蛇这个程序一共要实现如下几个功能,包括游戏方面开始游戏、暂停游戏以及停止游戏,音乐音效的添加与控制,游戏帮助提示与英雄榜的显示等等。具体的程序结构如下面的图1-1所示。

贪食蛇小游戏开发设计基础教程_小游戏开发_游戏设计_游戏设计教程_课课家

  图2-1贪吃蛇结构图

  4、程序流程

  根据分析后的贪吃蛇结构设计出相应的贪吃蛇流程。贪吃蛇的内容主要包括:游戏开始,随机-2-

  出现食物;按下ToolBar中的暂停按钮或Space键可以实现暂停功能;按下帮助键或ToolBar中的“?”键可获得游戏帮助说明;可播放背景音乐和音效并可通过菜单以及ToolBar控制其播放或停止等等。

  图2-2贪吃蛇流程图

    5、变量函数及资源的声明

  根据程序的结构,将贪吃蛇需要实现的功能细化成为相应的函数。

  函数声明

 

  变量声明

  6、资源

  (1)对话框

  (2)音乐

  (3)位图

  (4)菜单/工具栏

  (5)头文件

  7、主要功能的实现

  (1)游戏界面

  贪吃蛇游戏的游戏界面包括背景图片、蛇身体的绘制、蛇移动范围的绘制等等。其中贪吃蛇的身体用什么方法绘制,才可以使得其在游戏过程中可以实现“吃”的功能是很重要的。因此在游戏界面的初始绘制时就必须考虑到游戏时可能遇到的问题。

  本程序采用点数组CArray<CPoint,CPoint>m_ysBody来存储贪吃蛇,点数组的功能很强大,可以添加点,同时可以获得蛇的长度,对于而后进行游戏中控制蛇的颜色以及音效的播放等都有很大的帮助。

  导入位图以及菜单工具条后,游戏未开始前(XP系统下)的界面显示如图3-1所示。

  图3-1游戏初始界面显示

  (2)初始化食物

  确定用点数组存储贪吃蛇以后,贪吃蛇的食物如何达到随机出现,并且能够按照网格式与蛇头无偏差相接就是一个亟待解决的问题。

  随机出现应采用rand()函数来实现,而食物与蛇头无偏差相接则利用坐标来解决。设置两个整型变量m_ysX,m_ysY作为食物出现的点的坐标,令m_ysX=rand()%30,,m_ysY=rand()%40即可。使随机出现的点能够整除最小网格,也就是使食物与蛇头无偏差相接。

  再由食物坐标(m_ysX,m_ysY)与蛇头坐标是否相同判断蛇是否“吃”到了食物,设置判断标签ysTag,如果吃到了,ysTag为1,则再出现下一个食物,反之,如果没吃到,则不出现食物直到标签为1为止。

  最后,再将(m_ysX,m_ysY)赋给m_ysFood作为食物坐标,以便在其他函数中调用。在下面的图3-2中,我们可以看到,蛇的身体是与出现的食物在一条直线上的,完全可以达到相接的目的。

  图3-2蛇与食物的相接

  (3)开始游戏

  开始游戏后的重点是如何用键盘来控制蛇的移动并传递到OnTimer(UINTnIDEvent)函数中去以及判断蛇是否死亡。首先说明键盘与蛇的响应,设置一个方向控制变量m_ysDirect,再添加OnKeyDown(UINTnChar,UINTnRepCnt,UINTnFlags)函数来实现键盘消息的传递,按下不同的键盘按键,m_ysDirect会相应的改变,再利用switch语句在OnTimer(UINTnIDEvent)函数中对坐标进行相应改变即可。如图3-3所示。

  

  图3-3键盘的上下左右键的效果

  其次来解释一下如何判断蛇的死亡,由于蛇的身体是由点坐标数组构成的,因此判断蛇是否死亡其本质就是判断蛇头的坐标是否与游戏边框相同或者蛇头坐标是否与蛇自己的身体相同。该过程也在OnTimer(UINTnIDEvent)函数中写入即可,设置一个判断死亡变量ysTag1,当按下向下键时,蛇纵坐标不断自加,此处仅以向下为例,具体程序如下:

  如果ysTag1为1,则说明蛇已经死亡,应当弹出对话框提示死亡,输出得分(如图3-4),同时还可以根据玩家的得分数相应的改变对话框中的话语(XP系统下)。

  

  图3-4贪吃蛇的死亡

 

  我们看到图3-4的蛇身体的颜色发生了变化,不再是初始状态的绿色,而是变为了蓝色,这是在OnDraw(CDC*pDC)函数中设置的,设置变量获取蛇身长度,随着长度的增加,蛇的颜色发生相应改变,最终会变为表示危险的红色。

  并且伴随着贪吃蛇挂掉,播放不同的音乐,如果高于70分,则放带有掌声鼓励的高分音乐的IDR_YS_HIGHSCORE,反之,则播放蛇被撞死的电子音乐IDR_YS_LOWSCORE。

  播放音乐的函数用包含在头文件mmsystem.h中的PlaySound函数。此外,游戏开始还需要计时、计分以及暂停等功能。这些功能都比较简单,游戏时间和分数分别用两个变量m_ysTime和m_ysScore来记录,应用pDC->TextOut函数来输出即可。至于暂停和继续的功能实现,只需要暂停和恢复计时器就可以了,实现暂停功能即KillTimer(1)并同时令控制暂停变量为m_yspausectrl为0即可。

  8、英雄榜

  很多游戏都有英雄榜这一个功能。贪吃蛇这个游戏也不例外,为了下一次开始新游戏的玩家也能够看到别人的成绩,所以采用文件来存储游戏记录。

  首先加入头文件fstream.h包含文件写入读出函数ifstream、ofstream。定义文件及变量存储成绩,将对话框中EditBox的变量设置成为对应类型。例如:

  上面所写的就是变量的传递,传递完毕后,对话框控件中就有了初值,可以正常显示分数。而后进行游戏相应等级的玩家成绩判断,如果玩家成绩与英雄榜成绩相同,则根据时间来判断,若游戏时间短,则进入英雄榜。判断条件如下:

  (m_ysScore>m_1bestscore||m_ysScore==m_1bestscore&&m_ysTime<m_1besttime)&&m_yslevelctrl==1本程序默认游戏结束即显示英雄榜,但玩家如果想在没有游戏时查看也可以点击菜单“帮助—〉英雄榜”查看。

  9、游戏设置

  这里的游戏设置主要是指游戏的等级以及音效音乐的播放控制。前面在变量声明中已经看到,关于这三个量,我们已经予以了定义,只需要在按下相应键盘或鼠标消息的时候,将变量值进行改变,再利用这些值控制相应功能的运行。以游戏音效为例,在按下菜单中的“游戏设置—〉音乐—〉音效开/关”后(即菜单消息voidCYuShuoView::OnYsEffect()),代码如下:

  其中在构造函数CYuShuoView::CYuShuoView()中已经将m_yseffectctrl的初值设置为1。m_yseffectctrl=1;//将音效控制变量改为1break;

  10、程序运行

  程序开始运行后会进入游戏界面,但是不会立即进行游戏,单击菜单的“开始”才会开始游戏。在游戏开始前,玩家可以根据自己的喜好,通过菜单或者工具栏设置游戏等级等。

  在游戏过程中,按下Space键就会暂停游戏,再按下Space键则会继续游戏。图4-1所显示的是XP系统下菜单的样式,以及单击菜单开始。

  (1)带有子菜单的菜单样式

  (2)单击开始菜单

  图4-1菜单样式及单击开始游戏

  开始游戏了,小蛇越来越长,颜色也有所不同了。颜色的改变预示着游戏的难度加大了,并且,不同的最终得分会产生不同的死亡评语。

  在前面的图3-4中显示了贪吃蛇死亡的样子,其中因为该局游戏得分比较低,因此得到的评语是“你才得了这么两分!”,而如果得分较高,就会得到更好的评语,最好的评语是“牛!”。

  图4-2所显示的是游戏开始后随着蛇长度的增加而变的颜色。

  (1)黄色

(2)红色

  图4-2蛇变颜色

  如果不太会玩贪吃蛇这款游戏,那么可以单击菜单“帮助—〉游戏说明”,或者单击工具条上的,寻求帮助。如图4-2所示。

  图4-3游戏说明

  如果你觉得自己实力很强想看看别人的成绩,那么可以单击英雄榜看看什么样。

  

  图4-4英雄榜样式

  11、错误调试与分析

  本程序由于经常调用Invalidate()函数重绘窗口,因此在游戏过程中频闪的非常严重。查阅了很多资料,双缓冲技术可以解决这个问题,但是如果采用双缓冲技术,暂时还不能克服背景的问题,因为在双缓冲技术的应用中,背景是被强制默认为颜色,而不是图片。

     以上是贪吃蛇小游戏设计的全过程,欢迎关注家家课“游戏开发”板块,还有更多的精彩教程。

赞(0)
踩(0)
分享到:
华为认证网络工程师 HCIE直播课视频教程