C/C++实现推箱子小游戏

 更新时间:2021年06月01日 14:31:05   作者:两片空白  
这篇文章主要为大家详细介绍了C/C++实现推箱子小游戏,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C/C++实现推箱子小游戏的具体代码,供大家参考,具体内容如下

效果演示

实现功能

如上图所示。按键控制小猪的运动,推箱子到达目的地。

如何实现

1.首先思考要保存箱子,小猪等信息,添加多个map可以用到三维数组。
2.定义小猪,箱子,墙,空地等信息在三维数组里的数值。

 空地             0     
 墙               1
 目的地           2   
 箱子             3
 猪               4  2+4=6 猪到达目的地也显示猪
 箱子到达目的地   2+3=5

3.按键实现推箱子运动。

考虑多种情况:

①.小猪的运动(空地,目的在)
②.小猪推箱子运动(空地,目的地)

用三维数组保存map信息:这里我只做了两种图,可自行添加

int backgrand[MAP][ROW][COL] =//map图
{
 {
  1, 1, 1, 1, 1, 1, 1, 1,
  1, 0, 0, 0, 2, 0, 0, 1,
  1, 1, 0, 0, 3, 1, 1, 1,
  1, 2, 3, 0, 4, 0, 0, 1,
  1, 0, 1, 0, 3, 3, 2, 1,
  1, 1, 0, 3, 2, 0, 0, 1,
  1, 0, 0, 2, 0, 0, 1, 1,
  1, 1, 1, 1, 1, 1, 1, 1
 },
 {
  0, 1, 1, 1, 1, 1, 1, 1,
  1, 1, 0, 2, 0, 0, 0, 1,
  1, 1, 0, 0, 3, 0, 1, 1,
  1, 2, 3, 0, 4, 0, 0, 1,
  1, 0, 1, 0, 0, 0, 1, 1,
  1, 1, 0, 3, 2, 3, 0, 1,
  1, 0, 0, 0, 0, 2, 0, 1,
  1, 1, 1, 1, 1, 1, 1, 1
 },
};

绘图用到了easyx库,加载图片和绘制窗口只用到了三条语句:很简单

initgraph();//绘制窗口大小
loadimage();//加载图片
putinmage();//放出图片

具体可看代码!

代码块

#include<stdio.h>
#include<Windows.h>
#include<stdlib.h>
#include<time.h>
#include<conio.h>
#include<graphics.h>
#define ROW 8
#define COL 8
#define MAP 2//map个可以自己添加数


int count = 0;//哪个map图
/*
空地             0
墙               1
目的地           2
箱子             3
猪               4  2+4=6 猪到达目的地也显示猪
箱子到达目的地   2+3=5


*/


IMAGE image1, image2, image3, image4, image5, image6;

int backgrand[MAP][ROW][COL] =//map图
{
 {
  1, 1, 1, 1, 1, 1, 1, 1,
  1, 0, 0, 0, 2, 0, 0, 1,
  1, 1, 0, 0, 3, 1, 1, 1,
  1, 2, 3, 0, 4, 0, 0, 1,
  1, 0, 1, 0, 3, 3, 2, 1,
  1, 1, 0, 3, 2, 0, 0, 1,
  1, 0, 0, 2, 0, 0, 1, 1,
  1, 1, 1, 1, 1, 1, 1, 1
 },
 {
  0, 1, 1, 1, 1, 1, 1, 1,
  1, 1, 0, 2, 0, 0, 0, 1,
  1, 1, 0, 0, 3, 0, 1, 1,
  1, 2, 3, 0, 4, 0, 0, 1,
  1, 0, 1, 0, 0, 0, 1, 1,
  1, 1, 0, 3, 2, 3, 0, 1,
  1, 0, 0, 0, 0, 2, 0, 1,
  1, 1, 1, 1, 1, 1, 1, 1
 },
};
int Judge(){//p判断是否结束一局
 int i = 0;
 for (i = 0; i < ROW; i++){
  int j = 0;
  for (j = 0; j < COL; j++){
   if (backgrand[count][i][j] == 3 || backgrand[count][i][j] == 2){//判断是否还有箱子或者目的地
    return 0;
   }
  }
 }
 return 1;
}

void Backgrand(){//绘制地图
 int i = 0;
 for (; i < ROW; i++){
  int j = 0;
  for (; j < COL; j++){
   int x = 80 * j;//横轴是y(列),数轴是x(行)。
   int y = 80 * i;
   switch (backgrand[count][i][j]){
   case 0:
    putimage(x, y, &image3);
    break;
   case 1:
    putimage(x, y, &image1);
    break;
   case 2:
    putimage(x, y, &image6);
    break;
   case 3:
    putimage(x, y, &image4);
    break;
   case 4:
   case 6:
    putimage(x, y, &image2);
    break;
   case 5:
    putimage(x, y, &image5);
    break;
   default:
    break;
   }
  }
 }
}

void Keymove(){//按键控制猪的运动
 int i = 0;
 int j = 0;//j定义出来了,里面for循环要初始化
 for (i = 0; i < ROW; i++){ //找到猪的坐标
  for (j = 0; j < COL; j++){
   if (backgrand[count][i][j] == 4 || backgrand[count][i][j] == 6){
    break;
   }
  }
  if (backgrand[count][i][j] == 4 || backgrand[count][i][j] == 6){
   break;
  }
 }
 char key = _getch();//获得按键
 switch (key){
 case 'w':
 case 'W':
 case 72:
  if (backgrand[count][i - 1][j] == 0 ||\
   backgrand[count][i - 1][j] == 2)
  {  
   backgrand[count][i][j] = backgrand[count][i][j] - 4;//猪运动,猪旁边是空地或者是目的地
   backgrand[count][i - 1][j] = backgrand[count][i - 1][j] + 4;
  }
  if (backgrand[count][i - 1][j] == 3 && (backgrand[count][i - 2][j] == 0 || \
   backgrand[count][i - 2][j] == 2))   //猪推箱子运动条件,猪旁边是箱子与上箱子旁边是空地。
  {                                       //后面或的条件要括号括起来
   backgrand[count][i][j] = backgrand[count][i][j] - 4;                                      
   backgrand[count][i - 1][j] = backgrand[count][i - 1][j] + 4;
   backgrand[count][i - 1][j] -= 3;
   backgrand[count][i - 2][j] += 3;
  }
  if (backgrand[count][i - 1][j] == 5 &&\
   backgrand[count][i - 2][j] == 0)  //箱子到达目的地,后面还有空的情况
  {
   backgrand[count][i][j] -= 4;
   backgrand[count][i - 1][j] += 4;
   backgrand[count][i - 1][j] -= 3;
   backgrand[count][i - 2][j] += 3;
  }
  break;
 case 's':
 case 'S':
 case 80:
  if (backgrand[count][i + 1][j] == 0 || \
   backgrand[count][i + 1][j] == 2)
  {  //猪运动
   backgrand[count][i][j] = backgrand[count][i][j] - 4;
   backgrand[count][i + 1][j] = backgrand[count][i + 1][j] + 4;
  }
  if (backgrand[count][i + 1][j] == 3 && (backgrand[count][i + 2][j] == 0 ||\
   backgrand[count][i + 2][j] == 2))
  {
   backgrand[count][i][j] = backgrand[count][i][j] - 4;
   backgrand[count][i + 1][j] = backgrand[count][i + 1][j] + 4;
   backgrand[count][i + 1][j] -= 3;
   backgrand[count][i + 2][j] += 3;
  }
  if (backgrand[count][i + 1][j] == 5 && \
   backgrand[count][i + 2][j] == 0)
  {
   backgrand[count][i][j] -= 4;
   backgrand[count][i + 1][j] += 4;
   backgrand[count][i + 1][j] -= 3;
   backgrand[count][i + 2][j] += 3;
  }
  break;
 case 'a':
 case 'A':
 case 75:
  if (backgrand[count][i][j - 1] == 0 || \
   backgrand[count][i][j - 1] == 2)
  {  //猪运动
   backgrand[count][i][j] = backgrand[count][i][j] - 4;
   backgrand[count][i][j - 1] = backgrand[count][i][j - 1] + 4;
  }
  if (backgrand[count][i][j - 1] == 3 &&\
   (backgrand[count][i][j - 2] == 0 ||\
   backgrand[count][i][j - 2] == 2))
  {
   backgrand[count][i][j] = backgrand[count][i][j] - 4;
   backgrand[count][i][j - 1] = backgrand[count][i][j - 1] + 4;
   backgrand[count][i][j - 1] -= 3;
   backgrand[count][i][j - 2] += 3;
  }
  if (backgrand[count][i][j - 1] == 5 && \
   backgrand[count][i][j - 2] == 0)
  {
   backgrand[count][i][j] -= 4;
   backgrand[count][i][j - 1] += 4;
   backgrand[count][i][j - 1] -= 3;
   backgrand[count][i][j - 2] += 3;
  }
  break;
 case 'd':
 case 'D':
 case 77:
  if (backgrand[count][i][j + 1] == 0 || \
   backgrand[count][i][j + 1] == 2)
  {  //猪运动
   backgrand[count][i][j] = backgrand[count][i][j] - 4;
   backgrand[count][i][j + 1] = backgrand[count][i][j + 1] + 4;
  }
  if (backgrand[count][i][j + 1] == 3 && (backgrand[count][i][j + 2] == 0 ||\
   backgrand[count][i][j + 2] == 2))
  {
   backgrand[count][i][j] -= 4;
   backgrand[count][i][j + 1] += 4;
   backgrand[count][i][j + 1] -= 3;
   backgrand[count][i][j + 2] += 3;
  }
  if (backgrand[count][i][j + 1] == 5 && backgrand[count][i][j + 2] == 0){
   backgrand[count][i][j] -= 4;
   backgrand[count][i][j + 1] += 4;
   backgrand[count][i][j + 1] -= 3;
   backgrand[count][i][j + 2] += 3;
  }
  break;
 default:
  break;
 }


}


void Initgraph(){
 initgraph(80 * ROW, 80 * COL);
 loadimage(&image1, "1.jpg");//墙
 loadimage(&image2, "2.jpg");//猪
 loadimage(&image3, "3.jpg");//空地
 loadimage(&image4, "4.jpg");//箱子
 loadimage(&image6, "6.jpg");//目的地
 loadimage(&image5, "5.jpg");//箱子到目的地
}



int main(){
 Initgraph();
 while (1){
  Backgrand();
  Keymove();
  if (Judge()){
   Backgrand();
   Sleep(500);
   count++;
  }
  if (count == MAP){
   break;
  }
 }


 getchar();
 closegraph();
 system("pause");
 return 0;
}

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。

相关文章

  • C语言采用文本方式和二进制方式打开文件的区别分析

    C语言采用文本方式和二进制方式打开文件的区别分析

    这篇文章主要介绍了C语言采用文本方式和二进制方式打开文件的区别分析,有助于读者更好的理解文本文件与二进制文件的原理,需要的朋友可以参考下
    2014-07-07
  • 利用C++实现简易的.ini配置文件解析器

    利用C++实现简易的.ini配置文件解析器

    这篇文章主要为大家详细介绍了如何基于C++编写一个简易的.ini配置文件解析器,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以了解一下
    2023-03-03
  • C语言 小游戏打砖块实现流程详解

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

    打砖块游戏是一种动作电子游戏的名称。玩家操作一根萤幕上水平的“棒子”,让一颗不断弹来弹去的“球”在撞击作为过关目标消去的“砖块”的途中不会落到萤幕底下。球碰到砖块、棒子与底下以外的三边会反弹,落到底下会失去一颗球,把砖块全部消去就可以破关
    2021-11-11
  • C语言指针基础详解

    C语言指针基础详解

    这篇文章主要介绍了C语言指针的基础,主要对C语言中指针的本质及常见用法做了较为通俗易懂的分析,是后续深入学习C语言的基础,需要的朋友可以参考下
    2021-10-10
  • C++控制台用定时器实例代码

    C++控制台用定时器实例代码

    这篇文章主要介绍了C++控制台用定时器实例代码,分享了相关代码示例,小编觉得还是挺不错的,具有一定借鉴价值,需要的朋友可以参考下
    2018-02-02
  • C语言近万字为你讲透树与二叉树

    C语言近万字为你讲透树与二叉树

    树是计算机算法最重要的非线性结构。因为树能很好地描述结构的分支关系和层次特性,所以在计算机科学和计算机应用领域有着广泛的应用。这篇文章我就带大家一起了解一下树、二叉树这种结构,下篇文章会重点向大家介绍二叉树的遍历算法
    2022-05-05
  • 自己简单封装的一个CDialog类实例

    自己简单封装的一个CDialog类实例

    这篇文章主要介绍了自己简单封装的一个CDialog类,实例分析了自定义封装CDialog类的相关技巧,比较简单易懂,需要的朋友可以参考下
    2015-04-04
  • 解析一个有关sizeof用法的题目--sizeof(i++)

    解析一个有关sizeof用法的题目--sizeof(i++)

    本篇文章是对一个关于sizeof用法的题目进行了详细的分析介绍,需要的朋友参考下
    2013-06-06
  • 详解C++编程中的主表达式与后缀表达式编写基础

    详解C++编程中的主表达式与后缀表达式编写基础

    这篇文章主要介绍了C++编程中的主表达式与后缀表达式编写基础,是C++入门学习中的基础知识,需要的朋友可以参考下
    2016-01-01
  • C++超详细讲解操作符的重载

    C++超详细讲解操作符的重载

    C++预定义中的运算符的操作对象只局限于基本的内置数据类型,但是对于我们自定义的类型(类)是没有办法操作的。但是大多时候我们需要对我们定义的类型进行类似的运算,这个时候就需要我们对这么运算符进行重新定义,赋予其新的功能,以满足自身的需求
    2022-06-06

最新评论