C语言 完整游戏项目推箱子详细代码

 更新时间:2021年11月03日 10:02:10   作者:MAX在码字  
经典的推箱子是一个的古老游戏,目的是在训练你的逻辑思考能力。在一个狭小的仓库中,要求把木箱放到指定的位置,稍不小心就会出现箱子无法移动或者通道被堵住的情况,所以需要巧妙的利用有限的空间和通道,合理安排移动的次序和位置,才能顺利的完成任务

话不多说

我们今天就来创造出属于我们自己的《推箱子》,GOGOGO!!!

直接开始吧

首先是我们用二维数组特定的数字描绘出这个地图

int cas = 0;
int map[3][8][8] =
{
	1,1,1,1,1,1,1,1,
	1,3,4,0,0,4,3,1,
	1,0,1,3,0,1,0,1,
	1,0,1,4,0,1,0,1,
	1,0,0,5,0,0,0,1,
	1,0,1,0,0,1,0,1,
	1,3,4,0,0,4,3,1,
	1,1,1,1,1,1,1,1,
 
	1,1,1,1,1,1,1,1,
	1,3,4,0,0,4,3,1,
	1,0,1,3,0,1,0,1,
	1,0,1,4,0,1,0,1,
	1,3,4,5,0,0,0,1,
	1,0,1,0,0,1,0,1,
	1,3,4,0,0,4,3,1,
	1,1,1,1,1,1,1,1,
 
	1,1,1,1,1,1,1,1,
	1,3,4,0,0,4,3,1,
	1,0,1,3,0,1,0,1,
	1,0,1,4,0,1,0,1,
	1,3,4,5,0,4,3,1,
	1,0,1,0,0,1,0,1,
	1,3,4,0,0,4,3,1,
	1,1,1,1,1,1,1,1
};

然后来绘制我们的推箱子地图

void  drawGraph() 
{
	for (int i = 0; i < 8; i++) 
	{
		for (int j = 0; j < 8; j++) 
		{
			//算贴图的坐标
			int x = 50 * j;
			int y = 50 * i;
			switch (map[cas][i][j]) 
			{
			case 0:
				//一个汉字符号占用两个位置
				//printf("  ");
				putimage(x, y, img + 0);
				break;
			case 1:
				putimage(x, y, img + 1);
				//printf("■");
				break;
			case 3:
				putimage(x, y, img + 2);
				//printf("☆");
				break;
			case 4:
				putimage(x, y, img + 3);
				//printf("★");
				break;
			case 5:
			case 8:
				putimage(x, y, img + 4);
				//printf("人");
				break;
			case 7:
				putimage(x, y, img + 5);
				//printf("●");
				break;
			}
		}
		//printf("\n");
	}
}

之后就是我们的游戏函数,怎样去用什么按键去控制我们的角色

void keyDown() 
{
	int userKey = _getch();	//不可见输入
	//定位:找到人的位置
	int i = 0;
	int j = 0;
	for (i = 1; i < 8; i++) 
	{
		for (j = 1; j < 8; j++) 
		{
			if (map[cas][i][j] == 5 || map[cas][i][j] == 8) 
			{
				goto NEXT;
			}
		}
	}
	NEXT:
 
	//我们这个游戏用什么按键去玩
	switch (userKey) 
	{
	case 'W':
	case 'w':
	case 72:
		if (map[cas][i - 1][j] == 0 || map[cas][i - 1][j] == 3) 
		{
			map[cas][i][j] -= 5;
			map[cas][i - 1][j] += 5;
		}
		if (map[cas][i - 1][j] == 4 || map[cas][i - 1][j] == 7) 
		{
			if (map[cas][i - 2][j] == 0 || map[cas][i - 2][j] == 3) 
			{
				map[cas][i][j] -= 5;
				map[cas][i - 1][j] += 1;
				map[cas][i - 2][j] += 4;
			}
		}
		break;
	case 's':
	case 'S':
	case 80:
		if (map[cas][i + 1][j] == 0 || map[cas][i + 1][j] == 3)
		{
			map[cas][i][j] -= 5;
			map[cas][i + 1][j] += 5;
		}
		if (map[cas][i + 1][j] == 4 || map[cas][i + 1][j] == 7)
		{
			if (map[cas][i + 2][j] == 0 || map[cas][i +2][j] == 3)
			{
				map[cas][i][j] -= 5;
				map[cas][i + 1][j] += 1;
				map[cas][i + 2][j] += 4;
			}
		}
		break;
	case 'a':
	case 'A':
	case 75:
		if (map[cas][i][j - 1] == 0 || map[cas][i][j - 1] == 3)
		{
			//a+=1  a=a+1 复合赋值运算符
			map[cas][i][j] -= 5;
			map[cas][i][j - 1] += 5;
		}
		if (map[cas][i][j - 1] == 4 || map[cas][i][j - 1] == 7)
		{
			if (map[cas][i][j - 2] == 0 || map[cas][i][j - 2] == 3)
			{
				map[cas][i][j] -= 5;
				map[cas][i][j - 1] += 1;
				map[cas][i][j - 2] += 4;
			}
		}
		break;
	case 'd':
	case 'D':
	case 77:
		if (map[cas][i][j + 1] == 0 || map[cas][i][j + 1] == 3)
		{
			map[cas][i][j] -= 5;
			map[cas][i][j + 1] += 5;
		}
		if (map[cas][i][j + 1] == 4 || map[cas][i][j + 1] == 7)
		{
			if (map[cas][i][j + 2] == 0 || map[cas][i][j + 2] == 3)
			{
				map[cas][i][j] -= 5;
				map[cas][i][j + 1] += 1;
				map[cas][i][j + 2] += 4;
			}
		}
		break;
	}
}

再然后就是我们如何去判断游戏的结果

//胜负的判断:
int gameOver() 
{
	//地图上没有箱子就可以结束
	for (int i = 0; i < 8; i++) 
	{
		for (int j = 0; j < 8; j++) 
		{
			if (map[cas][i][j] == 4) 
			{
				return 0;
			}
		}
	}
	return 1;
}

最后运行我们的主函数就行啦

int main() 
{
	loadResource();
	mciSendString("open 1.mp3", 0, 0, 0);
	mciSendString("play 1.mp3 repeat", 0, 0, 0);
	initgraph(50 * 8, 50 * 8);
	while (1) 
	{
		drawGraph();
		if (gameOver())
		{
			cas++;			//变换关卡
			if(cas==3)
				break;
		}
		keyDown();
		//system("cls");
	}
	closegraph();
	//printf("GameOver!\n");
	return 0;
}

其实代码并不是很多,当然啦,如果同学们想更加完善,可以增加关卡设定,再优化一下我们的开始界面以及游戏界面也是可以的,大家快去尝试吧!!! 希望看完了的同学可以获得自己想要的知识,也感谢大家的耐心观看,在这里想得到大家一波关注,后续UP主还会发布更多的项目源码以及学习资料,有什么问题可以回帖留言,我尽量回答。希望和大家一起学习进步!!!

到此这篇关于C语言 完整游戏项目推箱子详细代码的文章就介绍到这了,更多相关C语言 推箱子内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 举例讲解C语言链接器的符号解析机制

    举例讲解C语言链接器的符号解析机制

    链接器的工作主要分为两个阶段:符号解析和重定位,符号解析的功能是将每个模块符号引用绑定到一个确切的符号定义,这里我们就来举例讲解C语言链接器的符号解析机制
    2016-05-05
  • C++17之std::visit的具体使用

    C++17之std::visit的具体使用

    本文主要介绍了C++17之std::visit的具体使用,文中通过示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2022-02-02
  • C++保存txt文件实现方法代码实例

    C++保存txt文件实现方法代码实例

    这篇文章主要介绍了C++保存txt文件实现方法代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-11-11
  • 使用C++中的ADO对SQLite进行增删改查

    使用C++中的ADO对SQLite进行增删改查

    本文将介绍如何使用C++的ADO (ActiveX Data Objects)对SQLite数据库进行增删改查操作,文中有详细的代码示例,需要的朋友可以参考下
    2023-06-06
  • C++基于对话框的程序的框架实例

    C++基于对话框的程序的框架实例

    这篇文章主要介绍了C++基于对话框的程序的框架,以实例形式讲述了C++对话框程序框架,有助于深入理解基于C++的Windows程序设计,需要的朋友可以参考下
    2014-10-10
  • OpenCV实现抠图工具

    OpenCV实现抠图工具

    这篇文章主要为大家详细介绍了OpenCV实现抠图工具,文中示例代码介绍的非常详细,具有一定为大家详细的参考价值,感兴趣的小伙伴们可以参考一下
    2022-01-01
  • C++ 多重继承和虚拟继承对象模型、效率分析

    C++ 多重继承和虚拟继承对象模型、效率分析

    本文简单介绍多态和多重继承、虚拟继承的基本概念。随后重点分析了C++中对象模型之间的差异和运行效率
    2014-08-08
  • 基于linux下获取时间函数的详解

    基于linux下获取时间函数的详解

    本篇文章是对linux下获取时间的函数进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • opengl绘制五星红旗

    opengl绘制五星红旗

    这篇文章主要为大家详细介绍了opengl绘制五星红旗的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2019-09-09
  • C++实现LeetCode(111.二叉树的最小深度)

    C++实现LeetCode(111.二叉树的最小深度)

    这篇文章主要介绍了C++实现LeetCode(111.二叉树的最小深度),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07

最新评论