贪吃蛇基础·框架版(简单)开头有原码

news2024/12/31 6:45:26

更新不易,麻烦多多点赞,欢迎你的提问,感谢你的转发,

最后的最后,关注我,关注我,关注我,你会看到更多有趣的博客哦!!!

喵喵喵,你对我真的很重要。

额,我有点晕了,今天先上框架版,晚上在进行优化,这个代码有点多,还跳来跳去,有F1和F2为实现,重新玩一次效果不佳,咬到自己那里的调用也有问题。

这是贪吃蛇的第一版,后期将会升级,希望可以弄懂每一步,而不是抄代码。

目录

原码,仅供侦错

首先的首先,这次我编译器是下面这个(需要安装包,请私信Q一下小喵),养成一个好习惯。

窗口设置

地图绘制

蛇结点创建

食物创建

键盘事件侦听

蛇的移动

​编辑

 屏幕提示

 结束页面

匹诺曹

结束页面实现及其子函数实现

开始页面

头文件

全局变量

函数声明

主函数

(水字数)贪吃蛇的游戏介绍

背景设定

操作指南

游戏特色

游戏评价


原码,仅供侦错

#include<stdio.h>
#include<stdlib.h>
#include<windows.h>//要使用windows的api ,lrq 
//因为要用到随机数函数,所以要调用time.h文件
#include<time.h> 
#include<conio.h>//用来接收键盘的输入输出 
//
//预定义
#define  U 1
#define  D 2
#define  L 3
#define  R 4
//U上 D下 L左 R右 
/
//定义全局变量 
typedef struct snake
{
	int x;
	int y;
	struct snake* next;
}snake;

snake *head;//指向蛇头的指针
snake *food;//创建的食物 
snake *q;//用来遍历蛇的结点的 
 
int status;
 
int add=10; //每个食物的得分 
int sumScore=0;//总得分 
int highScore=0;//最高分 

//三种结束状态变量
//1,撞墙    2,自己咬到自己了    3,主动退出 
int endGameStatus=0; 
   
//函数声明
void createMap();
//坐标转换
void gotoXY(int a,int b); 
//颜色更换
int color(int x);
//创建蛇
void initSnake(); 
//创建食物
void createFood(); 
//侦听键盘事件
void keyboardControl(); 
//让蛇动起来
int snakeMove();
//撞墙停止
int cantCrossWall();
//自己咬到自己
int biteSelf();
//主页面上小提示
void screenTips();
//结束页面 
void endGame();
//匹诺曹绘制
void LostDraw();
void File_In(); 
void File_Out();
void choose();
void printsnake();
void welcometoGame();

/*
	字符拼成英文图案
*/
void printsnake()
{
	color(2);
	printf("                                                                                         \n");
	printf("                       __________       ___                                              \n");
	printf("                      /          \\     / \\ \\    |____      __\\__                     \n");
	printf("                     /  ________  \\   / ___ \\  _/ __     | |   /                       \n");
	printf("                     |  |      |__|     _/_   |_|  /    [|] |/                           \n");
	printf("                     |  |              | | |      /     _|_ \\__/                        \n");
	printf("                     \\  \\_______        / \\      |___/        ____                    \n");
	printf("                      \\         \\    ____ ____      ____   __ |  |  ___   ______       \n");
	printf("                       \\_______  \\   |  |/    \\    /    \\_/ / |  | /  /  /      \\   \n");
	printf("                               \\  \\  |    ___  \\  / ____   /  |  |/  /  /  ____  \\   \n");
	printf("                     __        |  |  |   /   \\  \\ | |  |  /   |     /  |  /____\\  |   \n");
	printf("                    \\  \\_______|  |  |  |    |  | | |__|  |   |     \\  |  ________/   \n");
	printf("                     \\            /  |  |    |  |  \\       \\  |  |\\  \\  \\  \\____  \n");
	printf("                      \\__________/   |__|    |__|   \\___/\\__\\ |__| \\__\\  \\______/ \n");

}
void welcometoGame()
{
	int n=0;
	int i=0;
	int j=0;
	gotoXY(43,18);
	color(11);
	printf("贪 吃 蛇 游 戏");
	color(14);
	for(i=20;i<=26;i++)
	{
		
		for(j=27;j<=74;j++)
		{
		    gotoXY(j,i);
		    if(i==20 ||i==26)
			{
			printf("-");
		    }else if(j==27||j==74)
		    {
			printf("|");
			}
		} 
	}
	gotoXY(36,22);
	color(10);
	printf("1.开始游戏");
	gotoXY(50,22);
	color(10);
	printf("2.游戏说明");
    gotoXY(36,24);
	color(10);
	printf("3.退出游戏");
    gotoXY(28,27);
    color(3);
    printf("请选择[1 2 3]:[ ]\b\b");//\b是退格使光标处于两个中括号之间
	color(14);
	scanf("%d",&n);
	switch(n)
	{
	case 1:
		system("cls");
		File_Out();
		sumScore=0;
		createMap();
		screenTips();
		initSnake();
		createFood();
		keyboardControl();
		break;
	case 2:
		//游戏说明界面 
		break;
	case 3:
		exit(0); 
		break;
	default:
		break;
		
	} 
			
}



void endGame()
{
	//清屏操作 
	system("cls");
	LostDraw();
	if(endGameStatus==1)
	{
		//TODO
		gotoXY(35,9);
		color(7);
		printf("对不起,你撞墙了!游戏结束"); 
	}else if(endGameStatus==2)
		{
			//TODO
			gotoXY(35,9);
			color(7);
			printf("对不起,你咬到自己了!游戏结束"); 
		}
	else if(endGameStatus==3)
			{
				//TODO
				gotoXY(35,9);
				color(7);
				printf("游戏结束!"); 
			} 
	gotoXY(43,12);
	printf("你的得分是:%d分",sumScore);
	//判断得分是否需要存储
	if(sumScore>=highScore)
	{
		color(10);
		gotoXY(33,16);
		printf("创纪录了,最高分被你刷新了!"); 
		//最高分存入文件当中 
		File_In();
	} else{
		gotoXY(33,16);
		printf("继续努力吧~你离最高分还差:%d",highScore-sumScore);
	} 
	//调用选择选项
	 choose(); 
	
}


void choose()
{
	int n=0;
	gotoXY(30,23);
	color(12);
	printf("重玩一局[1]");
	gotoXY(50,23);
	printf("溜了溜了[2]");
	gotoXY(43,25);
	printf("选择:");
	scanf("%d",&n);
	switch(n)
	{
		case 1:
			system("cls");
		    printsnake();
		    //开始界面
			 welcometoGame(); 
			break;
		case 2:
			exit(0);
			break;
		default:
			gotoXY(35,27);
			color(12);
			printf("你输入的有误,请重新输入");
			break; 
			
	} 
} 


//文件读写
void File_In()
{
	//定义文件指针 
	FILE *fp;
	//指针关联文件 
	fp=fopen("save.txt","w+");
	//通过文件指针向文件写入内容 
	fprintf(fp,"%d",sumScore);
	//关闭文件 
	fclose(fp);
}

void File_Out()
{
	FILE *pp;
	pp=fopen("save.txt","a+");
	fscanf(pp,"%d",&highScore);
	fclose(pp);
	
}


void LostDraw() {
	/*
		失败界面
	*/
	system("cls");
	int i;
    gotoXY(45, 1);
	color(6);
	printf(" |-----|   ");		//匹诺曹的帽子
	gotoXY(45, 2);
	color(6);
	printf(" |     |   ");
	gotoXY(43, 3);
	color(6);
	printf("-------------");

	gotoXY(44, 4);
	color(14);
	printf("(");

	gotoXY(47, 4);
	color(15);
	printf(" > <");				//眼睛

	gotoXY(54, 4);
	color(14);
	printf(")");

	gotoXY(17, 5);
	color(11);
	printf("+------------------------");	//上边框

	gotoXY(35, 5);
	color(14);
	printf("oOOo");

	gotoXY(39, 5);
	color(11);
	printf("----------");					//上边框

	gotoXY(48, 5);
	color(14);
	printf("| |");				//鼻子
	gotoXY(48, 6);
	color(14);
	printf("|_|");

	gotoXY(51, 5);
	color(11);
	printf("----------");					//上边框

	gotoXY(61, 5);
	color(14);
	printf("oOOo");

	gotoXY(65, 5);
	color(11);
	printf("-----------------+");			//上边框

	for (i = 6; i <= 19; i++) {				//竖边框
		gotoXY(17, i);
		printf("|");
		gotoXY(82, i);
		printf("|");
	}

	gotoXY(17, 20);
	printf("+------------------------------------------");	//下边框

	gotoXY(60, 20);
	color(11);
	printf("----------------------+");						//下边框



}


void screenTips(){
	color(11);
	gotoXY(64,4);
	printf("☆最高记录是:%d☆",highScore);
	color(14);
	gotoXY(64,6);
	printf("当前得分:%d",sumScore);
	gotoXY(73,11);
	printf("小提示");
	
	gotoXY(60,13);
	color(6);
	printf("§--------------------§");
	
	gotoXY(60,26);
	color(6);
	printf("§--------------------§");
	
	gotoXY(64,14);
	color(3);
	printf("每个食物得分:%d分",add);
	
	gotoXY(64,16);
	printf("不能撞墙,不能咬到自己");

	gotoXY(64,18);
	printf("用上,下,左,右箭头分别控制方向");	
	
	gotoXY(64,20);
	printf("F1键加速,F2键减速");
	
	gotoXY(64,22);
	printf("空格键暂停游戏");
	
	gotoXY(64,24);
	printf("Esc键退出游戏");
	 
} 


int biteSelf()
{
	snake *self;//这里不涉及内存分配,它只是涉及只向的内容的变化
	self=head->next;
	while(self!=NULL)
	{
		//TODO 
		if(self->x==head->x&&self->y==head->y)
			{
				return 1;
			} 
		self = self->next;
	}
    return 0;
}


int cantCrossWall(){
	if(head->x==0||head->x==56||head->y==0||head->y==26)
	{
		system("cls");
		gotoXY(30,6);
		printf("撞墙了");
		return 1;
	}
	return 0;
} 
 
 
int snakeMove()
{
	snake *newNode;
	
	newNode = (snake*)malloc(sizeof(snake));
	if(status==U)
	{
		newNode->x=head->x;
		newNode->y=head->y-1;
	}
    if (status == D) {
		newNode->x = head->x;
		newNode->y = head->y + 1;
	}
	if (status == L) {
		newNode->x = head->x - 2;
		newNode->y = head->y;
	}
	if (status == R) {
		//TODO
		newNode->x = head->x + 2;
		newNode->y = head->y;
	}

		newNode->next=head;
		//将新的结点赋值给head 
		head=newNode;
		if(cantCrossWall())
		{
				status = 0;
				endGame();
				return 3;
		} 
		
		//判断新的结点是否有食物
		q=head;
		if(newNode->x==food->x&&newNode->y==food->y)
		{
			while(q!=NULL)
			{
				//TODO
				gotoXY(q->x,q->y);
				color(14);
				printf("◆");
				q=q->next;
			}
			//吃掉食物过后总分要加上单个食物的分值 
			sumScore+=add;
			//调用一次
			screenTips(); 
			//食物被吃掉了,再创建一个
			createFood(); 
			
		} else{
		        while(q->next->next!=NULL)
					{
						//TODO
						gotoXY(q->x,q->y);
						color(14);
						printf("◆");
						q=q->next;
					}
					//把倒数第一个变成原来的地图形状
					gotoXY(q->next->x,q->next->y);
					color(3);
					printf("■");
					//释放内存和指针
					free(q->next);
					q->next=NULL; 
	          }
	          if(biteSelf()==1)
	          {
			  	endGame(); 
				  return 2; 
			  }
	return 0;
}


void keyboardControl()
{
	status =R;//默认向右走 *
	while(1)
	{
		//TODO
		//侦听所有键盘事件状态 
		if(GetAsyncKeyState(VK_UP)&&status !=D)
		{
			//需要一个变量,来接收是哪个键按下去了 
			status =U; 
		}else if(GetAsyncKeyState(VK_DOWN)&&status !=U)
		{
			status=D;
		}
		else if(GetAsyncKeyState(VK_LEFT)&&status !=R)
		{
			status=L;
		}
		else if(GetAsyncKeyState(VK_RIGHT)&&status !=L)
		{
			status=R;
		}
		//空格键游戏暂停,蛇停止运动
		if(GetAsyncKeyState(VK_SPACE))
		{
			//TODO
			//第一次按空格键,进程挂起, 
			while(1)
			{
				Sleep(300);
				//第二次空格键,进程退出 
				if(GetAsyncKeyState(VK_SPACE))
				{
					break;
				}
			}//按下ESC键,游戏结束 
		} else if(GetAsyncKeyState(VK_ESCAPE)){
			endGameStatus=3;
			endGame();
			break; 
		}
		Sleep(300);
		//让蛇动起来 
		if(snakeMove()!=0)
		{
			break;
		}
	}
}


void createFood()
{
	snake* food1;
	food1=(snake*)malloc(sizeof(snake)); 
	//加上随机数种子,防止伪随机
	srand((unsigned)time(NULL)); 
	food1->x=rand()%53+2;//2.54没听懂?问问
	//【2~54】
	while(food1->x%2!=0)
	{
		//TODO
		food1->x=rand()%53+2;
	}
	food1->y=rand()%23+1;//?2.58
	//food1->next=NULL;?
	q=head;
	while(q->next!=NULL)
	{
		if(q->x==food1->x&&q->y==food1->y)
		{
			free(food1);
			createFood();//如果和蛇身重合了,就再次创建食物 
		}
		q=q->next; 
	}
	//把食物打出来
	gotoXY(food1->x,food1->y);
	color(10);
	printf("●");
	food=food1;
}



void initSnake()
{
	int i=1;
	color(15);
	snake *ss;//结点 
	//分配内存空间,使用头插法(单链表),以设定的x,y位置开始插入
	ss =(snake*)malloc(sizeof(snake));//?
	ss->x=24;
	ss->y=5;
	ss->next=NULL; 
	//利用头插法,插入剩下的四个结点 
	for(i=1;i<=4;i++)
	{
	head=(snake*)malloc(sizeof(snake));
	head->next=ss;
	head->x=24+i*2;
	head->y=5;
	ss=head;//将蛇头变成蛇尾,然后重复循环 
	}
	//打印蛇身
	while(ss!=NULL)
	{
		//TODO
		gotoXY(ss->x,ss->y);
		printf("◆");
		ss=ss->next;
	} 
}

int color(int x)
{
	//更改待打印颜色属性 
	SetConsoleTextAttribute(GetStdHandle(STD_OUTPUT_HANDLE),x); 
	return 0;
} 


void gotoXY(int a,int b)
{
	COORD c;//生成c的实例 
	c.X=a;
	c.Y=b;
	SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE),c); 
}
//函数定义/函数实现
 void createMap()
 {
 	int i,j;
 	color(6);//0~255 
 	//两个for填边框的色 
 	for(i=0;i<58;i+=2)
 	{
	 	gotoXY(i,0);
	 	printf("□");
	 	gotoXY(i,26);
	 	printf("□");
	 }
 	for(i=1;i<26;i++)
 	{
	 	gotoXY(0,i);
		printf("□");
		gotoXY(56,i);
		printf("□");
	 }
	 //填中间的色 
	 color(3); 
	 for(i=2;i<56;i+=2)
	 {
	 	for(j=1;j<26;j++)
	 	{
		 	gotoXY(i,j);
		 	printf("■");
		 } 
	 }
	    
 } 
 
 
int main()
{
	//设置控制台的宽高 
	    system("mode con cols=110 lines=30");
	    printsnake();
	    welcometoGame();
		while(1)
		{
			
		} 
	return 0;
}

首先的首先,这次我编译器是下面这个(需要安装包,请私信Q一下小喵),养成一个好习惯。

 好习惯:

一切以整体原代码为准,图片介绍仅供参考。没完成一步,建议编译一下,进行阶段性测试,这是一个非常实用的习惯,可以把bug缩小到子程序的范围,保证800来行代码的完成效率,谢谢。

小喵觉得图片能更加直观的展示代码(颜色有直观的区别),便于侦错,但csdn系统希望小喵有更完善的描述,所有小喵会附上局部代码,仅供侦错,难免重复,麻烦谅解,水一水字数了。


窗口设置


地图绘制

局部代码(仅供侦错)

void gotoXY(int a,int b)
{
	COORD c;//生成c的实例 
	c.X=a;
	c.Y=b;
	SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE),c); 
}
//函数定义/函数实现
 void createMap()
 {
 	int i,j;
 	color(6);//0~255 
 	//两个for填边框的色 
 	for(i=0;i<58;i+=2)
 	{
	 	gotoXY(i,0);
	 	printf("□");
	 	gotoXY(i,26);
	 	printf("□");
	 }
 	for(i=1;i<26;i++)
 	{
	 	gotoXY(0,i);
		printf("□");
		gotoXY(56,i);
		printf("□");
	 }
	 //填中间的色 
	 color(3); 
	 for(i=2;i<56;i+=2)
	 {
	 	for(j=1;j<26;j++)
	 	{
		 	gotoXY(i,j);
		 	printf("■");
		 } 
	 }
	    
 } 

写一个颜色变换的函数

进行阶段性测试

说明其中的函数


蛇结点创建

void initSnake()
{
	int i=1;
	color(15);
	snake *ss;//结点 
	//分配内存空间,使用头插法(单链表),以设定的x,y位置开始插入
	ss =(snake*)malloc(sizeof(snake));//?
	ss->x=24;
	ss->y=5;
	ss->next=NULL; 
	//利用头插法,插入剩下的四个结点 
	for(i=1;i<=4;i++)
	{
	head=(snake*)malloc(sizeof(snake));
	head->next=ss;
	head->x=24+i*2;
	head->y=5;
	ss=head;//将蛇头变成蛇尾,然后重复循环 
	}
	//打印蛇身
	while(ss!=NULL)
	{
		//TODO
		gotoXY(ss->x,ss->y);
		printf("◆");
		ss=ss->next;
	} 
}


食物创建

void createFood()
{
	snake* food1;
	food1=(snake*)malloc(sizeof(snake)); 
	//加上随机数种子,防止伪随机
	srand((unsigned)time(NULL)); 
	food1->x=rand()%53+2;//2.54没听懂?问问
	//【2~54】
	while(food1->x%2!=0)
	{
		//TODO
		food1->x=rand()%53+2;
	}
	food1->y=rand()%23+1;//?2.58
	//food1->next=NULL;?
	q=head;
	while(q->next!=NULL)
	{
		if(q->x==food1->x&&q->y==food1->y)
		{
			free(food1);
			createFood();//如果和蛇身重合了,就再次创建食物 
		}
		q=q->next; 
	}
	//把食物打出来
	gotoXY(food1->x,food1->y);
	color(10);
	printf("●");
	food=food1;
}


键盘事件侦听

void keyboardControl()
{
	status =R;//默认向右走 
	while(1)
	{
		//TODO
		//侦听所有键盘事件状态 
		if(GetAsyncKeyState(VK_UP)&&status !=D)
		{
			//需要一个变量,来接收是哪个键按下去了 
			status =U; 
		}else if(GetAsyncKeyState(VK_DOWN)&&status !=U)
		{
			status=D;
		}
		else if(GetAsyncKeyState(VK_LEFT)&&status !=R)
		{
			status=L;
		}
		else if(GetAsyncKeyState(VK_RIGHT)&&status !=L)
		{
			status=R;
		}
		Sleep(500);
		//让蛇动起来 
		snakeMove(); 
	}
}

蛇的移动

  

//让蛇动起来
void snakeMove();
 
void snakeMove()
{
	snake *newNode;
	
	newNode = (snake*)malloc(sizeof(snake));
	if(status==U)
	{
		newNode->x=head->x;
		newNode->y=head->y-1;
	}
    if (status == D) {
		newNode->x = head->x;
		newNode->y = head->y + 1;
	}
	if (status == L) {
		newNode->x = head->x - 2;
		newNode->y = head->y;
	}
	if (status == R) {
		//TODO
		newNode->x = head->x + 2;
		newNode->y = head->y;
	}

		newNode->next=head;
		//将新的结点赋值给head 
		head=newNode;
		//判断新的结点是否有食物
		q=head;
		if(newNode->x==food->x&&newNode->y==food->y)
		{
			while(q!=NULL)
			{
				//TODO
				gotoXY(q->x,q->y);
				color(14);
				printf("◆");
				q=q->next;
			}
			//食物被吃掉了,再创建一个
			createFood(); 
		} else{
		        while(q->next->next!=NULL)
					{
						//TODO
						gotoXY(q->x,q->y);
						color(14);
						printf("◆");
						q=q->next;
					}
					//把倒数第一个变成原来的地图形状
					gotoXY(q->next->x,q->next->y);
					color(3);
					printf("■");
					//释放内存和指针
					free(q->next);
					q->next=NULL; 
	          }
	
}

 蛇是可以动起来了,但蛇撞墙后出bug,要进行进一步修改

 屏幕提示

全局变量:

 子程序

//主页面上小提示
void screenTips();

void screenTips(){
	color(11);
	gotoXY(64,4);
	printf("☆最高记录是:53☆");
	color(14);
	gotoXY(64,6);
	printf("当前得分:20");
	gotoXY(73,11);
	printf("小提示");
	
	gotoXY(60,13);
	color(6);
	printf("§--------------------§");
	
	gotoXY(60,26);
	color(6);
	printf("§--------------------§");
	
	gotoXY(64,14);
	color(3);
	printf("每个食物得分:%d分",add);
	
	gotoXY(64,16);
	printf("不能撞墙,不能咬到自己");

	gotoXY(64,18);
	printf("用上,下,左,右箭头分别控制方向");	
	
	gotoXY(64,20);
	printf("F1键加速,F2键减速");
	
	gotoXY(64,22);
	printf("空格键暂停游戏");
	
	gotoXY(64,24);
	printf("Esc键退出游戏");
	 
} 

 结束页面

匹诺曹

void LostDraw() {
	/*
		失败界面
	*/
	system("cls");
	int i;
    gotoXY(45, 1);
	color(6);
	printf(" |-----|   ");		//匹诺曹的帽子
	gotoXY(45, 2);
	color(6);
	printf(" |     |   ");
	gotoXY(43, 3);
	color(6);
	printf("-------------");

	gotoXY(44, 4);
	color(14);
	printf("(");

	gotoXY(47, 4);
	color(15);
	printf(" > <");				//眼睛

	gotoXY(54, 4);
	color(14);
	printf(")");

	gotoXY(17, 5);
	color(11);
	printf("+------------------------");	//上边框

	gotoXY(35, 5);
	color(14);
	printf("oOOo");

	gotoXY(39, 5);
	color(11);
	printf("----------");					//上边框

	gotoXY(48, 5);
	color(14);
	printf("| |");				//鼻子
	gotoXY(48, 6);
	color(14);
	printf("|_|");

	gotoXY(51, 5);
	color(11);
	printf("----------");					//上边框

	gotoXY(61, 5);
	color(14);
	printf("oOOo");

	gotoXY(65, 5);
	color(11);
	printf("-----------------+");			//上边框

	for (i = 6; i <= 19; i++) {				//竖边框
		gotoXY(17, i);
		printf("|");
		gotoXY(82, i);
		printf("|");
	}

	gotoXY(17, 20);
	printf("+------------------------------------------");	//下边框

	gotoXY(60, 20);
	color(11);
	printf("----------------------+");						//下边框



}

结束页面实现及其子函数实现

void endGame()
{
	//清屏操作 
	system("cls");
	LostDraw();
	if(endGameStatus==1)
	{
		//TODO
		gotoXY(35,9);
		color(7);
		printf("对不起,你撞墙了!游戏结束"); 
	}else if(endGameStatus==2)
		{
			//TODO
			gotoXY(35,9);
			color(7);
			printf("对不起,你咬到自己了!游戏结束"); 
		}
	else if(endGameStatus==3)
			{
				//TODO
				gotoXY(35,9);
				color(7);
				printf("游戏结束!"); 
			} 
	gotoXY(43,12);
	printf("你的得分是:%d分",sumScore);
	//判断得分是否需要存储
	if(sumScore>=highScore)
	{
		color(10);
		gotoXY(33,16);
		printf("创纪录了,最高分被你刷新了!"); 
		//最高分存入文件当中 
		File_In();
	} else{
		gotoXY(33,16);
		printf("继续努力吧~你离最高分还差:%d",highScore-sumScore);
	} 
	//调用选择选项
	 choose(); 
	
}


void choose()
{
	int n=0;
	gotoXY(30,23);
	color(12);
	printf("重玩一局[1]");
	gotoXY(50,23);
	printf("溜了溜了[2]");
	gotoXY(43,25);
	printf("选择:");
	scanf("%d",&n);
	switch(n)
	{
		case 1:
			system("cls");
		    printsnake();
		    //开始界面
			 welcometoGame(); 
			break;
		case 2:
			exit(0);
			break;
		default:
			gotoXY(35,27);
			color(12);
			printf("你输入的有误,请重新输入");
			break; 
			
	} 
} 


//文件读写
void File_In()
{
	//定义文件指针 
	FILE *fp;
	//指针关联文件 
	fp=fopen("save.txt","w+");
	//通过文件指针向文件写入内容 
	fprintf(fp,"%d",sumScore);
	//关闭文件 
	fclose(fp);
}

void File_Out()
{
	FILE *pp;
	pp=fopen("save.txt","a+");
	fscanf(pp,"%d",&highScore);
	fclose(pp);
	
}

开始页面

/*
	字符拼成英文图案
*/
void printsnake()
{
	color(2);
	printf("                                                                                         \n");
	printf("                       __________       ___                                              \n");
	printf("                      /          \\     / \\ \\    |____      __\\__                     \n");
	printf("                     /  ________  \\   / ___ \\  _/ __     | |   /                       \n");
	printf("                     |  |      |__|     _/_   |_|  /    [|] |/                           \n");
	printf("                     |  |              | | |      /     _|_ \\__/                        \n");
	printf("                     \\  \\_______        / \\      |___/        ____                    \n");
	printf("                      \\         \\    ____ ____      ____   __ |  |  ___   ______       \n");
	printf("                       \\_______  \\   |  |/    \\    /    \\_/ / |  | /  /  /      \\   \n");
	printf("                               \\  \\  |    ___  \\  / ____   /  |  |/  /  /  ____  \\   \n");
	printf("                     __        |  |  |   /   \\  \\ | |  |  /   |     /  |  /____\\  |   \n");
	printf("                    \\  \\_______|  |  |  |    |  | | |__|  |   |     \\  |  ________/   \n");
	printf("                     \\            /  |  |    |  |  \\       \\  |  |\\  \\  \\  \\____  \n");
	printf("                      \\__________/   |__|    |__|   \\___/\\__\\ |__| \\__\\  \\______/ \n");

}
void welcometoGame()
{
	int n=0;
	int i=0;
	int j=0;
	gotoXY(43,18);
	color(11);
	printf("贪 吃 蛇 游 戏");
	color(14);
	for(i=20;i<=26;i++)
	{
		
		for(j=27;j<=74;j++)
		{
		    gotoXY(j,i);
		    if(i==20 ||i==26)
			{
			printf("-");
		    }else if(j==27||j==74)
		    {
			printf("|");
			}
		} 
	}
	gotoXY(36,22);
	color(10);
	printf("1.开始游戏");
	gotoXY(50,22);
	color(10);
	printf("2.游戏说明");
    gotoXY(36,24);
	color(10);
	printf("3.退出游戏");
    gotoXY(28,27);
    color(3);
    printf("请选择[1 2 3]:[ ]\b\b");//\b是退格使光标处于两个中括号之间
	color(14);
	scanf("%d",&n);
	switch(n)
	{
	case 1:
		system("cls");
		File_Out();
		sumScore=0;
		createMap();
		screenTips();
		initSnake();
		createFood();
		keyboardControl();
		break;
	case 2:
		//游戏说明界面 
		break;
	case 3:
		exit(0); 
		break;
	default:
		break;
		
	} 
			
}

头文件

#include<stdio.h>
#include<stdlib.h>
#include<windows.h>//要使用windows的api ,lrq 
//因为要用到随机数函数,所以要调用time.h文件
#include<time.h> 
#include<conio.h>//用来接收键盘的输入输出 
//
//预定义
#define  U 1
#define  D 2
#define  L 3
#define  R 4
//U上 D下 L左 R右 

全局变量

//定义全局变量 
typedef struct snake
{
	int x;
	int y;
	struct snake* next;
}snake;

snake *head;//指向蛇头的指针
snake *food;//创建的食物 
snake *q;//用来遍历蛇的结点的 
 
int status;
 
int add=10; //每个食物的得分 
int sumScore=0;//总得分 
int highScore=0;//最高分 

//三种结束状态变量
//1,撞墙    2,自己咬到自己了    3,主动退出 
int endGameStatus=0; 

函数声明

//函数声明
void createMap();
//坐标转换
void gotoXY(int a,int b); 
//颜色更换
int color(int x);
//创建蛇
void initSnake(); 
//创建食物
void createFood(); 
//侦听键盘事件
void keyboardControl(); 
//让蛇动起来
int snakeMove();
//撞墙停止
int cantCrossWall();
//自己咬到自己
int biteSelf();
//主页面上小提示
void screenTips();
//结束页面 
void endGame();
//匹诺曹绘制
void LostDraw();
void File_In(); 
void File_Out();
void choose();
void printsnake();
void welcometoGame();

主函数

int main()
{
	//设置控制台的宽高 
	    system("mode con cols=110 lines=30");
	    printsnake();
	    welcometoGame();
		while(1)
		{
			
		} 
	return 0;
}

(水字数)贪吃蛇的游戏介绍

背景设定

编辑 播报

贪食蛇游戏图面(19张)

1976年,Gremlin平台推出了一款经典街机游戏Blockade。游戏中,两名玩家分别控制一个角色在屏幕上移动,所经之处砌起围栏。角色只能向左、右方向90度转弯,游戏目标保证让对方先撞上屏幕或围栏。 听起来有点复杂,其实就是下面这个样子:

基本上就是两条每走一步都会长大的贪吃蛇比谁后完蛋,玩家要做的就是避免撞上障碍物和越来越长的身体。更多照片、视频可以看 GamesDBase 的介绍。

Blockade 很受欢迎,类似的游戏先后出现在 Atari 2600、TRS-80、苹果 2 等早期游戏机、计算机上。但真正让这种游戏形式红遍全球的还是21年后随诺基亚手机走向世界的贪吃蛇游戏——Snake。

操作指南

编辑 播报

玩家使用方向键操控一条长长的蛇不断吞下豆子,同时蛇身随着吞下的豆子不断变长,当蛇头撞到蛇身或障壁时游戏结束。贪吃蛇最初为人们所知的是诺基亚手机附带的一个小游戏,它伴随着诺基亚手机走向世界。现在的贪吃蛇出现了许多衍生版本,并被移植到各种平台上。

游戏特色

编辑 播报

贪吃蛇原型游戏图片

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

贪食蛇的另一个危险期在于游戏开始几十秒之后。由于玩家的注意力高度集中,精神紧张,此时局面稍好,就会不由自主地想放松一下,结果手指一松劲,贪食蛇就死了。所以贪食蛇可以算作一个敏捷型的小游戏。

游戏评价

编辑 播报

贪吃蛇游戏画面

和别的游戏不同,贪食蛇是一个悲剧性的游戏。许多电子游戏都是以操作者的胜利而告终,而贪食蛇的结局却是死亡。不管玩得多么纯熟,技术多么高超,你最终听到的都是贪食蛇的一声惨叫。当手机上的小蛇越长越长,积分越来越高的时候,死亡也就越来越近。那时候忙的不是为了吃豆子长身体,而是为了避免撞墙。你会发现你穷于应付,四处奔忙。贪食蛇最要命的就在一个“贪”字上。

要死,要死,要死,我现在就剩一口气了,啊————。

本来想边敲边写的,可是代码跳来跳去,我的灵魂已经跑出来了,明天再梳理一遍,这一篇博客是16个40分钟的成果,我想一篇博客讲完,脑壳有点疼。希望明天梳理会好用些,今天我已经吐血了。

更新不易,麻烦多多点赞,欢迎你的提问,感谢你的转发,

最后的最后,关注我,关注我,关注我,你会看到更多有趣的博客哦!!!

喵喵喵,你对我真的很重要。

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

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

相关文章

XStream < 1.4.20 栈缓冲区溢出漏洞

漏洞描述 XStream 是一个轻量级的、简单易用的开源Java类库&#xff0c;它主要用于将对象序列化成XML&#xff08;JSON&#xff09;或反序列化为对象。 在1.4.20之前的版本中存在栈缓冲区溢出漏洞&#xff0c;从而导致通过操纵已处理的输入流来造成拒绝服务。 在使用集合和映…

一文掌握FastDeploy Serving服务化部署(打造线上证件照制作系统,含完整代码)

目录一、概述1.1 服务化部署1.2 FastDeploy简介二、搭建线上证件照制作系统2.1 准备环境2.1.1 安装Docker2.1.2 安装NVIDIA Container Toolkit2.1.3 获取FastDeploy Serving镜像2.2 部署模型2.2.1 准备模型仓库2.2.2 编写配置文件config.pbtxt2.2.3 服务启动2.3.4 测试访问2.3 …

盒子模型、CSS 中选择器优先级以及权重计算、px、em 和 rem 的区别

CSS 的盒模型&#xff1f; 盒子模型&#xff08;Box Modle&#xff09;可以用来对元素进行布局&#xff0c;包括内边距&#xff0c;边框&#xff0c;外边距&#xff0c;和实际 内容这几个部分 盒子模型分为两种 第一种是 W3C 标准的盒子模型&#xff08;标准盒模型&#xff09;…

微软 Outlook 如何修改邮件列表中的字体或字号

因为电脑的操作系统是默认英文的&#xff0c;默认的字体实在是太难看了。 解决方案 我们是可以对字体进行修改的。 例如修改成下面的方案。 选择视图 首先&#xff0c;先选定顶部的视图。 然后在当前的视图下&#xff0c;选择视图设置。 随后在弹出的窗口中&#xff0c;选择…

一劳永逸解决latex 80%bug

Latex编辑器也用过很多了&#xff0c;这种问题出现&#xff0c;一般就是}没对应啥的&#xff0c;但是这次检查了半天&#xff0c;就是找不到问题。 最后有一个快捷的解决方案&#xff0c;就是overleafhttps://www.overleaf.com/project/6347bab20a4c120392547ff3 写文章五六年…

美颜sdk是如何美化皮肤的?

当下&#xff0c;互联网娱乐飞速发展&#xff0c;一些社交拍摄的平台逐渐爆火&#xff0c;例如短视频和直播类平台&#xff0c;此类平台基本都需要真人出镜&#xff0c;因此大家或多或少都有些“颜值焦虑”&#xff0c;平台方也正是因为这个原因&#xff0c;开始为大家接入美颜…

Mathorcup数学建模竞赛第五届-【妈妈杯】D题:图像去噪中几类稀疏变换的矩阵表示(附特等奖获奖论文和matlab代码实现)

赛题描述 假设一幅二维灰度图像 X 受到加性噪声的干扰:Y=X+N , Y 为观察到的噪声图像, N 为噪声。通过对于图像 Y 进行稀疏表示可以达到去除噪声的目的。任务: 2. 利用 Cameraman 图像中的一个小图像块(见图 1 )进行验证。 3. 分析稀疏系数矩阵,比较四种方法…

写作历时一个月,长达8000字的年终总结——[2022年终总结]不要怕,请勇敢的向前走

个人博客&#xff1a;武师叔 ❤️ 做一个有趣而不甘平庸的人&#xff01;&#xff01;❤️ 哈喽哈喽&#xff0c;好久不见&#xff0c;我的老朋友最近还好吗 距离上次7.21凌晨1:06完稿的【年中总结】&#xff0c;下半年也匆匆过去啦~ 其实总的来说&#xff0c;下半年过得并不…

医药流通企业如何安全访问医药ERP?无需公网IP和改变现有IT架构

随着目前医药流通行业竞争的加剧&#xff0c;市场供应日趋饱和&#xff0c;传统的粗放式管理缺陷逐渐暴露&#xff0c;导致从事医药行业企业的利润不同程度的下滑&#xff0c;想要满足医药行业客户的个性化需求&#xff0c;为适应企业未来发展&#xff0c;医药流通行业越来越多…

2022 IoTDB Summit:Apache IoTDB PMC 张金瑞《为物联网场景优化的时序数据库共识协议》...

12 月 3 日、4日&#xff0c;2022 Apache IoTDB 物联网生态大会在线上圆满落幕。大会上发布 Apache IoTDB 的分布式 1.0 版本&#xff0c;并分享 Apache IoTDB 实现的数据管理技术与物联网场景实践案例&#xff0c;深入探讨了 Apache IoTDB 与物联网企业如何共建活跃生态&#…

再学C语言19:循环控制语句——关系运算符

关系表达式&#xff08;relational expression&#xff09;&#xff1a;进行比较的判断表达式 关系运算符&#xff08;relational operator&#xff09;&#xff1a;关系表达式中出现的运算符 一、关系运算符 关系运算符运算符含义<小于<小于或等于等于>大于或等于&…

第二十一讲:神州路由器RIP路由的配置

设备 端口 IP 子网掩码 网关 Router-A F0/0 192.168.1.1 255.255.255.0 无 F0/3 192.168.10.1 255.255.255.0 无 Router-B F0/0 192.168.1.2 255.255.255.0 无 F0/3 192.168.20.1 255.255.255.0 无 PC1 192.168.10.2 255.255.255.0 192.168.10.1 PC…

超店有数丨tiktok必备选品和带货技巧!小白秒变大神!

有一些刚刚入门的小白缺乏跨境电商选品灵感&#xff0c;苦于不知道从哪里挖掘爆款产品&#xff0c;不知如何发现热门商家。如果你也面临着这些困扰&#xff0c;可以试试超店有数&#xff0c;它是专业的第三方数据服务平台&#xff0c;能够帮助商家发现热门种草视频、进行小店数…

【C++、数据结构】二叉搜索树 模拟实现

文章目录&#x1f4d6; 前言1. 二叉搜索树2. 二叉搜索树的模拟实现2.1 结点的声明2.2 基本的几个成员函数非递归版本&#xff08;1&#xff09;查找&#xff1a;&#xff08;2&#xff09;插入&#xff1a;&#xff08;4&#xff09;删除&#xff1a;&#xff08;重点&#xff…

你阳了吗?可以接种最新加强针疫苗了!

今天不聊技术&#xff0c;唠唠嗑。刚才得知室友全部阳了&#xff0c;不知道我还能撑到多会&#x1f926;‍♂️当前时间&#xff0c;距离全国抗疫政策转向已有一个月时间&#xff0c;大家都不可避免的直面新冠病毒。奥密克戎的传播能力果然很强&#xff0c;短短半个月时间从周围…

Docker- 7.2、跨主机网络-overlay

Docker提供了overlay driver&#xff0c;使用户可以创建基于VxLan的overlay网络。VxLAN可将二层数据封装到UDP进行传输&#xff0c;VxLAN提供与VLAN相同的以太网二层服务&#xff0c;但拥有更强的扩展性和灵活性。Docker overlay网络需要一个key-value数据库用于保存网络状态信…

嵌入式C语言设计模式 --- 工厂方法模式

1 - 什么是工厂方法模式? 前一篇文章讲述了在使用简单工厂模式的时候,有一个明显的缺陷,就是我们添加一款新的LCD控制器的时候,需要修改工厂类的构造函数(因为只有一家工厂),在switch-case里面新增一个条件项,违背了面向对象设计的“开闭原则”。 为了解决这个问题,可…

让自己成为一个创作者

写博客三年多&#xff0c;创作不易&#xff0c;以下是自己的一点感悟&#xff0c;大家共勉&#xff01; “千万不要把“创作”当成是一件很大的事情&#xff0c;那只是思维方式和行为的转变而已&#xff01;” 01 — 我有个爱好--打游戏&#xff0c; 特别喜欢宫崎英高的魂系…

【JavaSE成神之路】数组结构的概念与应用技术

哈喽&#xff0c;我是兔哥呀&#xff0c;今天就让我们继续这个JavaSE成神之路&#xff01; 这一节啊&#xff0c;咱们要学习的内容是数组的概念与应用技术。 乍一听还挺唬人的有没有&#xff0c;数组这个东西呢并不是什么新的知识啦&#xff0c;之前的章节中我们已经学习过数组…

Linux虚拟机安装Hive(mysql安装)

Hive安装第01节 Hive安装部署1. 安装前准备2. 安装MySQL3. Hive安装配置4. metastore服务第02节. Hive客户端的使用1. 客户端介绍2. HiveServer2服务3. Hive CLI的使用4. beeline客户端5. DataGrip可视化客户端第02节 Hive简单使用1. 基本操作2. 查看YARN及HDFS3. 总结第01节 H…