感谢Lo问我为什么看星星大佬(粉丝比我少)的帮助!
推箱子就是主角将箱子通过移动推到指定地点的游戏
今天,我们用C++来还原一下这款游戏
首先我们要定义地图,地图多大都可以
但是最好使用整数类型,这样运行起来容易,但是我为了美观,还是使用了字符类型
char a[11][11]={
"##########",
"## ##",
"## ## N ##",
"# o #",
"# # ### #",
"### #x #",
"##########"
};
注意,因为源代码有错误,需要加上分号,删除最后的逗号,不然无法成立,地图范围不超过10,不能设置10,以防有意外,而且这样不好判断是否走到死角
然后呢我们定义字符变量b用来接收输入的方向
char b;
定义位置为X=3,Y=2,然后定义变量,这两个要倒着来,不然会错误
int x = 3, y = 2;
然后呢打印欢迎语,这里我改进了一下,因为cin和cout的实际速度是比scanf和printf速度慢的(真实),然后窗口要定义名字,这就需要了另一个函数库
#include <windows.h>
这样就可以了,然后怎么更改窗口名字
这很简单
system("title 推箱子小游戏");
最好放在前面,然后打印欢迎语,再等待5秒
可能会有人疑惑,C++怎么等待5秒
这很简单
Sleep(5000);
然后切换界面,清空文字,设置文字颜色为XX色(什么色都可以)
清空文字也简单
system("cls");
设置文字这里要说一下,system函数的性质其实和我们大多数人使用的Windows系统中的命令提示符(Cmd)一模一样
所以我这里要声明一点
COLOR [attr]
attr 指定控制台输出的颜色属性。
颜色属性由两个十六进制数字指定 -- 第一个
对应于背景,第二个对应于前景。每个数字
可以为以下任何值:
0 = 黑色 8 = 灰色
1 = 蓝色 9 = 淡蓝色
2 = 绿色 A = 淡绿色
3 = 浅绿色 B = 淡浅绿色
4 = 红色 C = 淡红色
5 = 紫色 D = 淡紫色
6 = 黄色 E = 淡黄色
7 = 白色 F = 亮白色
然后我们定义颜色
system("color 06");
我这里定义了黄色
然后无限循环
再次清空文字
然后for循环10次,因为地图就这么大,然后用puts打印a列表,这样做是打印地图
其实也可以用printf,但是要麻烦一点
但是说实话puts是不大稳定的
用puts的话需要用到新函数库
#include <conio.h>
#include <cstring>
两个哪一个都行
for(int i = 0; i < 10; i++)
{
puts(a[i]);
}
然后打印提示语
printf("你是‘o’,你要把箱子(‘N’)推到放箱子的地点(‘x’)!");
printf("往上按‘w’,往下按‘s’,往左按‘a’,往右按‘d’,请用英文输入!");
然后开始接收输入的方向(W前,S后,A左,D右)
b = getch();
然后再移动主角前进方向,再判断如果碰到箱子和碰到X和碰到边界的反应
if(b == 'w') {
if(a[x - 1][y] != '#')
{
if(a[x - 1][y] == 'N')
{
if(a[x - 2][y] != '#')
{
a[x - 2][y] = 'N';
a[x][y] = ' ';
x--;
a[x][y] = 'o';
}
}
else
{
a[x][y] = ' ';
x--;
a[x][y] = 'o';
}
}
}
再判断主角后退方向
if(b == 's') {
if(a[x + 1][y] != '#') {
if(a[x + 1][y] == 'N') {
if(a[x + 2][y] != '#') {
a[x + 2][y] = 'N';
a[x][y] = ' ';
x++;
a[x][y] = 'o';
}
}
else {
a[x][y] = ' ';
x++;
a[x][y] = 'o';
}
}
}
再判断主角左走方向
if(b == 'a') {
if(a[x][y - 1] != '#') {
if(a[x][y - 1] == 'N') {
if(a[x][y - 2] != '#') {
a[x][y - 2] = 'N';
a[x][y] = ' ';
y--;
a[x][y] = 'o';
}
}
else {
a[x][y] = ' ';
y--;
a[x][y] = 'o';
}
}
}
再判断主角右走方向
if(b == 'd') {
if(a[x][y + 1] != '#') {
if(a[x][y + 1] == 'N') {
if(a[x][y + 2] != '#') {
a[x][y + 2] = 'N';
a[x][y] = ' ';
y++;
a[x][y] = 'o';
}
}
else {
a[x][y] = ' ';
y++;
a[x][y] = 'o';
}
}
}
判断地点是否存在
if(a[5][6] == ' ')
{
a[5][6]='x';
}
如果箱子推进去则挑战成功
if(a[5][6] == 'N') {
system("cls");
system("color 07");
cout << "恭喜你挑战成功!" << endl;
getch();
return 0;
}
最重要的一点来了,判断箱子是否到达了死角
for(int i = 0; i < 10; i++) {
for(int j = 0; j < 10; j++) {
if(a[i][j] == 'N') {
if(a[i - 1][j] == '#' && a[i][j + 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
if(a[i - 1][j] == '#' && a[i][j - 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
if(a[i + 1][j] == '#' && a[i][j - 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
if(a[i + 1][j] == '#' && a[i][j + 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
}
}
}
如果实在不想要的话,可以判断输入的是否为“q”,然后结束重来
最后结束
总代码
#include <iostream>
#include <cstring>
#include <windows.h>
#include <conio.h>
#include<cstdio>
using namespace std;
char a[11][11]={
"##########",
"## ##",
"## ## N ##",
"# o #",
"# # ### #",
"### #x #",
"##########"
};
int main()
{
system("title 推箱子小游戏");
char b;
int x = 3, y = 2;
cout << "欢迎来到推箱子游戏!(5秒后开始游戏!)" << endl;
Sleep(5000);
system("cls");
system("color 06");
while(true) {
system("cls");
for(int i = 0; i < 10; i++)
{
puts(a[i]);
}
printf("你是‘o’,你要把箱子(‘N’)推到放箱子的地点(‘x’)!");//往上按‘w’,往下按‘s’,往左按‘a’,往右按‘d’,请用英文输入!
printf("往上按‘w’,往下按‘s’,往左按‘a’,往右按‘d’,请用英文输入!");
b = getch();
if(b == 'w') {
if(a[x - 1][y] != '#')
{
if(a[x - 1][y] == 'N')
{
if(a[x - 2][y] != '#')
{
a[x - 2][y] = 'N';
a[x][y] = ' ';
x--;
a[x][y] = 'o';
}
}
else
{
a[x][y] = ' ';
x--;
a[x][y] = 'o';
}
}
}
if(b == 's') {
if(a[x + 1][y] != '#') {
if(a[x + 1][y] == 'N') {
if(a[x + 2][y] != '#') {
a[x + 2][y] = 'N';
a[x][y] = ' ';
x++;
a[x][y] = 'o';
}
}
else {
a[x][y] = ' ';
x++;
a[x][y] = 'o';
}
}
}
if(b == 'a') {
if(a[x][y - 1] != '#') {
if(a[x][y - 1] == 'N') {
if(a[x][y - 2] != '#') {
a[x][y - 2] = 'N';
a[x][y] = ' ';
y--;
a[x][y] = 'o';
}
}
else {
a[x][y] = ' ';
y--;
a[x][y] = 'o';
}
}
}
if(b == 'd') {
if(a[x][y + 1] != '#') {
if(a[x][y + 1] == 'N') {
if(a[x][y + 2] != '#') {
a[x][y + 2] = 'N';
a[x][y] = ' ';
y++;
a[x][y] = 'o';
}
}
else {
a[x][y] = ' ';
y++;
a[x][y] = 'o';
}
}
}
if(a[5][6] == ' ') a[5][6]='x';
if(a[5][6] == 'N') {
system("cls");
system("color 07");
cout << "恭喜你挑战成功!" << endl;
getch();
return 0;
}
for(int i = 0; i < 10; i++) {
for(int j = 0; j < 10; j++) {
if(a[i][j] == 'N') {
if(a[i - 1][j] == '#' && a[i][j + 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
if(a[i - 1][j] == '#' && a[i][j - 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
if(a[i + 1][j] == '#' && a[i][j - 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
if(a[i + 1][j] == '#' && a[i][j + 1] == '#') {
system("cls");
for(int i = 0; i < 10; i++) puts(a[i]);
Sleep(3000);
system("cls");
system("color 07");
cout << "你输了,箱子进入了死角!" << endl;
getch();
return 0;
}
}
}
}
}
return 0;
}