C语言Easyx实现贪吃蛇详解

目录
  • 一、头文件包含
  • 二、创建蛇与食物的结构体
  • 三、游戏的初始化
  • 四、游戏的绘画事件
  • 五、蛇的移动事件
  • 六、输入方向******这个方面没什么好解释的大家看代码应该可以看懂。
  • 七、生成食物
  • 八、吃食物
  • 九、游戏失败的判定
  • 十、main函数
  • 总结:

一、头文件包含

     #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} ;

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

直接上代码:

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);//生成圆形食物

五、蛇的移动事件

void snakemove()
{
    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;
}

总结:

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

本篇文章就到这里了,希望能够给你带来帮助,也希望您能够多多关注我们的更多内容!

(0)

相关推荐

  • 用C语言实现贪吃蛇小游戏

    本文实例为大家分享了C语言实现贪吃蛇小游戏的具体代码,供大家参考,具体内容如下 实现功能 蛇最开始三节,向右移动.用户可以通过按上下左右来控制蛇的移动,食物随机产生,蛇吃到食物后蛇的身体会变长.蛇撞墙或者撞到自己身体后,游戏结束. 怎么实现 要实现一个贪吃蛇小游戏,首先要想清楚游戏里有什么,怎样实现功能. 很明显游戏中只有两样东西,蛇和食物. 所以要建立蛇和食物信息,然后将蛇和食物进行初始化,在将蛇和食物画出来. 实现的功能有: 1. 蛇的移动  2. 按键控制蛇的移动  3. 食物的产生  4

  • C语言循环链表实现贪吃蛇游戏

    本文实例为大家分享了C语言表实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下 总体思想 利用循环链表将一条蛇的坐标进行存储,然后利用gotoxy()函数(可以将光标定位到指定的位置),此时根据蛇的坐标进行输出"@",输出多几个既可以产生一条蛇.通过遍历循环链表进行蛇的移动,对循环链表的插入元素,产生蛇变长的效果.下面为各功能实现的函数 1.贪吃蛇地图函数map() 2.蛇的移动move(),up(),left()等函数 3.产生食物food()和吃到食物eat_food() 4.蛇吃

  • C语言实现贪吃蛇游戏代码

    本文实例为大家分享了C语言实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下 //------------------------------------------problm区------------------------------ //①思考typedef 定义的变量如何利用fwrite进行存储 //②典型可利用sleep()语句类实现控制移动速度 //③BOOL PlaySoundW(LPCWSTR, HMODULE, DWORD)": 无法将参数 1 从"const ch

  • 基于easyx的C++实现贪吃蛇

    本文实例为大家分享了基于easyx的C++实现贪吃蛇的具体代码,供大家参考,具体内容如下 本代码来自于easyx讨论群的分享 先上效果图,其实也只是画了简单的圈圈代表蛇和食物,背景就是黑色的. #include "stdafx.h" #include <iostream> #include <stdlib.h> #include <time.h> #include <conio.h> #include <graphics.h>

  • 用纯C语言实现贪吃蛇游戏

    本文实例为大家分享了C语言实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下 在读大学生一枚,五一期间用四天时间写一个小游戏. 本贪吃蛇游戏代码共计531行,开发环境是VS,游戏分为两种模式,标准模式和超大地图模式,详细看以下源代码,并进入游戏体验具体内容. //贪吃蛇 #include<stdio.h> #include<windows.h> #include<time.h> #include<conio.h> //游戏窗口 #define FrameX

  • C语言实现贪吃蛇代码

    本文实例为大家分享了C语言实现贪吃蛇代码的具体代码,供大家参考,具体内容如下 #include"stdafx.h" #include<stdio.h> #include<time.h> #include<windows.h> #include<stdlib.h> #include<conio.h> #define U 1 #define D 2 #define L 3 #define R 4 //蛇的状态 U:上 D:下 L:

  • C语言Easyx实现贪吃蛇详解

    目录 一.头文件包含 二.创建蛇与食物的结构体 三.游戏的初始化 四.游戏的绘画事件 五.蛇的移动事件 六.输入方向******这个方面没什么好解释的大家看代码应该可以看懂. 七.生成食物 八.吃食物 九.游戏失败的判定 十.main函数 总结: 一.头文件包含 #include<stdio.h> #include<graphics.h> //图形处理需要包含的库文件 #include<mmsystem.h> //windows多媒体接口 #include<con

  • 利用Python如何制作贪吃蛇及AI版贪吃蛇详解

    用python制作普通贪吃蛇 哈喽,大家不知道是上午好还是中午好还是下午好还是晚上好! 贪吃蛇,应该是90后小时候的记忆(连我这个00后也不例外),今天,我们就用python这款编程语言来实现贪吃蛇 系统:所有都可以 需导入模块: random pygame pygame.locals sys 下载以上模块指令: random和sys是Python自带的,我们只需要下载pygame即可 下载pygame: 在开始菜单输入"cmd"回车打开,输入``指令:pip install pyga

  • C语言基于EasyX实现贪吃蛇

    本文实例为大家分享了C语言基于EasyX实现贪吃蛇的具体代码,供大家参考,具体内容如下 成品展示: 实现思路: 贪吃蛇的实现思路并不复杂,由于我们需要将数据展示在图形窗口上,因此就不需要之前那种用数组表示整个游戏地图的方法. 贪吃蛇的蛇有X坐标和Y坐标,而且不止一节,因此需要一个坐标结构体数组来保存,蛇的移动思路是除了第一节以外,后面每一节都是前面一节的坐标,然后通过键盘的输入输出使蛇的X或Y坐标加或者减来起到上下左右移动的作用.通过判断蛇与食物的坐标是否重合绝对是否吃到食物,吃到食物以后,蛇的

  • C语言 指针与数组的详解及区别

    C语言 指针与数组的详解及对比 通俗理解数组指针和指针数组 数组指针: eg:int( *arr)[10]; 数组指针通俗理解就是这个数组作为指针,指向某一个变量. 指针数组: eg:int*arr[10]; 指针数组简言之就是存放指针的数组: --数组并非指针&&指针并非数组 (1)定义一个外部变量: eg:int value=10; int *p=&value; 举例:当需要在一个函数中用这个变量时:externa int*p;而非extern int p[]; 分析:当用:e

  • 基于C语言实现的贪吃蛇游戏完整实例代码

    本文以实例的形式讲述了基于C语言实现的贪吃蛇游戏代码,这是一个比较常见的游戏,代码备有比较详细的注释,对于读者理解有一定的帮助. 贪吃蛇完整实现代码如下: #include <graphics.h> #include <conio.h> #include <stdlib.h> #include <dos.h> #define NULL 0 #define UP 18432 #define DOWN 20480 #define LEFT 19200 #defi

  • C语言动态内存分配的详解

    C语言动态内存分配的详解 1.为什么使用动态内存分配 数组在使用的时候可能造成内存浪费,使用动态内存分配可以解决这个问题. 2. malloc和free C函数库提供了两个函数,malloc和free,分别用于执行动态内存分配和释放. (1)void *malloc(size_t size); malloc的参数就是需要分配的内存字节数.malloc分配一块连续的内存.如果操作系统无法向malloc提供更多的内存,malloc就返回一个NULL指针. (2)void free(void *poi

  • C语言memset函数使用方法详解

    C语言memset函数使用方法详解 一.函数原形   void *  memset(void*s, int ch,size_t n) 二.函数作用  将以s内存地址为首的连续n个字节的内容置成ch,一般用来对大量结构体和数组进行清零 三.常见错误 1.搞反了 ch 和 n的位置 对char[20]清零,一定是 memset(a,0,20); 2.过度使用memset 3.其实这个错误严格来讲不能算用错memset,但是它经常在使用memset的场合出现 int fun(strucy someth

  • C/C++语言宏定义使用实例详解

     C/C++语言宏定义使用实例详解 1. #ifndef 防止头文件重定义 在一个大的软件工程里面,可能会有多个文件同时包含一个头文件,当这些文件编译链接成 一个可执行文件时,就会出现大量"重定义"的错误.在头文件中实用#ifndef #define #endif能避免头文件的重定义. 方法:例如要编写头文件test.h 在头文件开头写上两行: #ifndef TEST_H #define TEST_H //一般是文件名的大写 头文件结尾写上一行: #endif 这样一个工程文件里同时

  • Java语言实现数据结构栈代码详解

    近来复习数据结构,自己动手实现了栈.栈是一种限制插入和删除只能在一个位置上的表.最基本的操作是进栈和出栈,因此,又被叫作"先进后出"表. 首先了解下栈的概念: 栈是限定仅在表头进行插入和删除操作的线性表.有时又叫LIFO(后进先出表).要搞清楚这个概念,首先要明白"栈"原来的意思,如此才能把握本质. "栈"者,存储货物或供旅客住宿的地方,可引申为仓库.中转站,所以引入到计算机领域里,就是指数据暂时存储的地方,所以才有进栈.出栈的说法. 实现方式是

  • 70行C语言代码实现贪吃蛇

    本文实例为大家分享了C语言实现贪吃蛇的具体代码,供大家参考,具体内容如下 #include <stdio.h> #include <Windows.h> #include <conio.h> #include <time.h> #define MAX_WIDE 50 #define MAX_HIGH 16 short dx = 1, dy = 0, randxy, score = 0; COORD coord; struct Snake{ short len

随机推荐