当前位置: 首页 > news >正文

C语言搭配EasyX实现贪吃蛇小游戏

封面展示

内部展示

完整代码

#define _CRT_SECURE_NO_WARNINGS
#include<easyx.h>
#include<stdio.h>
#include<mmsystem.h>
#pragma comment (lib,"winmm.lib")
#define width 40//宽有40个格子
#define height 30//长有40个格子
#define size 25//每个正方形格子的边长为20
int snack[width][height] = { 0 };//蛇
char direction='w';//初始方向向上
int foodx, foody;//食物刷新位置
int isover = 0;//游戏是否结束
int result = 0;//得分
int speed = 5;//速度
int maxscore;//历史最高分
char title1[] = "开始游戏",title2[] = "退出游戏",title3[] = "查看历史最高分",title4[] = "游戏帮助",title5[]="选择难度模式";//主页文字
int x = width * size / 2, y = height * size / 2;//提前用于文字居中
void getmaxscore();//获得历史最高分
void Remembermaxscore();//记住最高分
void menu();//菜单
void choose();//选择指令
void choosespeed();//选择蛇的移动速度
void Look_maxscore();//查看最高分,重新打印封面
void BGM();//这么刺激的游戏,没有点音乐可不行
void game();//游戏实现
void gamehelp();//游戏帮助
void gamemap();//绘制游戏地图
void Initialize();//绘制初始蛇以及食物
void draw();//每次蛇不同,重新绘制
void movespeed();//控制蛇的移动速度
void operate();//控制蛇的操作
void move();//蛇的运动
int main()
{getmaxscore();initgraph(width * size, height * size);//地图尺寸choose();return 0;
}
void getmaxscore()
{FILE* fp = fopen("历史最高分.txt", "r");fscanf(fp, "%d", &maxscore);fclose(fp);
}
void Remembermaxscore()
{if (result > maxscore){FILE* fp = fopen("历史最高分.txt", "w");fprintf(fp, "%d", result);fclose(fp);}}
void menu()
{IMAGE img;loadimage(&img, "./贪吃蛇封面.jpg", width * size, height * size);putimage(0, 0, &img);setfillcolor(YELLOW);setlinecolor(BLACK);setbkmode(TRANSPARENT);settextstyle(20, 0, "黑体");settextcolor(BLACK);fillrectangle(x - 100, y - 60, x + 100, y - 20);//打印四个按钮,按钮居中outtextxy(x - 100 + (200 - textwidth(title1))/2, y - 60 + (40 - textheight(title1))/2, title1);fillrectangle(x - 100, y - 20, x + 100, y + 20);outtextxy(x - 100 + (200 - textwidth(title2)) / 2, y - 20 + (40 - textheight(title2)) / 2, title2);fillrectangle(x - 100, y + 20, x + 100, y + 60);outtextxy(x - 100 + (200 - textwidth(title3)) / 2, y + 20 + (40 - textheight(title3)) / 2, title3);fillrectangle(x - 100, y + 60, x + 100, y + 100);outtextxy(x - 100 + (200 - textwidth(title4)) / 2, y + 60 + (40 - textheight(title4)) / 2, title4);fillrectangle(x - 100, y + 100, x + 100, y + 140);outtextxy(x - 100 + (200 - textwidth(title5)) / 2, y + 100 + (40 - textheight(title5)) / 2, title5);
}
void choose()
{menu();int f = 0;while (1){ExMessage msg;if (f) break;while (peekmessage(&msg, EX_MOUSE)){switch (msg.message){case WM_LBUTTONDOWN:if (msg.x > x - 100 && msg.x<x + 100 && msg.y>y - 60 && msg.y < y - 20){game();menu();}else if (msg.x > x - 100 && msg.x<x + 100 && msg.y>y - 20 && msg.y < y + 20)f = 1;else if (msg.x > x - 100 && msg.x<x + 100 && msg.y>y + 20 && msg.y < y + 60){Look_maxscore();menu();}else if (msg.x > x - 100 && msg.x<x + 100 && msg.y>y + 60 && msg.y < y + 100){gamehelp();menu();}else if (msg.x > x - 100 && msg.x<x + 100 && msg.y>y + 100 && msg.y < y + 140){choosespeed();menu();}break;default:break;}}}
}
void choosespeed()
{IMAGE img;loadimage(&img, "./01.jpg", width * size, height * size);putimage(0, 0, &img);char back[] = "<<===";settextstyle(30, 0, "宋体");setfillcolor(BROWN);fillrectangle(10, 10, 100, 50);outtextxy(10 + (90 - textwidth(back)) / 2, 10 + (40 - textheight(back)) / 2, back);setfillcolor(GREEN);fillrectangle(200, 305, 400, 445);outtextxy(200 + (200 - textwidth("老年人模式")) / 2, 305 + (140 - textheight("老年人模式")) / 2, "老年人模式");setfillcolor(YELLOW);fillrectangle(420, 305, 620, 445);outtextxy(420 + (200 - textwidth("儿童模式")) / 2, 305 + (140 - textheight("儿童模式")) / 2, "儿童模式");setfillcolor(RED);fillrectangle(640, 305, 840, 445);outtextxy(640 + (200 - textwidth("大学生模式")) / 2, 305 + (140 - textheight("大学生模式")) / 2, "大学生模式");int f = 0;while (1){ExMessage msg;while (peekmessage(&msg, EX_MOUSE)){switch (msg.message){case WM_LBUTTONDOWN:if (msg.x > 200 && msg.x < 400 && msg.y>305 && msg.y < 445){speed = 10;}else if (msg.x > 420 && msg.x < 620 && msg.y>305 && msg.y < 445){speed = 5;}else if (msg.x > 640 && msg.x < 840 && msg.y>305 && msg.y < 445){speed = 3;}else if (msg.x > 10 && msg.x < 100 && msg.y>10 && msg.y < 50){f = 1;}break;default:break;}}if (f) break;}
}
void Look_maxscore()
{IMAGE img;loadimage(&img, "./01.jpg", width * size, height * size);putimage(0, 0, &img);char score[100];char back[] = "<<===";settextstyle(30, 0, "宋体");sprintf_s(score, "历史最高分:%d", maxscore);outtextxy(width*size/2-120, height*size/2, score);setfillcolor(BROWN);fillrectangle(10, 10, 100, 50);outtextxy(10 + (90 - textwidth(back)) / 2, 10 + (40 - textheight(back)) / 2,back);int f = 0;while (1){ExMessage msg;if (f) break;while(peekmessage(&msg, EX_MOUSE)){switch (msg.message){case WM_LBUTTONDOWN:if (msg.x > 10 && msg.x < 100 && msg.y>10 && msg.y < 50)f = 1;break;default:break;}}}
}
void gamehelp()
{IMAGE img;loadimage(&img, "./01.jpg", width * size, height * size);putimage(0, 0, &img);char back[] = "<<===";settextstyle(30, 0, "宋体");setfillcolor(BROWN);fillrectangle(10, 10, 100, 50);outtextxy(10 + (90 - textwidth(back)) / 2, 10 + (40 - textheight(back)) / 2, back);outtextxy(50, 100, "帮助:");outtextxy(200, 200, "按键操作:");outtextxy(200, 250, "w:向上");outtextxy(200, 300, "s:向下");outtextxy(200, 350, "a:向左");outtextxy(200, 400, "d:向右"); outtextxy(200, 450, "尽量吃更多的食物获得更高的分数。");outtextxy(200, 500, "注意:蛇头不能撞上地图边缘和自己身体!");int f = 0;while (1){ExMessage msg;if (f) break;while (peekmessage(&msg, EX_MOUSE)){switch (msg.message){case WM_LBUTTONDOWN:if (msg.x > 10 && msg.x < 100 && msg.y>10 && msg.y < 50)f = 1;break;default:break;}}}
}
void BGM()
{mciSendString("open ./level.mp3 alias s1", 0, 0, 0);mciSendString("play s1 repeat", 0, 0, 0);
}
void game()
{gamemap();Initialize();BGM();while (1){draw();movespeed();operate();}
}
void gamemap()
{setbkmode(BLUE);cleardevice();BeginBatchDraw();setlinecolor(WHITE);//网格颜色for (int i = size; i < width * size; i += size)//打印网格line(i, 0, i, height * size);for (int i = size; i < height * size; i += size)line(0, i, width * size,i);
}
void Initialize()
{snack[width / 2][height / 2] = 1;//初始蛇头for (int i = 1; i <= 4; i++)snack[width / 2][height / 2 + i] = i + 1;//初始蛇身foodx = rand() % (width - 2) + 1;//随机刷出食物位置foody = rand() % (height - 2) + 1;
}
void draw()
{for (int i = 0; i < width; i++) {for (int j = 0; j < height; j++) {if (snack[i][j] != 0)setfillcolor(HSVtoRGB(snack[i][j] * 10, 0.9, 1));elsesetfillcolor(LIGHTGRAY);fillrectangle(i * size, j * size, (i + 1) * size, (j + 1) * size);}}setfillcolor(LIGHTMAGENTA);fillrectangle(foodx * size, foody * size, (foodx + 1) * size, (foody + 1) * size);if (isover){Remembermaxscore();char a[100];sprintf_s(a, "最后得分:%d", result);settextcolor(RED);settextstyle(40, 0, "宋体");setbkmode(TRANSPARENT);outtextxy(200, 150, "游戏结束");outtextxy(200, 200, a);}FlushBatchDraw();
}
void operate()
{if (GetAsyncKeyState('W')){if (direction == 's')direction = 's';else direction = 'w';}if (GetAsyncKeyState('S')){if (direction == 'w')direction = 'w';else direction = 's';}if (GetAsyncKeyState('A')){if (direction == 'd')direction = 'd';else direction = 'a';}if (GetAsyncKeyState('D')){if (direction == 'a')direction = 'a';else direction = 'd';}
}
void movespeed()
{if (isover) return;static int wait = 1;wait++;if (wait == speed){move();wait = 1;}
}
void move()
{for (int i = 0; i < width; i++)for (int j = 0; j < height; j++)if (snack[i][j] != 0) snack[i][j]++;int oldHeadX, oldHeadY, oldTailX, oldTailY;int tailsnacks = 0;for (int i = 0; i < width; i++) {for (int j = 0; j < height; j++) {if (tailsnacks < snack[i][j]) {tailsnacks = snack[i][j];oldTailX = i;oldTailY = j;}if (snack[i][j] == 2) {oldHeadX = i;oldHeadY = j;}}}int newHeadX = oldHeadX, newHeadY = oldHeadY;switch (direction) {case'a':newHeadX -= 1;break;case 's':newHeadY += 1;break;case 'd':newHeadX += 1;break;case 'w':newHeadY -= 1;break;}if (newHeadX >= width || newHeadX < 0 || newHeadY >= height || newHeadY < 0 || snack[newHeadX][newHeadY] != 0) {isover = 1;//判断是否失败return;}snack[newHeadX][newHeadY] = 1;if (newHeadX == foodx && newHeadY == foody) {result++;//重新刷新食物foodx = rand() % (width - 2) + 1;foody = rand() % (height - 2) + 1;}elsesnack[oldTailX][oldTailY] = 0;
}

音乐和背景图大家可以自定义添加

相关文章:

C语言搭配EasyX实现贪吃蛇小游戏

封面展示 内部展示 完整代码 #define _CRT_SECURE_NO_WARNINGS #include<easyx.h> #include<stdio.h> #include<mmsystem.h> #pragma comment (lib,"winmm.lib") #define width 40//宽有40个格子 #define height 30//长有40个格子 #define size 2…...

# 软件安装-Linux搭建nginx(单机版)

软件安装-Linux搭建nginx(单机版) 安装版本:nginx-1.24.0 文章目录 软件安装-Linux搭建nginx(单机版)一、Nginx包下载二、创建用户1.新建组和用户2.设置用户密码3.登录自己创建的目录三、安装依赖组件四、安装Nginx五、启动Nginx六、配置Nginx一、Nginx包下载 1. nginx-1.24下…...

成熟的汽车制造供应商协同平台 要具备哪些功能特性?

汽车行业是一个产业链长且“重”的行业&#xff0c;整个业务流程包括了研发、设计、采购、库存、生产、销售、售后等一系列环节&#xff0c;在每一个环节都涉及到很多信息交换的需求。对内要保证研发、采购、营销等业务环节信息流通高效安全&#xff0c;对外要与上、下游合作伙…...

React16源码: React中处理ref的核心流程源码实现

ref的实现过程 1 &#xff09;概述 在更新流程当中如何去设置ref上面的对象的过程在我们创建fiber的时候去处理ref这个属性那我们什么时候创建fiber对象? 就是我们去更新某一个节点&#xff0c;然后要去调和它的子节点的时候这个时候我们会对每一个子节点去创建这个fiber对象…...

ref和reactive

看尤雨溪说&#xff1a;为什么Vue3 中应该使用 Ref 而不是 Reactive&#xff1f;...

掌握数据预测的艺术:线性回归模型详解

线性回归是统计学中用于建模两个或多个变量之间线性关系的一种方法,广泛应用于数据分析、机器学习等领域。从数学建模的角度出发,线性回归旨在找到一个线性方程,最好地描述自变量(或称为解释变量、特征变量)和因变量(或称为目标变量)之间的关系。本文将通过Python代码示…...

STM32F407移植OpenHarmony笔记8

继上一篇笔记&#xff0c;成功开启了littlefs文件系统&#xff0c;能读写FLASH上的文件了。 今天继续研究网络功能&#xff0c;让控制台的ping命令能工作。 轻量级系统使用的是liteos_m内核lwip协议栈实现网络功能&#xff0c;需要进行配置开启lwip支持。 lwip的移植分为两部分…...

C++:输入流/输出流

C流类库简介 C为了克服C语言中的scanf和printf存在的缺点。&#xff0c;使用cin/cout控制输入/输出。 cin&#xff1a;表示标准输入的istream类对象&#xff0c;cin从终端读入数据。cout&#xff1a;表示标准输出的ostream类对象&#xff0c;cout向终端写数据。cerr&#xff…...

十、Qt三维图表

一、Data Visualization模块概述 Data Visualization的三维显示功能主要有三种三维图形来实现&#xff0c;三各类的父类都是QAbstract3DGraph&#xff0c;从QWindow继承而来。这三类分别是&#xff1a;三维柱状图Q3DBar三维空间散点Q3DScatter三维曲面Q3DSurface 1、相关类的…...

CMake官方教程中文翻译 Step 6: Adding Support for a Testing Dashboard

鉴于自己破烂的英语&#xff0c;所以把cmake的官方文档用 谷歌翻译 翻译下来方便查看。 英语好的同学建议直接去看cmake官方文档&#xff08;英文&#xff09;学习&#xff1a;地址 点这里 或复制&#xff1a;https://cmake.org/cmake/help/latest/guide/tutorial/index.html …...

【leetcode】完全背包总结

本文内容参考了代码随想录&#xff0c;并进行了自己的总结。 完全背包 关键点 ● 每件物品有若干种状态&#xff1a;不选、选 1 件、选 2 件、…、选 n 件 代码 在代码上&#xff0c;只有重量的遍历方向和 01 背包不一样&#xff1a; for(int i 0; i < nums.length; i…...

【Linux】理解系统中一个被打开的文件

文件系统 前言一、C语言文件接口二、系统文件接口三、文件描述符四、struct file 对象五、stdin、stdout、stderr六、文件描述符的分配规则七、重定向1. 重定向的原理2. dup23. 重谈 stderr 八、缓冲区1. 缓冲区基础2. 深入理解缓冲区3. 用户缓冲区和内核缓冲区4. FILE 前言 首…...

k8s kubeadm部署安装详解

目录 kubeadm部署流程简述 环境准备 步骤简述 关闭 防火墙规则、selinux、swap交换 修改主机名 配置节点之间的主机名解析 调整内核参数 所有节点安装docker 安装依赖组件 配置Docker 所有节点安装kubeadm&#xff0c;kubelet和kubectl 定义kubernetes源并指定版本…...

RT-DETR算法优化改进: 下采样系列 | 一种新颖的基于 Haar 小波的下采样HWD,有效涨点系列

💡💡💡本文独家改进:HWD的核心思想是应用Haar小波变换来降低特征图的空间分辨率,同时保留尽可能多的信息,与传统的下采样方法相比,有效降低信息不确定性。 💡💡💡使用方法:代替原始网络的conv,下采样过程中尽可能包括更多信息,从而提升检测精度。 RT-DET…...

CocosCreator3.8源码分析

Cocos Creator架构 Cocos Creator 拥有两套引擎内核&#xff0c;C 内核 和 TypeScript 内核。C 内核用于原生平台&#xff0c;TypeScript 内核用于 Web 和小游戏平台。 在引擎内核之上&#xff0c;是用 TypeScript 编写的引擎框架层&#xff0c;用以统一两套内核的差异&#xf…...

(已解决)spingboot 后端发送QQ邮箱验证码

打开QQ邮箱pop3请求服务&#xff1a;&#xff08;按照QQ邮箱引导操作&#xff09; 导入依赖&#xff08;不是maven项目就自己添加jar包&#xff09;&#xff1a; <!-- 邮件发送--><dependency><groupId>org.springframework.boot</groupId><…...

【蓝桥杯冲冲冲】[NOIP2001 普及组] 装箱问题

蓝桥杯备赛 | 洛谷做题打卡day26 文章目录 蓝桥杯备赛 | 洛谷做题打卡day26题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示思路 题解代码我的一些话 [NOIP2001 普及组] 装箱问题 题目描述 有一个箱子容量为 V V V&#xff0c;同时有 n n n 个物品&#xff0c;每…...

2024牛客寒假算法基础集训营1

文章目录 A DFS搜索M牛客老粉才知道的秘密G why外卖E 本题又主要考察了贪心B 关鸡C 按闹分配 今天的牛客&#xff0c;说是都是基础题&#xff0c;头昏昏的&#xff0c;感觉真不会写&#xff0c;只能赛后补题了 A DFS搜索 写的时候刚开始以为还是比较难的&#xff0c;和dfs有关…...

元素的显示与隐藏,精灵图,字体图标,CSSC三角

元素的显示与隐藏 类似网站广告&#xff0c;当我们点击关闭就不见了&#xff0c;但是我们重新刷新页面&#xff0c;会重新出现 本质&#xff1a;让元素在页面中隐藏或者显示出来。 1.display显示隐藏 2.visibility显示隐藏 3.overflow溢出显示隐藏 1.display属性&#xff08;…...

最新!2024顶级SCI优化!TTAO-CNN-BiGRU-MSA三角拓扑聚合优化、双向GRU融合注意力的多变量回归预测程序!

适用平台&#xff1a;Matlab 2023版及以上 TTOA三角聚合优化算法&#xff0c;将在2024年3月正式发表在中科院1区顶级SCI期刊《Expert Systems with Applications》上。 该算法提出时间极短&#xff0c;目前以及近期内不会有套用这个算法的文献。新年伊始&#xff0c;尽快拿下…...

AI:词向量模型详解(Word Embedding)

词向量模型详解&#xff08;Word Embedding&#xff09; 词向量&#xff08;Word Embedding&#xff09;是自然语言处理&#xff08;NLP&#xff09;中最基础且影响深远的表示学习方法之一。它将离散的词汇映射为低维、稠密的实数向量&#xff0c;使计算机能够“理解”词语之间…...

kotlin协程取消执行

取消启动协程的整个scope&#xff0c;该scope下面的所有协程都会被取消。协程内部是通过抛出一个特殊的异常来实现取消的&#xff1a;CancellationException。如果想在取消时传递取消的原因&#xff0c;可以在调用cancel时主动提供一个CancellationException的实例&#xff1a;…...

软考机考绘图技巧与实战指南

1. 软考机考绘图工具基础操作 第一次参加软考机考的朋友们&#xff0c;最头疼的莫过于绘图题了。我当年第一次考试时&#xff0c;看到屏幕上密密麻麻的绘图工具&#xff0c;手指在键盘上悬了半天都不知道该点哪个按钮。后来经过多次实战&#xff0c;总结出一套快速上手的方法。…...

武汉围挡厂家:装配式市政围挡选购指南

随着城市基建与市政施工持续推进&#xff0c;施工围挡已不再是单一的隔离设施&#xff0c;而是集安全防护、规范施工、城市风貌管理于一体的工程配套产品。对于武汉及华中地区工程相关从业者而言&#xff0c;科学选择适配项目需求的装配式围挡&#xff0c;对施工安全、验收合规…...

基于转子磁链模型的滑模观测器改进:自适应反馈增益拓宽低速运行区间仿真研究

基于转子磁链模型的改进滑模观测器 1.对滑模观测器进行改进&#xff0c;采用与转速相关的自适应反馈增益&#xff0c;避免恒定增益导致的低速下抖振明显的问题&#xff1b; 2.区别传统滑模从反电势中提取位置和转速信息&#xff0c;改进滑模观测器中利用转子磁链来提取相关信息…...

筑牢代码安全基石:GB/T 34943/34944 标准详解与库博静态分析工具的全面支持

一、标准概述&#xff1a;GB/T 34943 与 GB/T 34944 国家标准在软件安全日益成为国家信息化战略核心的背景下&#xff0c;GB/T 34943-2017《C/C 语言源代码漏洞测试规范》与 GB/T 34944-2017《Java 语言源代码漏洞测试规范》两项国家标准应运而生国家标准化管理委员会。由全国信…...

STM32时钟系统解析与启动配置实践

1. STM32单片机启动时的时钟源选择机制刚接触STM32开发时&#xff0c;我总有个疑问&#xff1a;在main函数执行前&#xff0c;单片机是怎么跑起来的&#xff1f;特别是在我们还没配置系统时钟之前&#xff0c;CPU靠什么时钟在工作&#xff1f;这个问题困扰了我很久&#xff0c;…...

2026互联网大厂AI招聘趋势:高薪岗位解析,普通人如何抓住AI时代红利?

2026年互联网大厂招聘&#xff0c;AI岗已成绝对主角&#xff0c;百度AI岗占比超90%&#xff0c;阿里超6成&#xff0c;腾讯、字节等AI相关岗位占比也达6-7成&#xff0c;AI不再是“可选项”&#xff0c;而是“必答题”。以下是核心岗位、薪资与优势的精炼解读&#xff0c;帮你快…...

WPF 进阶之路:从 MVVM 到企业级应用的架构与实战

1. MVVM 模式在企业级应用中的深度实践 很多刚接触WPF的开发者都会觉得MVVM模式很抽象&#xff0c;我第一次用的时候也是一头雾水。直到接手了一个电商后台管理系统项目&#xff0c;才真正体会到MVVM的价值。这个项目有30多个页面&#xff0c;如果按照传统事件驱动的方式开发&a…...

SPI扩展CAN方案:从寄存器配置到多路通信实战

1. SPI扩展CAN方案的核心价值 在工业控制领域&#xff0c;CAN总线因其高可靠性和实时性被广泛使用。但随着设备节点增加&#xff0c;主控芯片原生CAN接口往往不够用。这时通过SPI接口扩展CAN通道就成了性价比极高的解决方案。我曾在多个工业现场实测&#xff0c;用10元级的MCP2…...