EasyX实现简易贪吃蛇

news2025/1/31 3:11:41

在这里插入图片描述

📝个人主页:认真写博客的夏目浅石.
📣系列专栏:夏目的C语言宝藏

文章目录

  • 前言
  • 一、头文件包含
  • 二、创建蛇与食物的结构体
  • 三、游戏的初始化
  • 四、游戏的绘画事件
  • 五、蛇的移动事件
  • 六、输入方向
  • 七、生成食物
  • 八、吃食物
  • 九、游戏失败的判定
  • 十、main函数
  • 总结


前言

我们曾经都玩过贪吃蛇游戏,所以我今天学习了C语言就想学习然后写一下。


一、头文件包含

#include<stdio.h>
#include<graphics.h> //图形处理需要包含的库文件
#include<mmsystem.h> //windows多媒体接口
#include<conio.h>   //读取键盘输入
#include<time.h>    //随机数种子
#include<stdlib.h>   //内存分配

包含完头文件后进行一些预处理操作:

#pragma comment(lib,"winmm.lib")//多媒体接口
#define NUM 200;
#define SIZE 10
enum Ch{ up=72,down=80,left=75,right=77} ;   

二、创建蛇与食物的结构体

贪吃蛇是基于帧驱动,而不是事件驱动的程序。
开发者只需要处理每一帧蛇的变化,而不是处理出现的事件(用户输入,蛇吃到食物)。
easyX提供了绘制填充矩形的API fillrectangle。
我们把窗口分割成无数个小方格,蛇的身体和食物绘制在方格的点中。
贪吃蛇中的蛇,是一个集合,储存是每个方块的x和y坐标。
蛇移动的本质是 头 向当前方向移动一个单元格,然后其他的身体格坐标变成上一个格的坐标。
食物是一个点,只需要储存x和y坐标就可以表示。
只有蛇头碰到食物才算吃到食物,蛇的身体变长,实质上是蛇是吃到食物后移动时,加入一个位置,并设置成移动前最后一个位置的坐标
根据上述描述,我们可以构建对应的结构体;

struct pos   //蛇身坐标
{
    int x;
    int y;
};
struct snake  
{
    int n;    //初始化蛇身长度
    Ch ch;    //蛇前进的方向
    pos szb[3265];  //蛇的坐标数组
};
struct food
{
    int x;
    int y;
    bool iseat;  //判断食物是否被吃
};

//创建一个蛇与食物

snake s;
food  f;

三、游戏的初始化

代码如下(示例):

void gameinit()
{
    srand((unsigned int)time(NULL));//随机数种子,用于随机生成食物
    s.n = 2;  //蛇的初始长度,可以自己设定
    s.ch = right;//蛇的初始方向;
    s.szb[0].x=100;
    s.szb[0].y=100;
    s.szb[1].x = 90;
    s.szb[1].y = 100;//蛇的初始位置坐标
    f.iseat = true;
}

四、游戏的绘画事件

代码如下(示例):

cleardevice();  //每次绘画都要进行一次清屏
    setfillcolor(RED); //蛇头颜色
    fillrectangle(s.szb[0].x, s.szb[0].y,
        s.szb[0].x + SIZE, s.szb[0].y + SIZE);//SIZE在预处理是已经定义表示每个蛇身的大小
    for (int i = 0; i < s.n; i++) {
        rectangle(s.szb[i].x, s.szb[i].y,
            s.szb[i].x + SIZE, s.szb[i].y + SIZE);
    } //生成矩形蛇
    setfillcolor(GREEN);//食物颜色
    fillroundrect(f.x, f.y, f.x + SIZE, f.y + SIZE,5,5);//生成圆形食物

五、蛇的移动事件

代码如下(示例):

{
    for (int i = s.n - 1; i > 0; i--)
    {
        s.szb[i].x = s.szb[i - 1].x;
        s.szb[i].y = s.szb[i - 1].y;  //通过数组的变换来实现蛇的移动
    }
    switch (s.ch)//ch枚举类型在预处理时已经定义
    {
    case up:
        s.szb[0].y -= SIZE;

        //由于在窗口坐标系中y方向是向下的所以向上移动需要减去一个size
        break;
    case down:
        s.szb[0].y += SIZE;
        break;
    case left:
        s.szb[0].x -= SIZE;
        break;
    case right:
        s.szb[0].x += SIZE;
        break;
    }
}

六、输入方向

代码如下(示例):

void changech()
{
    char key;
    key = _getch();
    switch (key)
    {
    case up:
        if (s.ch != down)
            s.ch = up;
        break;
    case down:
        if (s.ch != up)
            s.ch = down;
        break;
    case left:
        if (s.ch != right)
            s.ch = left;
    case right:
        if (s.ch != left)
            s.ch = right;
    }
}

七、生成食物

代码如下(示例):

void creatfood()
{
    bool flag = false;
    if (f.iseat == true) {
        while (1)
        {
            flag = false;//设定flag判断食物是否与蛇身重合
                f.x = rand() % 68*10;
                f.y = rand() % 48*10;//食物的随机生成
                for (int i = 0; i < s.n; i++)
                {
                    if (f.x == s.szb[i].x && f.y == s.szb[i].y)
                    {
                        flag = true;
                        break;
                    }
                }
                if (!flag)
                {
                    f.iseat = false;
                    break;
                }

           //上面部分为判断食物是否与蛇身重合
        }
    }
}

八、吃食物

代码如下(示例):

void eatfood()
{
    if (s.szb[0].x == f.x && s.szb[0].y == f.y)//如果蛇头与食物重合那么食物就被吃掉了
    {
        f.iseat = true;
        s.n++;
    }
}

九、游戏失败的判定

代码如下(示例):
因为我初始化的窗口为640*480,if判断的范围打击可以根据自己窗口大小设定。

int gameover()
{
    if (s.szb[0].x < 0 || s.szb[0].x>640 || s.szb[0].y < 0 || s.szb[0].y>480)
    {
        return 1;
    }
    for (int i = 1; i < s.n; i++)
    {
        if (s.szb[0].x == s.szb[i].x && s.szb[0].y == s.szb[i].y)
        {
            return 1;
        }
    }
    return 0;
}

十、main函数

代码如下(示例):

int main()
{
    initgraph(680,480);
    mciSendString(L"open 7895.mp3", 0, 0, 0);
    mciSendString(L"play 7895.mp3", 0, 0, 0);

//添加音乐必须加上这个预处理指令#pragma comment(lib,"winmm.lib")
    int n = 0;
    gameinit();
    while (1) {
        while (!_kbhit())
        {
            snakemove();
            drawgame();
            creatfood();
            eatfood();
            n = gameover();
            if (n)
                break;
            Sleep(100);
        }
        if (n)
            break;
        changech();
    }
    closegraph();
    getchar();
    return 0;
}

总结

贪吃蛇游戏的难点就在于蛇身的变化与移动,只要这两个问题解决后其他的都很好想。封面就是运行后的结果。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【Python开发】FastAPI 09:middleware 中间件及跨域

FastAPI 提供了一些中间件来增强它的功能&#xff0c;类似于 Spring 的切面编程&#xff0c;中间件可以在请求处理前或处理后执行一些操作&#xff0c;例如记录日志、添加请求头、鉴权等&#xff0c;跨域也是 FastAPI 中间件的一部分。 目录 1 中间件 1.1 创建中间件 1.2 使…

IDEA日常配置和操作小结

✅作者简介&#xff1a;大家好&#xff0c;我是Cisyam&#xff0c;热爱Java后端开发者&#xff0c;一个想要与大家共同进步的男人&#x1f609;&#x1f609; &#x1f34e;个人主页&#xff1a;Cisyam-Shark的博客 &#x1f49e;当前专栏&#xff1a; IDEA专栏 ✨特色专栏&…

算法刷题-数组-长度最小的子数组

209.长度最小的子数组 力扣题目链接 给定一个含有 n 个正整数的数组和一个正整数 s &#xff0c;找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组&#xff0c;并返回其长度。如果不存在符合条件的子数组&#xff0c;返回 0。 示例&#xff1a; 输入&#xff1a;s 7, …

电子元器件解析之电容(一)——定义与性能参数

下篇文章&#xff1a;电子元器件解析之电容(二)——电容分类与应用场景&#xff1a;https://blog.csdn.net/weixin_42837669/article/details/131142767 摘要 电容是最基本的电子元器件之一&#xff0c;本文介绍了电容的定义&#xff0c;并总结了电容的各个性能参数&#xff0c…

攻防世界—easyupload

2023.6.10 又试了一下 他好像会检测php字段&#xff0c;所以一开始的aaa.jpg怎么也传不上去&#xff0c;用a.jpg那种就可以了 根据题目和页面我们可以猜到这应该是一个利用文件上传漏洞&#xff0c;利用一句话木马来获取服务器上保存的flag保险起见右键查看源代码 可以发现毫无…

基础实验篇 | RflySim底层飞行控制算法开发系列课程总体介绍

本讲主要介绍多旋翼的特点及选用多旋翼作为实验平台的原因、对于无人系统教育的一些新需求、RflySim平台对于飞控的底层控制算法的开发优势、本期平台课程的设置、以及如何开发自驾仪系统。 相较于固定翼和直升机&#xff0c;多旋翼具有机械结构简单、 易维护的优点。以四旋翼…

使用 Pycharm 调试远程代码

文章目录 背景同步远程代码Interpreter注意点 背景 工作机是一台 Windows 电脑&#xff0c;而很多时候需要在 Mac 电脑上编码、配合 iPhone 模拟器&#xff0c;所以我以前是用 VNC 或者向日葵来远程 Mac 来编程&#xff0c;其实还能接受&#xff0c;但是最让我不舒服的是快捷键…

MySQL表操作:提高数据处理效率的秘诀(进阶)(2)

&#x1f495;“学习难免有坎坷&#xff0c;重要的是你能尽力而为&#xff0c;持之以恒。”&#x1f495; &#x1f43c;作者&#xff1a;不能再留遗憾了&#x1f43c; &#x1f386;专栏&#xff1a;MySQL学习&#x1f386; &#x1f697;本文章主要内容&#xff1a;MySQL表操…

K Shortest Paths算法之Yen algorithm

Yen’s算法是一种在图论中用于计算单源K最短无环路径的算法&#xff0c;该算法由Jin Y. Yen在1971年提出。这个算法的时间复杂度和空间复杂度都取决于用于计算偏离路径的最短路径算法。如果使用Dijkstra算法&#xff0c;那么时间复杂度为O(KN3)&#xff0c;采用Fibonacci堆计算…

Elasticsearch:Explain API - 如何计算分数

你想了解你的文档为何获得该分数吗&#xff1f; 文档 让我们通过一组示例文档来了解 Explain API。 就我而言&#xff0c;我将使用一小部分电影名言。 POST _bulk { "index" : { "_index" : "movie_quotes" } } { "title" : "T…

从malloc到跑路

当我还是一个懵懂无知的少年时&#xff0c;内心也曾升起这样的疑问这内存咋来的捏❓ 有个帅气的小哥哥给我甩了一篇博客&#xff1a;对&#xff0c;就是这篇&#xff0c;看完后总感觉意犹未尽&#xff0c;似乎少了点什么的样子。。。 还是从malloc开始 如果申请的内存小于64B…

“配置DHCP服务器和DHCP中继的网络自动配置实验“

"配置DHCP服务器和DHCP中继的网络自动配置实验" 【实验目的】 部署DHCP服务器。熟悉DHCP中继的配置方法。验证拓扑。 【实验拓扑】 实验拓扑如图所示。 设备参数如下表所示。 设备 接口 IP地址 子网掩码 默认网关 DHCPSERVE S0/3/0 192.168.10.1 255.255.…

丰富上下文的超高分辨率分割:一种新的基准

文章目录 Ultra-High Resolution Segmentation with Ultra-Rich Context: A Novel Benchmark摘要数据集Dataset SummaryData Collection and Pre-processing 数据标注数据统计 WSDNet实验结果 Ultra-High Resolution Segmentation with Ultra-Rich Context: A Novel Benchmark …

SSM整合快速入门案例(一)

文章目录 前言一、设计数据库表二、创建工程三、SSM技术整合四、功能模块开发五、接口测试总结 前言 为了巩固所学的知识&#xff0c;作者尝试着开始发布一些学习笔记类的博客&#xff0c;方便日后回顾。当然&#xff0c;如果能帮到一些萌新进行新技术的学习那也是极好的。作者…

不认识docker,怎么好意思说自己是干IT的

1.Docker是什么 一款产品从开发到上线&#xff0c;从操作系统&#xff0c;到运行环境&#xff0c;再到应用配置。作为开发运维之间的协作我们需要关心很多东西&#xff0c;这也是很多互联网公司都不得不面对的问题&#xff0c;特别是各种版本的迭代之后&#xff0c;不同版本环…

用户行为数据分析

文章目录 用户行为数据分析1 项目描述2 项目需求3 数据准备1、创建user_data数据表用于导入user_data.csv中的数据2、加载user_data.csv中的数据到user_data表3、接下来进行数据清洗&#xff0c;包括&#xff1a;删除重复值&#xff0c;时间戳格式化&#xff0c;删除异常值。 4…

OpenGL光照之基础光照

文章目录 环境光照漫反射光照计算漫反射光照镜面光照代码 现实世界的光照是极其复杂的&#xff0c;而且会受到诸多因素的影响&#xff0c;这是我们有限的计算能力所无法模拟的。因此OpenGL的光照使用的是简化的模型&#xff0c;对现实的情况进行近似&#xff0c;这样处理起来会…

MyBatis-Plus(2.0)

ActiveRecord ActiveRecord(简称AR)一直广受动态语言&#xff08;PHP、Ruby等&#xff09;的喜爱&#xff0c;而java作为准静态语言&#xff0c;对于ActiveRecord往往只能感叹器优雅 什么是ActiveRecord&#xff1f; ActiveRecord也属于ORM(对象关系映射)层&#xff0c;由Rail…

视频|人人能看懂的苹果visionOS空间设计课程

本周的重磅消息无疑是苹果Vision Pro以及对应的visionOS&#xff0c;考虑到苹果头显硬件上当前以第一方App为主&#xff0c;因此本届WWDC的一个重点就是释放visionOS和相关能力给开发者&#xff0c;让开发者尽快打造出更多、更优质的第三方App阵容。 与此同时&#xff0c;苹果也…

【vue3】10-vue组件化额外知识补充(下)-动态组件-组件缓存-v-model在组件上的应用

组件化-额外知识补充&#xff08;下&#xff09; 动态组件的使用(了解)keep-alive&#xff08;理解&#xff09;认识keep-alivekeep-alive的使用 异步组件的使用webpack分包处理&#xff08;了解&#xff09;Vue中实现异步组件 组件的v-model组件的混入Mixin&#xff08;了解&a…