当前位置:文档之家› 操作系统实验报告(贪吃蛇游戏)

操作系统实验报告(贪吃蛇游戏)

南通大学计算机科学与技术学院操作系统试验报告书试验题目贪吃蛇游戏专业班级XXXXXX学生姓名XXXXX指导教师XXXX日期2017年6月主要内容(一)设计内容:在Windows 9x/2000/XP/ME操作系统下,使用VC、VB、Java或C等编程语言,采用多道程序设计技术编写一个游戏软件或解决一个简单的实际问题,要求设计一个两道以上的程序,可以是固定的2道程序、也可以是灵活的多道模式。

设计的内容可以是下面任选其一:(1)用多道程序技术实现一个游戏程序。

如大炮打飞机、赛车比赛等。

(2)用多道程序技术模拟客观世界中一个多任务实际问题的解决。

(二)设计要求:(1)本程序可运行在Windows 9x/2000/XP/ME操作系统下,可安装到任意路径下。

(2)采用多进程或多线程方式运行,尽量体现进程间的同步和互斥关系。

(3)经调试后程序能够正常运行,并体现多道程序的特点。

(三)实验目的:1.掌握进程和线程的概念。

2.掌握进程控制原语或进程控制系统调用的使用3.掌握多道程序设计的基本理论、方法和技术。

4.掌握相关语言进程控制的API函数的使用。

5.培养学生多道程序设计的能力。

6.培养学生团队合作的能力。

(四)实验的选择:用多道程序技术实现一个游戏程序。

游戏:《贪吃蛇》实验思想:1.首先制作游戏的窗体布局。

其中包括窗体的大小,位置,添加按钮组件,在窗体上面划定游戏区域等。

2.为按钮添加监听器,为开始按钮,结束按钮,键盘,还有游戏结束的时候的确定按钮.3.单击开始按钮,看到的效果是在游戏区域里面看到一个随机产生的食物,和蛇体。

产生随见事物使用Random类,随机定位一个游戏区域里面的方块,然后使用Graphrics可以定位到这个方块的坐标图上颜色,这样就产生了肉眼可见的食物。

关于蛇体,我们将蛇体的每个方块添加到集合里面,使用的是List,为什么不用数组,原因是数组的长度总是有限的,你不知道蛇体里面最终存放多少方格,而且数组比较繁琐。

我们将蛇体的每个方块另外创建一个类(蛇体的每个方格)snakeAct,包含成员变量方格的坐标,每个snakeAct对象实例就是一个方块,将这个对象添加到列表List中就好了,然后再用Graphics,循环画出列表中的每个对象,就成功的画出了蛇体。

设置蛇体的初始长度只有蛇头,并设置蛇头的初始位置为居中。

4.通过方向键设置蛇头的移动,定义move()方法,蛇头每移动一次位置就会变化到另外一个方块,对应的坐标x,y都是有相应的变化,例如按下UP键,坐标的变化就是,x不变,y减1。

5.蛇头可以运动只有面临的问题就是要吃食物,而吃食物的过程是在移动过程中,所以在move()方法中添加eat()方法,吃到食物的条件是蛇头的坐标和食物的坐标对应相等,蛇头吃到食物的过程就是将列表中没有吃到食物前的最后一个方格重新画一遍,这样列表的长度就加一,而列表中的对象就多了一个。

6.将食物添加到列表中之后,仍然只是蛇头可以移动,让蛇体跟着蛇头移动定义othermove ()方法,就是将蛇体的每个蛇块替换移动前的前一个蛇块的坐标,这样在移动只有,整个蛇体就可以移动了,othermove 方法也写在move ()方法里面,move ()方法写在键盘的监听方法里面。

7.撞墙的或者蛇头撞到自己的身体,可以再move ()方法里面进行预判,如果蛇头移动满足判定条件,才可以移动,若蛇头碰到墙壁或者自己的身体,弹出对话框,点击确定按钮,恢复初始化,清空列表。

(五)主函数流程图:开始游戏(六)详细设计:1.贪吃蛇的本体设计贪吃蛇的头部拥有一个坐标(x,y),蛇体有一个长度length,蛇有一个运动方向direct,故定义一个结构体如下:struct Snake{ int x,y;int len;int direct;}Snake[20];2.贪吃蛇食物设计贪吃蛇的食物有一个坐标(x,y),此食物有一个标志isfood,当isfood 为0时,表示食物还没被吃,为1时,表示被吃。

struct Food{ int x;int y;int isfood;}Food;(八)具体模块实现:#include <iostream>#include <cstdio>#include <cstdlib>#include <ctime>#include <conio.h>#include <cmath>#include <windows.h>using namespace std;HANDLE hout=GetStdHandle(STD_OUTPUT_HANDLE);COORD coord;void locate(int x,int y){coord.X=y;coord.Y=x;SetConsoleCursorPosition(hout,coord);};void hide(){CONSOLE_CURSOR_INFO cursor_info={1,0};SetConsoleCursorInfo(hout, &cursor_info);}double random(double start, double end){return start+(end-start)*rand()/(RAND_MAX + 1.0); }int m,n;struct node{int x,y;}snake[1000];int snake_length,dir;node food;int direct[4][2]={{-1,0},{1,0},{0,-1},{0,1}};void print_wall(){cout << " ";for (int i=1;i<=n;i++)cout << "-";cout << endl;for (int j=0;j<=m-1;j++){cout << "|";for (int i=1;i<=n;i++) cout << " ";cout << "|" << endl;}cout << " ";for (int i=1;i<=n;i++)cout << "-";}void print_snake(){locate(snake[0].x,snake[0].y);cout << "@";for (int i=1;i<=snake_length-1;i++){locate(snake[i].x,snake[i].y);cout << "*";}}bool is_correct(){if (snake[0].x==0 || snake[0].y==0 || snake[0].x==m+1 || snake[0].y==n+1) return false;for (int i=1;i<=snake_length-1;i++){if (snake[0].x==snake[i].x && snake[0].y==snake[i].y) return false;}return true;}bool print_food(){srand((unsigned)time(0));bool e;while (1){e=true;int i=(int) random(0,m)+1,j=(int) random(0,n)+1;food.x=i;food.y=j;for (int k=0;k<=snake_length-1;k++){if (snake[k].x==food.x && snake[k].y==food.y){e=false;break;}}if (e) break;}locate(food.x,food.y);cout << "$";return true;}bool go_ahead(){node temp;bool e=false;temp=snake[snake_length-1];for (int i=snake_length-1;i>=1;i--)snake[i]=snake[i-1];snake[0].x+=direct[dir][0];snake[0].y+=direct[dir][1];locate(snake[1].x,snake[1].y);cout << "*";if (snake[0].x==food.x && snake[0].y==food.y){snake_length++;e=true;snake[snake_length-1]=temp;}if (!e){locate(temp.x,temp.y);cout << " ";}elseprint_food();locate(snake[0].x,snake[0].y);cout << "@";if (!is_correct()){system("cls");cout << "You lose!" << endl << "Length: " << snake_length << endl; return false;}return true;}int main(){cout << "--------------------贪吃蛇---------------------" << endl;cout << "请先输入两个数,表示地图大小.要求长宽均不小于10." << endl;cout << "请注意窗口大小,以免发生错位.建议将窗口调为最大." << endl;cout << "再选择难度.请在1-10中输入1个数,1最简单,10则最难" << endl;cout << "然后进入游戏画面,以方向键控制方向.祝你游戏愉快!" << endl; cout << "-----------------------------------------------" << endl; cin >> m >> n;if (m<10 || n<10 || m>25 || n>40){cout << "ERROR" << endl;system("pause");return 0;}int hard;cin >> hard;if (hard<=0 || hard>100){cout << "ERROR" << endl;system("pause");return 0;}snake_length=5;clock_t a,b;char ch;double hard_len;for (int i=0;i<=4;i++){snake[i].x=1;snake[i].y=5-i;}dir=3;system("cls");hide();print_wall();print_food();print_snake();locate(m+2,0);cout << "Now length: ";while (1){hard_len=(double)snake_length/(double) (m*n);a=clock();while (1){b=clock();if (b-a>=(int)(400-30*hard)*(1-sqrt(hard_len))) break; }if (kbhit()){ch=getch();if (ch==-32){ch=getch();switch(ch){case 72:if (dir==2 || dir==3)dir=0;break;case 80:if (dir==2 || dir==3)dir=1;break;case 75:if (dir==0 || dir==1)dir=2;break;case 77:if (dir==0 || dir==1)dir=3;break;}}}if (!go_ahead()) break;locate(m+2,12);cout << snake_length;}system("pause");return 0;}(九)上机调适及运行结果:(十)参考文献:《C++程序设计教程》《操作系统》《数据结构》管致锦徐慧陈德裕清华大学出版社附(十一)分工总结1号:这次实验我负责做了游戏的全局框架,给组员分配了一些任务便于合作完成。

相关主题