C++ 一个有bug的贪吃蛇。。。。。。。。

C++    一个有bug的贪吃蛇。。。。。。。。

#include <graphics.h>
#include<Windows.h>
#include<Mmsystem.h>
#include<conio.h> 
#include<time.h> 
#include<stdio.h>
#include<easyx.h>
using namespace std;
#pragma warning(disable:4996)
#define WINDOW_LENGTH 640 //窗口长
#define WINDOW_WIDE 480 //串口宽
#define M_TOP 50 //地图左上顶点y坐标
#define M_LEFT 20 //地图左上顶点x坐标
#define M_BOTTOM WINDOW_WIDE-30 //地图右下顶点y坐标
#define M_RIGHT WINDOW_LENGTH-30 //地图右下顶点x坐标
#define SNAKE_UP 72 //蛇向上运动
#define SNAKE_DOWN 80 //蛇向下运动
#define SNAKE_LEFT 75 //蛇向左运动
#define SNAKE_RIGHT 77  //蛇向右运动
#define SNAKE_QUIT 27 //结束游戏ESC键
#define SNAKE_SPEED 500 //蛇运动速度
#define SNAKE_PAUSS 32 //蛇暂停运动typedef struct FOOD { //定义食物结构体int x;int y;int FOOD_LIVE;
}FOOD;typedef struct NODE { //定义蛇的节点int x;int y;NODE* PRE;NODE* NEXT;
}NODE;typedef struct SANKE { //定义一个蛇NODE* TAIL;NODE* HEAD;int NODES; //蛇的节数int DIRECTION; //蛇的运动方向int SANKE_LIVE; //存活状态
}SANKE;int score_ = 0;
FOOD f;
SANKE s;
int rank;
int t = 1;
int tt;
int biteSelf(); // 判断是否咬到了自己
int snake_life(); //蛇是否存活
void gameover(); //结束界面
int eatfood(); /食物
void score(); //分数
void time(); //时间
void meau(); //菜单
void initGAME(); //初始化游戏
void creatWINDOW(int x, int y); //创建窗口
void closeWINDOW(); //关闭窗口
void creatmap(); //创建地图
void creatfood(); //创建食物
void drawfood(); //画食物
void drawSANKE(); //画蛇
void initSANKE(); //创建蛇
void moveSANKE(); //移动蛇
void speed(); //调整速度
void playgame(); //开始游戏
int direction(int c); //判断操作方向是否与蛇的方向相同
void Data(); //保存分数
void ESC(); //esc结束
void upgrade(); //升级模式int main()
{while (t){meau();initGAME();playgame();closeWINDOW();}
}void initGAME()//进入游戏
{creatWINDOW(WINDOW_LENGTH, WINDOW_WIDE);creatmap();creatfood();initSANKE();score();f.FOOD_LIVE = 0;
}void creatWINDOW(int x, int y) {//创建窗口initgraph(WINDOW_LENGTH, WINDOW_WIDE);setbkcolor(RGB(166, 135, 100));cleardevice();
}void closeWINDOW() {//关闭窗口Data();getch();closegraph();
}void creatmap() {int i;setlinecolor(BLACK);rectangle(M_LEFT, M_TOP, M_RIGHT, M_BOTTOM);//画外边界线rectangle(M_LEFT - 10, M_TOP - 10, M_RIGHT + 10, M_BOTTOM + 10);//画内边界线for (i = M_LEFT; i <= M_RIGHT; i = i + 10)line(i, M_TOP, i, M_TOP - 10);for (i = M_TOP; i <= M_BOTTOM; i = i + 10)line(M_LEFT, i, M_LEFT - 10, i);for (i = M_LEFT; i <= M_RIGHT; i = i + 10)line(i, M_BOTTOM, i, M_BOTTOM + 10);for (i = M_TOP; i <= M_BOTTOM; i = i + 10)line(M_RIGHT, i, M_RIGHT + 10, i);
}void creatfood() {srand(time(0));int x, y;while (1) {x = rand() % (600 - 20 + 1) + 20;y = rand() % (440 - 50 + 1) + 50;if (x % 10 == 0 && y % 10 == 0) {f.x = x;f.y = y;break;}}f.FOOD_LIVE = 1;
}void drawfood() {setfillcolor(YELLOW);fillrectangle(f.x, f.y, f.x + 9, f.y + 9);
}void initSANKE() {s.HEAD = (NODE*)malloc(sizeof(NODE));s.TAIL = (NODE*)malloc(sizeof(NODE));s.HEAD->x = 30;//初始蛇头蛇尾s.HEAD->y = 400;s.TAIL->x = 30;s.TAIL->y = 410;s.HEAD->NEXT = s.TAIL;s.HEAD->PRE = NULL;s.TAIL->NEXT = NULL;s.TAIL->PRE = s.HEAD;s.DIRECTION = SNAKE_UP;s.NODES = 2;s.SANKE_LIVE = 1;
}void drawSANKE() {NODE* p;//指针p指向蛇的头部p = s.HEAD;while (p){if (p == s.HEAD)setfillcolor(BLUE);//蛇头为蓝色elsesetfillcolor(YELLOW);fillrectangle(p->x, p->y, p->x + 9, p->y + 9);p = p->NEXT;}
}int direction(int c) {//不是相反的方向,返回0.if (s.DIRECTION == SNAKE_DOWN && c == SNAKE_UP)return 1;else if (s.DIRECTION == SNAKE_UP && c == SNAKE_DOWN)return 1;else if (s.DIRECTION == SNAKE_LEFT && c == SNAKE_RIGHT)return 1;else if (s.DIRECTION == SNAKE_RIGHT && c == SNAKE_LEFT)return 1;elsereturn 0;
}void playgame() {int c;while (true) {if (f.FOOD_LIVE == 1)//若食物存在,则画出食物{drawfood();}if (f.FOOD_LIVE == 0)//若食物不存在,则生成食物{creatfood();drawfood();}if (snake_life() == 0)//若蛇死亡,游戏结束{gameover();closeWINDOW();break;}while (!kbhit())//当没有按键的时候{time();if (eatfood() == 1){creatfood();drawfood();}if (snake_life() == 0)//若蛇死亡,游戏结束{break;}moveSANKE();drawSANKE();if (tt)upgrade();speed();}while (kbhit())//当有按键的时候{c = getch();if (direction(c) == 0)//不是相反的方向{switch (c){case SNAKE_LEFT: s.DIRECTION = SNAKE_LEFT; break;case SNAKE_RIGHT: s.DIRECTION = SNAKE_RIGHT; break;case SNAKE_UP: s.DIRECTION = SNAKE_UP; break;case SNAKE_DOWN: s.DIRECTION = SNAKE_DOWN; break;case SNAKE_PAUSS:system("pause"); break;case SNAKE_QUIT:ESC();default:break;}}}}
}void ESC() {gameover();_getch();exit(0);
}void moveSANKE() {NODE* p;p = (NODE*)malloc(sizeof(NODE));clearrectangle(s.TAIL->x, s.TAIL->y, s.TAIL->x + 9, s.TAIL->y + 9);//清楚原来的蛇尾creatmap();//绘制地图p = s.TAIL;while (p->PRE != NULL){p->x = p->PRE->x;p->y = p->PRE->y;p = p->PRE;}switch (s.DIRECTION) {//蛇头变换方向case SNAKE_UP:s.HEAD->y -= 10; break;case SNAKE_LEFT:s.HEAD->x -= 10; break;case SNAKE_DOWN:s.HEAD->y += 10; break;case SNAKE_RIGHT:s.HEAD->x += 10; break;default:break;}
}void speed() {Sleep(rank);
}int snake_life() {int x, y;x = s.HEAD->x;y = s.HEAD->y;if (x < 20 || x > 600 || y > 440 || y < 50)//蛇头出界,蛇死亡s.SANKE_LIVE = 0;if (biteSelf() == 1)//蛇吃到自己蛇死亡s.SANKE_LIVE = 0;return s.SANKE_LIVE;
} //蛇是否存活void gameover() {int c, x;x = 1;//musicforgg();settextstyle(50, 0, _T("宋体"));settextcolor(BLUE);char s1[] = "你死掉了!!!";outtextxy(150, 200, s1);_getch();initgraph(WINDOW_LENGTH, WINDOW_WIDE);setbkcolor(BLACK);cleardevice();settextcolor(YELLOW);char s[] = "";sprintf(s, "%s%d", "您的分数是:", score_);char s3[] = "1.重新挑战";char s2[] = "2.退出游戏";settextstyle(30, 0, _T("宋体"));outtextxy(200, 200, s3);outtextxy(200, 250, s2);settextstyle(50, 0, _T("宋体"));outtextxy(150, 100, s);settextcolor(WHITE);char s5[] = "按任意键继续。。。";char s7[] = "输入有误。。。";char s8[] = "谢谢使用!";while (x) {kbhit();c = getch();switch (c) {case '1':t = 1; x = 0; outtextxy(150, 350, s5);score_ = 0; main(); break;//继续生成游戏case '2':outtextxy(150, 350, s8); getch(); exit(0);//退出游戏default:x = 1; outtextxy(150, 350, s7); break;}}
}//结束界面int eatfood() {int x1 = s.HEAD->x;int y1 = s.HEAD->y;int x2 = f.x;int y2 = f.y;NODE* p;if (x1 == x2 && y1 == y2)//蛇的头部和食物重叠{s.TAIL->NEXT = (NODE*)malloc(sizeof(NODE));//扩大蛇的长度s.TAIL->NEXT->x = s.TAIL->x;s.TAIL->NEXT->y = s.TAIL->y;s.TAIL->NEXT->PRE = s.TAIL;s.TAIL->NEXT->NEXT = NULL;p = s.TAIL->NEXT;s.TAIL = p;//尾部扩展s.NODES++;//蛇的长度+1f.FOOD_LIVE = 0;s.NODES++;f.x = 0 - f.x;score_ += 10;score();return 1;}elsereturn 0;
} /食物void score() {//记录分数char str[20];settextcolor(YELLOW);//颜色:灰色settextstyle(20, 0, _T("宋体"));//大小和字体sprintf(str, "得分:%d", score_);//生成字符串outtextxy(10, 20, str);
} //分数void time() {char str[20];char c[] = "提示:空格键暂停游戏,ESC键结束游戏。";time_t t;struct tm* lt;settextstyle(20, 0, _T("宋体"));//大小和字体time(&t);//获取Unix时间戳。lt = localtime(&t);//转为时间结构。sprintf(str, "时间:%2d:%2d:%2d", lt->tm_hour, lt->tm_min, lt->tm_sec);//生成字符串outtextxy(500, 20, str);outtextxy(100, 20, c);
}//时间void meau() {int c;int x;x = 1;initgraph(WINDOW_LENGTH, WINDOW_WIDE);setbkcolor(BLACK);cleardevice();settextstyle(50, 0, _T("宋体"));settextcolor(YELLOW);char s[] = "欢迎来到贪吃蛇!";outtextxy(170, 100, s);settextstyle(25, 0, _T("宋体"));char s1[] = "选择难度:";char s2[] = "1.简单模式";settextcolor(GREEN);outtextxy(250, 240, s2);char s3[] = "2.普通模式";settextcolor(BLUE);outtextxy(250, 280, s3);char s4[] = "3.困难模式";settextcolor(RED);outtextxy(250, 320, s4);char s7[] = "输入有误。。。";settextcolor(WHITE);char s5[] = "按任意键继续。。。";while (x){kbhit();c = getch();switch (c){case '1':rank = 300; x = 0; tt = 0;outtextxy(250, 390, s5);break;case '2':rank = 200; x = 0; tt = 0;outtextxy(250, 390, s5);break;case '3':rank = 80; x = 0; tt = 0;outtextxy(250, 390, s5);break;default:x = 1; outtextxy(250, 390, s7); break;}}_getch();
} //菜单
void upgrade() {}void __cdecl fprintf()
{
}int biteSelf() {NODE* self;self = s.HEAD->NEXT;while (self != NULL){if (self->x == s.HEAD->x && self->y == s.HEAD->y)//蛇身坐标与蛇头重合,判断蛇死亡{return 1;}self = self->NEXT;}return(0);
}void Data()
{FILE* pf = fopen("123.txt", "w"); //以只写的方式打开文件if (pf == NULL) //打开文件失败{printf("保存最高得分记录失败\n");exit(0);}fwrite(&score, sizeof(int), 1, pf); //将本局游戏得分写入文件当中fclose(pf); //关闭文件pf = NULL; //文件指针及时置空}

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

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

相关文章

【AI】计算机视觉VIT文章(Transformer)源码解析

论文&#xff1a;Dosovitskiy A, Beyer L, Kolesnikov A, et al. An image is worth 16x16 words: Transformers for image recognition at scale[J]. arXiv preprint arXiv:2010.11929, 2020 源码的Pytorch版&#xff1a;https://github.com/lucidrains/vit-pytorch 0.前言 …

Tinker 环境下数据表的用法

如果我们要自己手动创建一个模型文件&#xff0c;最简单的方式是通过 make:model 来创建。 php artisan make:model Article 删除模型文件 rm app/Models/Article.php 创建模型的同时顺便创建数据库迁移 php artisan make:model Article -m Eloquent 表命名约定 在该文件中&am…

WPF Button使用漂亮 控件模板ControlTemplate 按钮使用控制模板实例及源代码 设计一个具有圆角边框、鼠标悬停时颜色变化的按钮模板

续前两篇模板文章 模板介绍1 模板介绍2 WPF中的Button控件默认样式简洁&#xff0c;但可以通过设置模板来实现更丰富的视觉效果和交互体验。按钮模板主要包括背景、边框、内容&#xff08;通常为文本或图像&#xff09;等元素。通过自定义模板&#xff0c;我们可以改…

test perf-03-性能测试之 Gatling 使用入门官方教程

quick start 快速入门 学习 Gatling 的概念&#xff0c;使用录制器创建可运行的 Gatling 仿真。 介绍 在这一部分&#xff0c;我们将使用 Gatling 进行负载测试一个简单的云托管的 Web 服务器&#xff0c;并向您介绍 DSL&#xff08;领域特定语言&#xff09;的基本要素。 …

Flink1.17实战教程(第五篇:状态管理)

系列文章目录 Flink1.17实战教程&#xff08;第一篇&#xff1a;概念、部署、架构&#xff09; Flink1.17实战教程&#xff08;第二篇&#xff1a;DataStream API&#xff09; Flink1.17实战教程&#xff08;第三篇&#xff1a;时间和窗口&#xff09; Flink1.17实战教程&…

[Redis实战]优惠券秒杀

三、优惠券秒杀 3.1 全局唯一ID 每个店铺都可以发布优惠券&#xff1a; 当用户抢购时&#xff0c;就会生成订单并保存到tb_voucher_order这种表中&#xff0c;而订单表如果使用数据库自增ID就存在一些问题&#xff1a; id的规律性太明显受单表数据量的限制 场景分析一&…

【网络安全 | 扫描器】御剑安装及使用教程详析

御剑是一款传统的Web网络安全综合检测程序&#xff0c;支持对PHP、JSP、ASPX等文件进行扫描&#xff0c;具备全扫描、网络安全扫描和主机安全扫描能力&#xff0c;方便发现网站漏洞。 文章目录 下载使用教程 本文对御剑的安装及使用教程进行详析 下载 下载地址读者可自行上网…

无人职守自动安装linux操作系统

无人职守自动安装linux操作系统 1. 大规模部署案例2. PXE 技术3. Kickstart 技术4. 配置安装服务器4.1 DHCP服务4.2 TFTP 服务4.3 NFS服务 5. 示例5.1 搭建server1. 启动dhcp并设为开机自启2. 设置并启动tftp3. 将客户端所需启动文件复制到TFTP服务器4. 创建Kickstart自动应答文…

美国化妆品FDA认证被强制要求,出口企业该这么办!!!

化妆品FDA认证是进入美国市场的重要准入条件&#xff0c;具备该认证有助于提升产品的市场竞争力和信誉&#xff1b; 目前FDA注册系统已全面开放&#xff0c;从原来的自愿性认证变更为现在的强制性认证&#xff0c;化妆品企业合规日期为2023年12月29日&#xff0c;但是强制处罚…

C++day2作业

把课上strcut的练习&#xff0c;尝试着改成class #include <iostream>using namespace std; class Stu { private:int age;string sex;int hign; public:int soce;void get_information();void set_information(); }; void Stu::set_information() {static Stu s1;cout …

JAVA——JDBC学习

视频连接&#xff1a;https://www.bilibili.com/video/BV1sK411B71e/?spm_id_from333.337.search-card.all.click&vd_source619f8ed6df662d99db4b3673d1d3ddcb 《视频讲解很详细&#xff01;&#xff01;推荐》 JDBC&#xff08;Java DataBase Connectivity Java数据库连…

Flink1.17实战教程(第四篇:处理函数)

系列文章目录 Flink1.17实战教程&#xff08;第一篇&#xff1a;概念、部署、架构&#xff09; Flink1.17实战教程&#xff08;第二篇&#xff1a;DataStream API&#xff09; Flink1.17实战教程&#xff08;第三篇&#xff1a;时间和窗口&#xff09; Flink1.17实战教程&…