C++ 情怀游戏贪吃蛇的实现流程详解

还记我们童年时的贪吃蛇吗,用“砖头”诺基亚玩的更是经典中的经典,贪食蛇操作简单,可玩性比较高。这个游戏难度最大的不是蛇长得很长的时候,而是开始。那个时候蛇身很短,看上去难度不大,却最容易死掉,因为把玩一条小短蛇让人容易走神,失去耐心。由于难度小,你会不知不觉加快调整方向的速度,在游走自如的时候蛇身逐渐加长了,而玩家却没有意识到危险,在最得意洋洋的一刻突然死亡。

1976年,Gremlin平台推出了一款经典街机游戏Blockade。游戏中,两名玩家分别控制一个角色在屏幕上移动,所经之处砌起围栏。角色只能向左、右方向90度转弯,游戏目标保证让对方先撞上屏幕或围栏。 听起来有点复杂,其实就是下面这个样子: 基本上就是两条每走一步都会长大的贪吃蛇比谁后完蛋,玩家要做的就是避免撞上障碍物和越来越长的身体。更多照片、视频可以看 GamesDBase 的介绍。 Blockade 很受欢迎,类似的游戏先后出现在 Atari 2600、TRS-80、苹果 2 等早期游戏机、计算机上。但真正让这种游戏形式红遍全球的还是21年后随诺基亚手机走向世界的贪吃蛇游戏——Snake。

我们今天就来自己写一个游戏《贪吃蛇》

其实这个项目很早就想和大家分享了,但是鉴于这个比较简单,当时觉得没必要,但近期有小伙伴私信我说想要贪吃蛇的项目源码,我就来满足小伙伴们的要求,大家一定要好好看好好学哦!

行吧,我们现在就开始吧!!!

首先还是、还是我们的老朋友结构体(我们的食物以及蛇)

typedef struct pointXY
{
	int x;
	int y;
}MYPOINT;
HWND hwnd = NULL;

//蛇
struct mySnake
{
	int num;
	MYPOINT xy[MAX];
	char postion;		//表示方向,标记
}snake;

//食物
struct myFood
{
	MYPOINT foodxy;
	int flag;
	int eatGrade;
}food;

接下来便是初始化了,这也是我们的老伙计了,再有就是绘制这条蛇以及食物的函数

//1.初始化蛇
void initSnake()
{
	snake.xy[2].x = 0;
	snake.xy[2].y = 0;

	snake.xy[1].x = 10;
	snake.xy[1].y = 0;

	snake.xy[0].x = 20;
	snake.xy[0].y = 0;

	snake.num = 3;
	snake.postion = right;

	food.flag = 0;
}
//2.绘制蛇
void drawSnake()
{
	for (int i = 0; i < snake.num; i++)
	{
		setlinecolor(RED);
		setfillcolor(GREEN);
		fillrectangle(snake.xy[i].x, snake.xy[i].y, snake.xy[i].x + 10, snake.xy[i].y + 10);
	}
}
//初始化食物
void  initFood()
{
	//0,63    630   640
	//0,47    470   480
	food.foodxy.x = rand() % 64 * 10;  //只能是10的整数倍,蛇头才能对齐食物
	food.foodxy.y = rand() % 48 * 10;
	food.flag = 1;
	//食物不能出现在蛇身上
	for (int i = 0; i < snake.num; i++)
	{
		if (food.foodxy.x == snake.xy[i].x&&food.foodxy.y == snake.xy[i].y)
		{
			food.foodxy.x = rand() % 64 * 10;  //只能是10的整数倍,蛇头才能对齐食物
			food.foodxy.y = rand() % 48 * 10;
		}
	}
}
//绘制食物
void drawFood()
{
	fillrectangle(food.foodxy.x, food.foodxy.y, food.foodxy.x + 10, food.foodxy.y + 10);
}

现在是蛇的移动函数,蛇要怎么走,千万不要一下头朝前,一下屁股朝前,不要闹笑话了

//3.移动蛇
void moveSnake()
{
	//除了第一节之外,后面的坐标都是前一节坐标
	for (int i = snake.num - 1; i > 0; i--)
	{
		snake.xy[i].x = snake.xy[i - 1].x;
		snake.xy[i].y = snake.xy[i - 1].y;
	}
	//蛇头怎么走,要根据方向标志去做移动
	switch (snake.postion)
	{
	case right:
		snake.xy[0].x += 10;
		break;
	case left:
		snake.xy[0].x -= 10;
		break;
	case down:
		snake.xy[0].y += 10;
		break;
	case up:
		snake.xy[0].y -= 10;
		break;
	}

}

项目重点,如何去控制我们的蛇,之前是鼠标控制,那键盘控制该怎么去写呢,看好了

//4.按键用户:人玩蛇
void keyDown()
{
	static char userkey = '\0';    //VC  getch不需要加下划线
	//userkey=_getch();		//不可见输入
	//自己生成按键
	switch (snake.postion)
	{
	case right:
	case left:
		if (food.foodxy.y >= snake.xy[0].y)
		{
			userkey = 80;
		}
		else  if (food.foodxy.y<snake.xy[0].y)
		{
			userkey = 72;
		}
		break;
	case up:
	case down:
		if (food.foodxy.x >= snake.xy[0].x)
		{
			userkey = 77;
		}
		else  if (food.foodxy.x < snake.xy[0].x)
		{
			userkey = 75;
		}
		break;
	}
	switch (userkey)
	{
	case 'w':
	case 'W':
	case 72:	//上
		if (snake.postion != down)
		{
			//蛇往上走,你要排除掉蛇本来是朝下
			snake.postion = up;
		}
		break;
	case 's':
	case 'S':
	case 80:	//下
		if (snake.postion != up)
		{
			snake.postion = down;
		}
		break;
	case 'a':
	case 'A':
	case 75:	//左
		if (snake.postion != right)
		{
			snake.postion = left;
		}
		break;
	case 'd':
	case 'D':
	case 77:	//右
		if (snake.postion != left)
		{
			snake.postion = right;
		}
	}
}

接下来是我们的老判断函数了,蛇吃到食物会怎么样以及怎么判断蛇的死亡,理清逻辑

//蛇吃食物
void eatFood()
{
	if (snake.xy[0].x == food.foodxy.x && snake.xy[0].y == food.foodxy.y)
	{
		snake.num++;
		food.eatGrade += 10;
		food.flag = 0;
	}
}
//蛇死亡判断
int snakeDie()
{
	//显示分数
	char grade[100] = { 0 };
	sprintf(grade, "%d", food.eatGrade);
	setbkmode(TRANSPARENT);
	settextcolor(RED);
	outtextxy(580, 20, "分数:");		//loadimage
	outtextxy(620, 20, grade);		//
	//判断蛇是否死亡

	//撞墙
	if (snake.xy[0].x > 640 || snake.xy[0].x<0 || snake.xy[0].y>480 || snake.xy[0].y < 0)
	{
		MessageBox(hwnd, "游戏结束!", "撞墙死亡!", 0);
		return 1;
	}
	//撞自己
	for (int i = 1; i < snake.num; i++)
	{
		if (snake.xy[0].x == snake.xy[i].x&&snake.xy[0].y == snake.xy[i].y)
		{
			MessageBox(hwnd, "游戏结束!", "撞自己!", 0);
			return 1;
		}
	}
	return 0;
}

最后是我们的主函数,这我就不说了

int main()
{
	srand((unsigned int)time(NULL));
	hwnd=initgraph(640, 480);
	setbkcolor(WHITE);
	cleardevice();
	initSnake();
	while (1)
	{
		cleardevice();		//刷掉路径
		if (food.flag == 0)
		{
			initFood();
		}
		drawFood();
		drawSnake();
		if (snakeDie())
		{
			break;
		}
		eatFood();
		moveSnake();
		Sleep(100);			//控制速度
		//while (_kbhit())	//kbhit() 存在按键操作,返回非零
		//{
		//	keyDown();
		//}
		keyDown();
	}
	closegraph();
	printf("GameOver!!!");
	system("pause");
	return 0;
}

经典游戏《贪吃蛇》完成,OK,简单总结一下,代码很简单,逻辑也不难,重要是大家一定要自己动手去做,这是毋庸置疑的,编程没有捷径,只有不断的学习熟练,加强自己的能力,有条件的话找个老师的话效果会更好,好了,希望大家可以在这里得到自己想要的知识以及快乐吧,也希望大家可以给UP主一个关注,非常感谢大家了!!!

到此这篇关于C++ 情怀游戏贪吃蛇的实现流程详解的文章就介绍到这了,更多相关C++ 贪吃蛇内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • C++实现简单贪吃蛇游戏

    我大概在一个多月前把自己上学期写的c代码的贪吃蛇游戏push到csdn上,并且说c风格的贪吃蛇写起来有些麻烦(贪吃蛇游戏的c语言实现),准备用面向对象的c++再写一遍.现在我们专业恰好刚教完了c++,学校也布置了一道简单的贪吃蛇的编程题目,实现下来,的确觉得c++的思路清晰很多,所以再次把c++的代码push上来,供大家对比参考:) 直接上代码,c++把整个游戏拆分成几个文件,分开上,有一定的c++基础的同学应该可以很容易看懂. 1.全局头文件(global.hpp) #ifndef _GLOB

  • C++实现简单贪吃蛇小游戏

    本文实例为大家分享了C++实现简单贪吃蛇小游戏的具体代码,供大家参考,具体内容如下 1 贪吃蛇游戏原理 1.1 构造蛇身:定义一个坐标数组,存放的是蛇的每一节蛇身所在的坐标位置. 1.2 移动效果:每次移动时,将每一节蛇身(蛇头除外)依次往前移动一节,去掉蛇的最后一节,确定蛇的方向 1.3 移动判断:每次移动时,判断蛇头是否触碰食物,如果碰到了食物,只进行前移蛇身和增加蛇头的操作,不进行擦除蛇尾的操作 2游戏设计 2.1 游戏首页 2.2 开始游戏 2.3 退出游戏 3.游戏实现 3.1 游戏首

  • 利用C/C++实现贪吃蛇游戏

    利用C/C++实现贪吃蛇 (注意:本文章仅供参考,第一次写博客还请多多指教.理解本文章需要easyx和c++等基础知识,并且需要了解贪吃蛇游戏机制) 贪吃蛇机制介绍 相信绝大多数人都曾玩过或者了解过贪吃蛇这款经典的游戏.贪吃蛇顾名思义,就是让蛇尽可能的吃食物.玩家可通过方向键或自定义键来控制蛇头的方向,使它吃到地图出现的随机食物.蛇每吃到一个食物,自身便会增长.当蛇碰到地图的边界或是蛇碰到自身,蛇便会死亡,游戏便结束. 机制大概了解过后,我们将考虑如何实现这类游戏. 设计与分析 首先,我们分析游

  • C++实现贪吃蛇游戏

    一.基本思路 制作贪吃蛇游戏,首先必须要有的材料是蛇和得分的食物:其次是游戏逻辑,1.要能使用键盘控制蛇的移动:2.食物被吃掉要能再次生成并且蛇要做出相应变化:3.蛇咬到自己的身体和墙会死亡:最后是图形界面的显示. 二.蛇和食物 蛇和食物使用结构体来储存,代码比较简单. #include <graphics.h> #include <stdio.h> #include <time.h> #include <conio.h> #define SIZE 30 #

  • C++控制台实现贪吃蛇游戏

    本文实例为大家分享了C++实现贪吃蛇游戏的具体代码,供大家参考,具体内容如下 刚学完了C语言,便尝试的写了贪吃蛇的代码,但是效果不佳,很多的bug,所以,这个学了C++,便重新的写了这个小游戏,用类来封装! 先是头文件: struct Snake { int x, y; }; class snake { public: snake() //构造函数 { length = 3; s[2].x = 10; s[2].y = 10; s[1].x = 9; s[1].y = 10; s[0].x =

  • C++实现简易贪吃蛇游戏

    C++实现建议贪吃蛇(不会闪屏幕) 使用vs2013完成.记录踏上游戏开发的道路. 效果图 代码 // 2021.7.24.1贪吃蛇.cpp : 定义控制台应用程序的入口点. // #include "stdafx.h" #include <iostream> #include <list> #include <numeric> #include <algorithm> #include <Windows.h> #includ

  • C++入门指南之贪吃蛇游戏的实现

    目录 参考 贪吃蛇游戏 程序框架 绘制游戏地图和蛇 小蛇向右移动 控制小蛇4个方向移动 时间控制的改进 失败判断与显示 添加食物 完整代码 总结 参考 <C和C++游戏趣味编程> 贪吃蛇游戏 键盘控制小蛇上.下.左.右移动,迟到食物后长度加1:蛇头碰到自身或窗口边缘,游戏失败 程序框架 #include <graphics.h> #include <conio.h> #include <stdio.h> // 全局变量定义 void startup() //

  • C++代码实现贪吃蛇小游戏

    本文实例为大家分享了C++实现贪吃蛇小游戏的具体代码,供大家参考,具体内容如下 1.游戏描述 贪吃蛇可谓是从小玩到大的经典趣味小游戏,蛇每吃到一次食物,身体就会长一节,如果撞到墙或者撞到自身,游戏结束. 2.代码实现 1.首先需要思考的问题是如何指定位置输出字符?这时候就有一个非常强大的函数叫 gotoxy() ,现在库函数里边已经没有了,只能我们自己实现,代码中注释很完整,自行阅读即可. 2.实现了指哪画哪的目标之后,就可以开始游戏内容制作了.首先便是圈地,即画地图,一个简简单单的循环就能安排

  • C++ 情怀游戏贪吃蛇的实现流程详解

    还记我们童年时的贪吃蛇吗,用"砖头"诺基亚玩的更是经典中的经典,贪食蛇操作简单,可玩性比较高.这个游戏难度最大的不是蛇长得很长的时候,而是开始.那个时候蛇身很短,看上去难度不大,却最容易死掉,因为把玩一条小短蛇让人容易走神,失去耐心.由于难度小,你会不知不觉加快调整方向的速度,在游走自如的时候蛇身逐渐加长了,而玩家却没有意识到危险,在最得意洋洋的一刻突然死亡. 1976年,Gremlin平台推出了一款经典街机游戏Blockade.游戏中,两名玩家分别控制一个角色在屏幕上移动,所经之处砌

  • Android开发之经典游戏贪吃蛇

    前言 这款游戏实现的思路和源码参考了Google自带的Snake的例子,其中修改了一些个人认为还不够完善的地方,加入了一些新的功能,比如屏幕上的方向操作盘,暂停按钮,开始按钮,退出按钮.另外,为了稍微增加些用户体验,除了游戏的主界面,本人自己新增了5个界面,分别是登陆界面,菜单界面,背景音乐设置界面,难度设置界面,还有个关于游戏的介绍界面.个人觉得在新手阶段,参考现成的思路和实现方式是难以避免的.重要的是我们需要有自己的理解,读懂代码之后,需要思考代码背后的实现逻辑,形成自己的思维.这样在下次开

  • C++ 情怀游戏扫雷的实现流程详解

    扫雷最原始的版本可以追溯到1973年一款名为"方块"的游戏. 不久,"方块"被改写成了游戏"Rlogic".在"Rlogic"里,玩家的任务是作为美国海军陆战队队员,为指挥中心探出一条没有地雷的安全路线,如果路全被地雷堵死就算输.两年后,汤姆·安德森在"Rlogic"的基础上又编写出了游戏"地雷",由此奠定了现代扫雷游戏的雏形. 1981年,微软公司的罗伯特·杜尔和卡特·约翰逊两位工程师

  • Python制作当年第一款手机游戏-贪吃蛇游戏(练习)

    目录 1. 创建游戏窗口 1.1 游戏初始化 1.2 初始化蛇的位置 蛇的长度 10 10 也就是蛇的 X Y 坐标 1.3 初始化食物的位置 1.4 开启游戏循环 1.5 填充背景为白色 1.6 绘制背景 1.7绘制蛇 2. 绘制贪吃蛇与食物 2.1 获取蛇的长度,移动蛇的身子 2.2 更改蛇头位置 2.3 键盘控制移动职位 2.4 获取蛇的长度,移动蛇的身子 3. 蛇吃食物 3.1 碰撞检测 如果蛇吃掉食物 3.2 如果蛇吃掉了自己 前言: 文章利用Python pygame做一个贪吃蛇的小

  • C语言 风靡一时的黄金矿工游戏实现流程详解

    游戏的玩法主要是通过不断采集地下的黄金和钻石,来得到更高的积分.只有完成任务目标,才可以通过相应的关卡.游戏画面中沙滩上的人物便是玩家的角色,下方深褐色的部分是地下,而黄金和钻石就是玩家需要采集的物品.人物右边的四个方框里的物品是游戏中可以使用的道具. 画面中的虚线就是游戏中的探测器,探测器会不断的左右摆动,当摆动到地下的黄金和钻石的位置时,只需要点击矿坑任意处,便可以发射勘探头采集到这些物品,当然一定要瞄准好再出手呦. 当然想要顺利采集到丰富的资源也不是那么简单的,地下矿坑中,会有各式各样的困

  • C语言 小游戏打砖块实现流程详解

    始祖是美国英宝格公司(en:Atari Games,ja:アタリ (ゲーム))于1976年推出的街机游戏"Breakout"(en:Breakout),由该公司在1972年发行的"PONG"(en:PONG,ja:ポン (ゲーム),世界上第一款电子游戏,类似台球)改良而来.相较于其前作,一个人就可以玩与变化丰富这两项特点让Breakout相当卖座,使各家公司竞相模仿. 因为规则简单与游戏性,现在许多移动电话都有内建打砖块游戏,也有许多因特网小游戏版本,目前在网上可以

  • C++ 风靡一时的连连看游戏的实现流程详解

    随着Flash应用的流行,网上出现了多种在线Flash版本"连连看".如"水晶连连看"."果蔬连连看"等,流行的"水晶连连看"以华丽界面吸引了一大批的女性玩家. 2008年,随着社交网络的普及和开放平台的兴起,"连连看"被引入了社交网络."连连看"与个人空间相结合,被快速的传播,成为一款热门的社交游戏,其中以开发者Jonevey在Manyou开放平台上推出的"宠物连连看&quo

  • 微信小程序支付及退款流程详解

    首先说明一下,微信小程序支付的主要逻辑集中在后端,前端只需携带支付所需的数据请求后端接口然后根据返回结果做相应成功失败处理即可.我在后端使用的是php,当然在这篇博客里我不打算贴一堆代码来说明支付的具体实现,而主要会侧重于整个支付的流程和一些细节方面的东西.所以使用其他后端语言的朋友有需要也是可以看一下的.很多时候开发的需求和相应问题的解决真的要跳出语言语法层面,去从系统和流程的角度考虑.好的,也不说什么废话了.进入正题. 一. 支付 支付主要分为几个步骤: 前端携带支付需要的数据(商品id,购

  • C++ 中国象棋的实现流程详解

    中国象棋的中国棋文化,也是中华民族的文化瑰宝,它源远流长,趣味浓厚,基本规则简明易懂.中国象棋在中国的群众中基础远远超过围棋,是普及最广的棋类项目,中国象棋已流传到十几个国家和地区. 中国象棋使用方形格状棋盘,圆形棋子共有32个,红黑二色各有16个棋子,摆放和活动在交叉点上.双方交替行棋,先把对方的将(帅)"将死"的一方获胜. 我们今天就来看看我们自己能不能写出这样一个游戏呢? 今天就不话不多说了,先说一下,今天我们做的是一个简易版的单机中国象棋,希望大家理解,联网对弈的话需要用到的知

  • Redis Sentinel服务配置流程(详解)

    1.Redis Sentinel服务配置 1.1简介 Redis 的 Sentinel 系统用于管理多个 Redis 服务器(instance), 该系统执行以下三个任务: 监控(Monitoring): Sentinel 会不断地检查你的主服务器和从服务器是否运作正常. 提醒(Notification): 当被监控的某个 Redis 服务器出现问题时, Sentinel 可以通过API 向管理员或者其他应用程序发送通知. 自动故障迁移(Automatic failover): 当一个主服务器不

随机推荐