《贪吃蛇C语言课程设计报告(共8页).doc》由会员分享,可在线阅读,更多相关《贪吃蛇C语言课程设计报告(共8页).doc(8页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。
1、精选优质文档-倾情为你奉上贪吃蛇游戏设计姓名: 张力学号: 完成日期: 月 日一、设计目的贪吃蛇游戏程序功能的实现主要是建立在二维数组和图形界面的应用上,通过编写游戏程序能够熟悉掌握相关数组和图形函数的运用,提高编程水平,增加编程的兴趣二、总体设计 主函数 图形驱动Init 画界面DrawK 游戏具体过程GamePlay 图形结束Close 游戏结束GameOver 输出成绩PrScore 三、详细设计(项目成员及分工、模块功能说明(如函数功能、入口及出口参数说明,函数调用关系描述等) 主函数main(): 定义使用的常数,全局变量及函数原型说明,并调用Init()函数初始化图形系统;然后调用
2、DrawK()函数画界面,调用GamePlay()函数实现游戏的具体过程,游戏结束后调用Close()函数关闭图形系统结束程序。画界面函数DrawK():主界面是一个密封的围墙,用两个循环语句分别在水平方向和垂直方向输出连续的宽度和高度均为10个单位的矩形小方块,设置成淡青色,背景颜色为黑色。游戏具体过程函数GamePlay():算法过程:a. 设置初始值。为防止食物出现在一个位置上,要设置随机数发生器,真正产生随机数。初始时,蛇只有蛇头,设定一个开始方向;b. 循环执行,直到按Esc键退出;c. 没有按键的情况下,循环执行。 如果没有食物,随机出现食物;食物的随机出现要确保它的位置在10的倍
3、数位置上,因为蛇的坐标都是以10为模的;如果有食物,则显示食物,蛇移动身体,根据蛇的方向改变坐标值,并判断蛇是否撞到了墙或自己吃到了自己,如果出现这两种情况之一,则蛇死;调用游戏结束函数GamePlay(),结束本次游戏;判断蛇吃到食物的方法是蛇头的坐标和食物的坐标都相等;如果蛇吃到了食物,蛇身体长一节,数组元素增加一个,身体节数、分数都进行相应的改变。在新位置画出蛇。采用的方法是每次移动的时候从最后一节开始到倒数第二节,将前一节的坐标赋值给后一节的坐标,移动后只要把最后一节用背景色去除即可。D.如果有按键,则识别按键值。如果按键为Esc键则结束游戏,程序运行结束;如果所按键为方向键,则根据该
4、键改变蛇方向的变量direction的值,相反方向键无效。游戏结束函数GameOver():游戏结束,清除屏幕,调用输出分数函数PrScore(),并显示游戏结束。输出分数函数PrScore():在指定位置利用sprintf()将整数转换为字符串,用outtextxy()输出,、bar()函数的应用是为了覆盖原来的值。图形结束函数Close():在显示游戏结束信息的画面时,按任意键关闭图形系统,程序结束。 四、 调试与测试:调试方法,测试结果的分析与讨论,测试过程中遇到的主要问题和采取的解决措施等; 将源文件在TC3.0环境下调试运行,前期发现错误为游戏界面静止。五、 源程序清单及执行结果:#
5、include#include#include#include#include#include#define LEFT 0x4b00#define RIGHT 0x4d00#define DOWN 0x5000#define UP 0x4800#define Esc 0x011b#define N 200/*定义全局变量*/int i,key;int score=0;/*得分*/int gamespeed=50000;/*游戏速度可以自己调整*/struct Foodint x;/*定义食物的横坐标*/int y;/*定义食物的纵坐标*/int yes;/*判断是否要出现食物的变量*/food
6、;/*食物的结构体*/struct snakeint xN;int yN;int node;/*蛇的节数*/int direction;/*蛇的移动方向*/int life;/*蛇的生命,0活着,1死亡*/snake;void Init(void);/*图形驱动*/void Close(void);/*图形结束*/void DrawK(void);/*开始画面*/void GameOver(void);/*结束游戏*/void GamePlay(void);/*玩游戏的具体过程*/void PrScore(void);/*输出成绩*/*图形驱动*/void Init(void)int gdri
7、ver=DETECT,gmode; initgraph(&gdriver,&gmode,D:TC30LIB);/*开始画面,左上角坐标为(50,40),右下角坐标为(610,460)的围墙*/void DrawK(void)setbkcolor(LIGHTGREEN);setcolor(11);setlinestyle(SOLID_LINE,0,THICK_WIDTH);/*设置线型*/for(i=50;i=600;i+=10)/*画围墙*/rectangle(i,40,i+10,49);/*上边*/rectangle(i,451,i+10,460);/*下边*/for(i=40;i0;i-)
8、/*蛇一个节一个节地往前移*/ snake.xi=snake.xi-1; snake.yi=snake.yi-1; /*1,2,3,4表示右左上下四个方向,通过判断这个来移动蛇头*/ switch(snake.direction) case 1:snake.x0+=10;break; case 2:snake.x0-=10;break; case 3:snake.y0-=10;break; case 4:snake.y0+=10;break; /*从蛇的第四节开始判断蛇有没有自己把自己吃掉*/ for(i=3;isnake.node;i+) if(snake.xi=snake.x0&snake
9、.yi=snake.y0) GameOver();/*显示游戏结束*/ snake.life=1;/*蛇死了T T!*/ break; If(snake.x0595|snake.y0455)/*判断蛇是否撞到墙*/ GameOver();/*游戏结束*/ snake.life=1;/*蛇死了T T!*/ if(snake.life=1)/*如果蛇死了就跳出内循环,重新开始*/ break; if(snake.x0=food.x&snake.y0=food.y)/*吃掉食物啦!*/ setcolor(0);/*把画面上的食物颜色覆盖掉*/ rectangle(food.x,food.y,food
10、.x+10,food.y-10); snake.xsnake.node=-20; snake.ysnake.node=-20; /*新的一节先放在看不见的位置,下次循环就取前一节的位置*/ snake.node+;/*蛇的身体长一节*/ food.yes=1;/*画面上需要出现新的食物*/ score+=10;/*加十分!*/ PrScore();/*输出新得分*/ setcolor(4);/*画出蛇*/ for(i=0;isnake.node;i+)rectangle(snake.xi,snake.yi,snake.xi+10,snake.yi-10); delay(gamespeed);
11、setcolor(0);/*用黑色去除蛇的最后一节*/ rectangle(snake.xsnake.node-1,snake.ysnake.node-1,snake.xsnake.node-1+10,snake.ysnake.node-1-10);/*endwhile(!kbhit)*/if(snake.life=1)/*如果蛇死了就跳出循环*/break;key=bioskey(0);/*接收按键*/if(key=Esc)/*按Esc键退出*/break;else if(key=UP&snake.direction!=4)/*判断是否往相反方向移动*/snake.direction=3;e
12、lse if(key=RIGHT&snake.direction!=2)snake.direction=1;else if(key=LEFT&snake.direction!=1)snake.direction=2;else if(key=DOWN&snake.direction!=3)snake.direction=4;/*endwhile(1)*/*游戏结束*/void GameOver(void)cleardevice();/*清除屏幕*/PrScore();/*输出得分*/setcolor(RED);settextstyle(0, 0,4);outtextxy(200,200,GAME
13、 OVER);/*显示游戏结束*/getch();void PrScore(void)/*输出成绩*/char str10;setfillstyle(SOLID_FILL,YELLOW);bar(50,15,220,35);setcolor(6);settextstyle(0,0,2);sprintf(str,score:%d,score);outtextxy(55,20,str);void Close(void)/*图形结束*/getch();closegraph();void main(void)/*主函数*/Init();DrawK();GamePlay();Close();专心-专注-专业