经典C语言/C++项目,雷霆战机

简介: 经典C语言/C++项目,雷霆战机
#include <stdio.h>
#include <easyx.h>
#include <time.h>
#include <Mmsystem.h>
#pragma comment(lib,"winmm.lib")
#define WIDTH   600
#define HEIGHT  850
#define bullet_max  5000      //我方飞机子弹最大量
#define enemy_bul_max 150  //敌方飞机子弹最大量
#define enemy1_hp 30          //敌方飞机生命值
#define enemy2_hp 50
#define enemy3_hp 30
#define enemy4_hp 10000
#define enemy5_hp 12000
IMAGE bgimg;                                //主界面图片
IMAGE bkimg0;                               
IMAGE bkimg1;
IMAGE bkimg2;
IMAGE bkimg3;
IMAGE Myplane[2];                           //飞机图片个数
IMAGE Enemy1[2];                            //小飞机
IMAGE Enemy2[2];                            //中飞机
IMAGE Enemy2Bullet[2];                      //中飞机子弹
IMAGE Enemy3[2];                            //横行飞机
IMAGE Enemy3Bullet[2];                      //横行飞机子弹
IMAGE Enemy4[2];                            //第二关boss
IMAGE Enemy4Bullet[2];                      //第二关boss子弹
IMAGE Enemy5[2];                            //第三关boss
IMAGE Enemy5Bullet[2];                      //第三关boss子弹
//加载图片
void loadimg();
//初始化游戏
void initGame();
//加载主界面
void DrawInterface();
//绘制游戏
void DrawGame();
//更新背景
void UpdateBack();
//更新飞机
void UpdatePlane();
//绘制子弹
void DrawBullet();
//子弹移动
void MoveBullet();
//关卡转换
void level_change();
//失败界面
void FailMenu();
//结束界面
void EndMenu();
//进入每一关的初始分数
void Judge();
//敌机移动机制
void EnemyMove();
//判定子弹碰撞敌机
void Bulletcrush();
//创建敌机
void EnemyCreat_L1();
void EnemyCreat_L2();
void EnemyCreat_L3();
//敌机产生子弹
void Enemy_Bullet_Creat();
//敌机子弹移动
void Enemy_Bullet_Move();
//敌机子弹打击
void Enemy_Bullet_Crush();
//碰撞敌机
void EnemyCrush();
//定义我方飞机类
struct Myplane
{
  int   x;
  int   y;
  int   hp;
  int   width = 95;
  int   height = 90;
  bool  isExit;                            //是否存在
}myplane[1]; 
IMAGE Bullet[2];                             //子弹图片个数
//定义我方飞机子弹类
struct Bullet
{
  int   x1;
  int   y1;
  int   x2;
  int   y2;
  bool  isExit;                             //是否存在
} bullet[bullet_max];                         //子弹个数
//定义敌方飞机类
struct Enemyplane
{
  double   x;
  double   y;
  int   hp;
  int   width;
  int   height;
  bool  isExit;
}enemy1[10], enemy2[5], enemy3[5], enemy4[1], enemy5[1];
//定义敌方飞机子弹类
struct Enemybullet
{
  int   x;
  int   y;
  int   hp;
  int   atk;                                //用于后面判断打击
  int   width;
  int   height;
  bool  isExit;
} enemy2_bullet[enemy_bul_max], enemy3_bullet[enemy_bul_max], enemy4_bullet[enemy_bul_max], enemy5_bullet[enemy_bul_max];
int   bky0, bky1,bk1y0,bk1y1,bk2y0,bk2y1;
int score = 0;                                //5000通过第一关,8000分第二关boss出现,12000分进入第三关
int enemy2_direct0 = 1;
int enemy2_direct1 = 1;
int enemy2_direct2 = 1;
int enemy3_direct0 = 1;
int enemy3_direct1 = 1;
int enemy3_direct2 = 1;
int enemy4_direct0 = 1;
int enemy5_direct0 = 1;
int level_change_count = 1;
int main();
int level()
{
  if (score > 5000 && score < 12000)
  {
    return 2;//第二关
  }
  else if (score < 5000)
  {
    return 1;//返回第一关
  }
  else if (score > 12000)
  {
    return 3;//第三关
  }
  if (score > 17000)
  {
    return 4;//结束界面
  }
}
void loadimg()
{
  //主界面图片
  loadimage(&bgimg, L"bg.jpg");
  //关卡背景图片
  if (level() == 1)
  {
    loadimage(&bkimg0, L"bk.jpg");
  }
  else if (level() == 2)
  {
    loadimage(&bkimg1, L"bk1.jpg");
  }
  else {
    loadimage(&bkimg2, L"bk2.jpg");
  }
  //我方飞机图片
  loadimage(&Myplane[0], L"uiPlane0.jpg");
  loadimage(&Myplane[1], L"uiPlane1.jpg");
  //加载子弹
  loadimage(&Bullet[0], L"bullet0.jpg");
  loadimage(&Bullet[1], L"bullet1.jpg");
  //敌机1
  loadimage(&Enemy1[0], L"enemy10.jpg");
  loadimage(&Enemy1[1], L"enemy11.jpg");
  //敌机2
  loadimage(&Enemy2[0], L"enemy20.jpg");
  loadimage(&Enemy2[1], L"enemy21.jpg");
  loadimage(&Enemy2Bullet[0], L"bullet0 - 副本.jpg");
  loadimage(&Enemy2Bullet[1], L"bullet1 - 副本.jpg");
  //敌机3
  loadimage(&Enemy3[0], L"enemy10.jpg");
  loadimage(&Enemy3[1], L"enemy11.jpg");
  loadimage(&Enemy3Bullet[0], L"bullet0 - 副本.jpg");
  loadimage(&Enemy3Bullet[1], L"bullet1 - 副本.jpg");
  //敌机4
  loadimage(&Enemy4[0], L"enemy30.jpg");
  loadimage(&Enemy4[1], L"enemy31.jpg");
  loadimage(&Enemy4Bullet[0], L"bullet0 - 副本.jpg");
  loadimage(&Enemy4Bullet[1], L"bullet1 - 副本.jpg");
  //敌机5
  loadimage(&Enemy5[0], L"enemy50.jpg");
  loadimage(&Enemy5[1], L"enemy51.jpg");
  loadimage(&Enemy5Bullet[0], L"bullet0 - 副本.jpg");
  loadimage(&Enemy5Bullet[1], L"bullet1 - 副本.jpg");
}
bool Timer(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
void DrawGame()
{
  //双缓冲绘图,防止闪屏
  BeginBatchDraw();
  loadimg();
  //绘制关卡背景
  if (level() == 1)
  {
    putimage(0, bky0, &bkimg0);
    putimage(0, bky1, &bkimg0);
  }
  else if (level() == 2)
  {
    putimage(0, bk1y0, &bkimg1);
    putimage(0, bk1y1, &bkimg1);
  }
  else
  {
    putimage(0, bk2y0, &bkimg2);
    putimage(0, bk2y1, &bkimg2);
  }
  //绘制我方飞机子弹(透明贴图)
  int i;
  for (i = 0; i < 1; i++)
  {
    if (myplane[i].isExit)                       //如果飞机存在,则绘制飞机
    {
      putimage(myplane[i].x, myplane[i].y, &Myplane[0], SRCPAINT);
      putimage(myplane[i].x, myplane[i].y, &Myplane[1], SRCAND);
    }
  }
  for (int i = 0; i < bullet_max; i++)
  {                                           //遍历所有子弹,若存在则贴图
    if (bullet[i].isExit)
    {                                       //SRCPAINT三元光栅操作码(用于实现透明贴图)
      putimage(bullet[i].x1, bullet[i].y1, &Bullet[0], SRCPAINT);
      putimage(bullet[i].x1, bullet[i].y1, &Bullet[1], SRCAND);
      putimage(bullet[i].x2, bullet[i].y2, &Bullet[0], SRCPAINT);
      putimage(bullet[i].x2, bullet[i].y2, &Bullet[1], SRCAND);
    }
  }
  for (i = 0; i < 10; i++)//敌机1
  {
    if (enemy1[i].isExit)
    {
      putimage(enemy1[i].x, enemy1[i].y, &Enemy1[0], SRCPAINT);
      putimage(enemy1[i].x, enemy1[i].y, &Enemy1[1], SRCAND);
    }
  }
  for (i = 0; i < 5; i++)//敌机2
  {
    if (enemy2[i].isExit)
    {
      putimage(enemy2[i].x, enemy2[i].y, &Enemy2[0], SRCPAINT);
      putimage(enemy2[i].x, enemy2[i].y, &Enemy2[1], SRCAND);
    }
  }
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy2_bullet[i].isExit)
    {
      putimage(enemy2_bullet[i].x, enemy2_bullet[i].y, &Enemy2Bullet[0], SRCPAINT);
      putimage(enemy2_bullet[i].x, enemy2_bullet[i].y, &Enemy2Bullet[1], SRCAND);
    }
  }
  for (i = 0; i < 5; i++)//敌机3
  {
    if (enemy3[i].isExit)
    {
      putimage(enemy3[i].x, enemy3[i].y, &Enemy3[0], SRCPAINT);
      putimage(enemy3[i].x, enemy3[i].y, &Enemy3[1], SRCAND);
    }
  }
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy3_bullet[i].isExit)
    {
      putimage(enemy3_bullet[i].x, enemy3_bullet[i].y, &Enemy3Bullet[0], SRCPAINT);
      putimage(enemy3_bullet[i].x, enemy3_bullet[i].y, &Enemy3Bullet[1], SRCAND);
    }
  }
  for (i = 0; i < 1; i++)
  {
    if (enemy4[i].isExit)
    {
      putimage(enemy4[i].x, enemy4[i].y, &Enemy4[0], SRCPAINT);
      putimage(enemy4[i].x, enemy4[i].y, &Enemy4[1], SRCAND);
    }
  }
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy4_bullet[i].isExit)
    {
      putimage(enemy4_bullet[i].x, enemy4_bullet[i].y, &Enemy4Bullet[0], SRCPAINT);
      putimage(enemy4_bullet[i].x, enemy4_bullet[i].y, &Enemy4Bullet[1], SRCAND);
    }
  }
  for (i = 0; i < 1; i++)
  {
    if (enemy5[i].isExit)
    {
      putimage(enemy5[i].x, enemy5[i].y, &Enemy5[0], SRCPAINT);
      putimage(enemy5[i].x, enemy5[i].y, &Enemy5[1], SRCAND);
    }
  }
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy5_bullet[i].isExit)
    {
      putimage(enemy5_bullet[i].x, enemy5_bullet[i].y, &Enemy5Bullet[0], SRCPAINT);
      putimage(enemy5_bullet[i].x, enemy5_bullet[i].y, &Enemy5Bullet[1], SRCAND);
    }
  }
  EndBatchDraw();
}
bool Timer_enemycreat(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
bool Timer2(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
bool Timer_enemy2_bullet_creat(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
bool Timer_enemy3_bullet_creat(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
bool Timer_enemy4_bullet_creat(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
bool Timer_enemy5_bullet_creat(int ms)//定时器
{
  static DWORD t1 = 0, t2 = 0;
  if (t2 - t1 > ms)
  {
    t1 = t2;
    return true;
  }
  t2 = clock();
  return false;
}
void EnemyMove()
{
  int i;
  for (i = 0; i < 10; i++)//最小敌机前进,不发射子弹
  {
    if (enemy1[i].isExit == true)
    {
      enemy1[i].y += 0.5;
      if (enemy1[i].y > HEIGHT)
      {
        enemy1[i].isExit = false;
      }
    }
  }
  for (i = 0; i < 5; i++)//中飞机,缓慢前进,并发射子弹
  {
    if (enemy2[i].isExit == true)
    {
      enemy2[i].y += 0.7;
      if (enemy2[i].y > HEIGHT)
      {
        enemy2[i].isExit = false;
      }
    }
  }
  for (i = 0; i < 5; i++)//横行飞机,左右移动,偶尔前进,并发射子弹
  {
    if (enemy3[i].isExit == true)
    {
      if (i == 0)//型号为0的飞机,奇数向左,偶数向右,且先向左
      {
        if (enemy3[i].y < HEIGHT / 2)
        {
          enemy3[i].y += 10;
        }
        else
        {
          if (enemy3_direct0 % 2 == 1)
          {
            enemy3[i].x -= 2;
            if (enemy3[i].x < 0)
            {
              enemy3_direct0++;
            }
          }
          if (enemy3_direct0 % 2 == 0)
          {
            enemy3[i].x += 2;
            if (enemy3[i].x + enemy3[i].width > WIDTH)
            {
              enemy3_direct0++;
            }
          }
        }
      }
      if (i == 1)//型号为1的飞机,奇数向右,偶数向左,且先向右边
      {
        if (enemy3[i].y < HEIGHT / 2)//先移动到画面中
        {
          enemy3[i].y += 10;
        }
        else
        {
          if (enemy3_direct1 % 2 == 0)
          {
            enemy3[i].x -= 2;
            if (enemy3[i].x < 0)
            {
              enemy3_direct1++;
            }
          }
          if (enemy3_direct1 % 2 == 1)
          {
            enemy3[i].x += 2;
            if (enemy3[i].x + enemy3[i].width > WIDTH)
            {
              enemy3_direct1++;
            }
          }
        }
      }
      if (i == 2)//型号为2的飞机,奇数向左,偶数向右,且先向左
      {
        if (enemy3[i].y < HEIGHT / 2)//先移动到画面中
        {
          enemy3[i].y += 10;
        }
        else
        {
          if (enemy3_direct2 % 2 == 1)
          {
            enemy3[i].x -= 2;
            if (enemy3[i].x < 0)
            {
              enemy3_direct2++;
            }
          }
          if (enemy3_direct2 % 2 == 0)
          {
            enemy3[i].x += 2;
            if (enemy3[i].x + enemy3[i].width > WIDTH)
            {
              enemy3_direct2++;
            }
          }
        }
      }
      if (enemy3[i].y < -3)
      {
        enemy3[i].isExit = false;
      }
    }
  }
  for (i = 0; i < 1; i++)
  {
    if (enemy4[i].isExit)
    {
      if (enemy4_direct0 % 2 == 1)
      {
        enemy4[i].x -= 1;
        if (enemy4[i].x < 0)
        {
          enemy4_direct0++;
        }
      }
      if (enemy4_direct0 % 2 == 0)
      {
        enemy4[i].x += 1;
        if (enemy4[i].x + enemy4[i].width > WIDTH)
        {
          enemy4_direct0++;
        }
      }
    }
  }
}
void EnemyClean()
{
  int i, j;
  for (i = 0; i < 10; i++)//敌机1,遍历所有敌机位,找到一个空位产生敌机
  {
    if (enemy1[i].isExit == true)
    {
      enemy1[i].isExit = false;
    }
  }
  for (j = 0; j < 5; j++)//敌机2
  {
    if (enemy2[j].isExit == true)
    {
      enemy2[j].isExit = false;
    }
  }
  for (j = 0; j < 10; j++)//敌机3
  {
    if (enemy3[j].isExit == true)
    {
      enemy3[j].isExit = false;
    }
  }
  for (i = 0; i < enemy_bul_max; i++)//遍历所有子弹位,找到一个空位存放子弹
  {
    if (enemy2_bullet[i].isExit == true)
    {
      enemy2_bullet[i].isExit = false;
    }
    if (enemy3_bullet[i].isExit == true)
    {
      enemy3_bullet[i].isExit = false;
    }
    if (enemy4_bullet[i].isExit == true)
    {
      enemy4_bullet[i].isExit = false;
    }
  }
}
void EnemyCreat_L1()
{
  int i, j;
  int count1 = 0, count2 = 0;
  if (Timer_enemycreat(3000))
  {
    for (i = 0; i < 10; i++)//敌机1
    {
      if (enemy1[i].isExit == false)
      {
        enemy1[i].isExit = true;
        enemy1[i].x = rand() % (WIDTH - 60);
        enemy1[i].y = 0;
        enemy1[i].hp = 30;
        count1++;
        if (count1 == 2)
        {
          count1 = 0;
          break;
        }
      }
    }
    for (j = 0; j < 5; j++)//敌机2
    {
      if (enemy2[j].isExit == false)
      {
        enemy2[j].isExit = true;
        enemy2[i].hp = 50;
        enemy2[j].x = rand() % (WIDTH - 60);
        enemy2[j].y = 0;
        count2++;
        if (count2 == 1)
        {
          count2 = 0;
          break;
        }
      }
    }
    if (score > 2500)
    {
      for (j = 0; j < 10; j++)//敌机3
      {
        if (enemy3[j].isExit == false)
        {
          enemy3[j].isExit = true;
          enemy3[j].hp = 30;
          enemy3[j].x = rand() % (WIDTH - 60);
          enemy3[j].y = 0;
          break;
        }
      }
    }
  }
}
void EnemyCreat_L2()
{
  int i, j;
  if (Timer_enemycreat(3000))
  {
    if (score > 5000 && score <= 8000)
    {
      for (i = 0; i < 10; i++)//敌机1
      {
        if (enemy1[i].isExit == false)
        {
          enemy1[i].isExit = true;
          enemy1[i].x = rand() % (WIDTH - 60);
          enemy1[i].y = 0;
          enemy1[i].hp = 30;
          break;
        }
      }
      for (j = 0; j < 5; j++)//敌机2
      {
        if (enemy2[j].isExit == false)
        {
          enemy2[j].isExit = true;
          enemy2[j].hp = 50;
          enemy2[j].x = rand() % (WIDTH - 60);
          enemy2[j].y = 0;
          break;
        }
      }
      for (j = 0; j < 5; j++)//敌机3
      {
        if (enemy3[j].isExit == false)
        {
          enemy3[j].isExit = true;
          enemy3[j].hp = 50;
          enemy3[j].x = -enemy3[i].width * 1.5;
          enemy3[j].y = 0;
          break;
        }
      }
    }
    if (score > 8000)
    {
      EnemyClean();
      for (j = 0; j < 1; j++)
      {
        if (enemy4[j].isExit == false)
        {
          enemy4[j].isExit = true;
          enemy4[j].hp = 10000;
          enemy4[j].x = WIDTH / 2 - enemy4[j].width / 2;
          enemy4[j].y = 0;
          break;
        }
      }
    }
  }
}
void EnemyCreat_L3()
{
  EnemyClean();
  int j;
  if (score < 17000);
  {
    for (j = 0; j < 1; j++)
    {
      if (enemy5[j].isExit == false)
      {
        enemy5[j].isExit = true;
        enemy5[j].hp = 12000;
        enemy5[j].x = WIDTH / 2 - enemy5[j].width / 2;
        enemy5[j].y = 0;
        break;
      }
    }
  }
}
void Enemy_Bullet_Creat()
{
  int i, j;
  if (Timer_enemy2_bullet_creat(5000))//子弹发射频率
  {
    for (j = 0; j < 5; j++)
    {
      for (i = 0; i < enemy_bul_max; i++)
      {
        if (enemy2_bullet[i].isExit == false && enemy2[j].isExit == true)
        {
          enemy2_bullet[i].isExit = true;
          enemy2_bullet[i].x = enemy2[j].x + enemy2[j].width / 2 ;
          enemy2_bullet[i].y = enemy2[j].y;
          break;
        }
      }
    }
  }
  if (Timer_enemy3_bullet_creat(3000))
  {
    for (j = 0; j < 3; j++)
    {
      for (i = 0; i < enemy_bul_max; i++)
      {
        if (enemy3_bullet[i].isExit == false && enemy3[j].isExit == true)
        {
          enemy3_bullet[i].isExit = true;
          enemy3_bullet[i].x = enemy3[j].x + enemy3[j].width / 2;
          enemy3_bullet[i].y = enemy3[j].y;
          break;
        }
      }
    }
  }
  int count4 = 1;
  if (Timer_enemy4_bullet_creat(500))
  {
    for (j = 0; j < 1; j++)
    {
      for (i = 0; i < enemy_bul_max; i++)
      {
        if (enemy4_bullet[i].isExit == false && enemy4[j].isExit == true)
        {
          enemy4_bullet[i].isExit = true;
          if (count4 == 1)
          {
            enemy4_bullet[i].x = enemy4[j].x + 38;
            enemy4_bullet[i].y = enemy4[j].y + 37;
            count4 += 1;
            continue;
          }
          if (count4 == 2)
          {
            count4 = 1;
            enemy4_bullet[i].x = enemy4[j].x + enemy4[j].width - 73;
            enemy4_bullet[i].y = enemy4[j].y + 37;
            break;
          }
        }
      }
    }
  }
  int count5 = 1;
  if (Timer_enemy5_bullet_creat(500))
  {
    for (j = 0; j < 1; j++)
    {
      for (i = 0; i < enemy_bul_max; i++)
      {
        if (enemy5_bullet[i].isExit == false && enemy5[j].isExit == true)
        {
          enemy5_bullet[i].isExit = true;
          if (count5 == 1)
          {
            enemy5_bullet[i].x = enemy5[j].x + 155;
            enemy5_bullet[i].y = enemy5[j].y + 360;
            count5 += 1;
            continue;
          }
          if (count5 == 2)
          {
            count5 = 1;
            enemy5_bullet[i].x = enemy5[j].x + enemy5[j].width - 175;
            enemy5_bullet[i].y = enemy5[j].y + 360;
            break;
          }
        }
      }
    }
  }
}
void Enemy_Bullet_Move()
{
  int i;
  //敌机2
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy2_bullet[i].isExit == true)
    {
      enemy2_bullet[i].y += 2;
      if (enemy2_bullet[i].y < 0)
      {
        enemy2_bullet[i].isExit = false;
      }
    }
  }
  //敌机3
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy3_bullet[i].isExit == true)
    {
      enemy3_bullet[i].y += 2;
      if (enemy3_bullet[i].y < 0)
      {
        enemy3_bullet[i].isExit = false;
      }
    }
  }
  //敌机4
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy4_bullet[i].isExit == true)
    {
      enemy4_bullet[i].y += 2;
      if (enemy4_bullet[i].y < 0)
      {
        enemy4_bullet[i].isExit = false;
      }
    }
  }
  //敌机5
  for (i = 0; i < enemy_bul_max; i++)
  {
    if (enemy5_bullet[i].isExit == true)
    {
      enemy5_bullet[i].y += 2;
      if (enemy5_bullet[i].y < 0)
      {
        enemy5_bullet[i].isExit = false;
      }
    }
  }
}
void Enemy_Bullet_Crush()
{
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < enemy_bul_max; j++)
    {
      if (!enemy2_bullet[j].isExit)
        continue;
      if (enemy2_bullet[j].x > myplane[i].x && enemy2_bullet[j].x < myplane[i].x + myplane[i].width && enemy2_bullet[j].y < myplane[i].y + myplane[i].height && enemy2_bullet[j].y > myplane[i].y)
      {
        myplane[i].hp -= 10;
        setbkmode(TRANSPARENT);
        settextstyle(60, 0, L"华文行楷");
        if (Timer2(1))
        {
          outtextxy(myplane[i].x, myplane[i].y + rand() % (myplane[i].height), _T("-10"));
        }
      }
      if (myplane[i].hp <= 0)
      {
        Judge();
      }
    }
  }
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < enemy_bul_max; j++)
    {
      if (!enemy3_bullet[j].isExit)
        continue;
      if (enemy3_bullet[j].x > myplane[i].x && enemy3_bullet[j].x < myplane[i].x + myplane[i].width && enemy3_bullet[j].y < myplane[i].y + myplane[i].height && enemy3_bullet[j].y > myplane[i].y)
      {
        myplane[i].hp -= 10;
        setbkmode(TRANSPARENT);
        settextstyle(60, 0, L"华文行楷");
        if (Timer2(1))
        {
          outtextxy(myplane[i].x, myplane[i].y + rand() % (myplane[i].height), _T("-10"));
        }
      }
      if (myplane[i].hp <= 0)
      {
        Judge();
      }
    }
  }
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < enemy_bul_max; j++)
    {
      if (!enemy4_bullet[j].isExit)
        continue;
      if (enemy4_bullet[j].x > myplane[i].x && enemy4_bullet[j].x < myplane[i].x + myplane[i].width && enemy4_bullet[j].y < myplane[i].y + myplane[i].height && enemy4_bullet[j].y > myplane[i].y)
      {
        myplane[i].hp -= 10;
        setbkmode(TRANSPARENT);
        settextstyle(60, 0, L"华文行楷");
        if (Timer2(1))
        {
          outtextxy(myplane[i].x, myplane[i].y + rand() % (myplane[i].height), _T("-10"));
        }
      }
      if (myplane[i].hp <= 0)
      {
        Judge();
      }
    }
  }
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < enemy_bul_max; j++)
    {
      if (!enemy5_bullet[j].isExit)
        continue;
      if (enemy5_bullet[j].x > myplane[i].x && enemy5_bullet[j].x < myplane[i].x + myplane[i].width && enemy5_bullet[j].y < myplane[i].y + myplane[i].height && enemy5_bullet[j].y > myplane[i].y)
      {
        myplane[i].hp -= 10;
        setbkmode(TRANSPARENT);
        settextstyle(60, 0, L"华文行楷");
        if (Timer2(1))
        {
          outtextxy(myplane[i].x, myplane[i].y + rand() % (myplane[i].height), _T("-10"));
        }
      }
      if (myplane[i].hp <= 0)
      {
        Judge();
      }
    }
  }
}
void EnemyCrush()
{
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < 10; j++)
    {
      if (!enemy1[j].isExit)
        continue;
      if (enemy1[j].x > myplane[i].x && enemy1[j].x<myplane[i].x + myplane[i].width && enemy1[j].y>myplane[i].y && enemy1[j].y < myplane[i].y + myplane[i].height)
      {
        myplane[i].hp -= 100;
        enemy1[j].isExit = false;
      }
      if (myplane[i].hp <= 0)
        Judge();
    }
  }
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < 5; j++)
    {
      if (!enemy2[j].isExit)
        continue;
      if (enemy2[j].x > myplane[i].x && enemy2[j].x<myplane[i].x + myplane[i].width && enemy2[j].y>myplane[i].y && enemy2[j].y < myplane[i].y + myplane[i].height)
      {
        myplane[i].hp -= 100;
        enemy2[j].isExit = false;
      }
      if (myplane[i].hp <= 0)
        Judge();
    }
  }
  for (int i = 0; i < 1; i++)
  {
    if (!myplane[i].isExit)
      continue;
    for (int j = 0; j < 5; j++)
    {
      if (!enemy3[j].isExit)
        continue;
      if (enemy3[j].x > myplane[i].x && enemy3[j].x<myplane[i].x + myplane[i].width && enemy3[j].y>myplane[i].y && enemy3[j].y < myplane[i].y + myplane[i].height)
      {
        myplane[i].hp -= 100;
        enemy3[j].isExit = false;
      }
      if (myplane[i].hp <= 0)
        Judge();
    }
  }
}
void UpdatePlane()
{
  //飞机移动
  if (GetAsyncKeyState(VK_UP))                //按UP键
  {
    for (int i = 0; i < 1; i++)
    {
      if (myplane[i].y > 0)
        myplane[i].y -= 8;
    }
  }
  if (GetAsyncKeyState(VK_DOWN))              //按DOWN键
  {
    for (int i = 0; i < 1; i++)
    {
      if (myplane[i].y < HEIGHT - myplane[i].height)
        myplane[i].y += 8;
    }
  }
  if (GetAsyncKeyState(VK_LEFT))              //按LEFT键
  {
    for (int i = 0; i < 1; i++)
    {
      if (myplane[i].x > -(myplane[i].width) / 2)
      {
        myplane[i].x -= 8;
      }
    }
  }
  if (GetAsyncKeyState(VK_RIGHT))              //按RIGHT键
  {
    for (int i = 0; i < 1; i++)
    {
      if (myplane[i].x < WIDTH - (myplane[i].width) / 2)
      {
        myplane[i].x += 8;
      }
    }
  }
}
void initGame()
{
  int i;
  //初始化背景地图Y轴坐标
  bky0 = -HEIGHT;
  bky1 = 0;
  bk1y0 = -HEIGHT;
  bk1y1 = 0;
  bk2y0 = -HEIGHT;
  bk2y1 = 0;
  //初始化我方飞机
  for (i = 0; i < 1; i++)
  {
    myplane[i].x = (WIDTH - myplane[i].width) / 2;
    myplane[i].y = (HEIGHT - myplane[i].height);
    myplane[i].hp = 500;
    myplane[i].isExit = true;
  }
  //初始化敌机
  for (i = 0; i < 10; i++)
  {
    enemy1[i].isExit = false;
    enemy1[i].hp = 30;
    enemy1[i].width = 70;
    enemy1[i].height = 70;
  }
  for (i = 0; i < 5; i++)
  {
    enemy2[i].isExit = false;
    enemy2[i].hp = 50;
    enemy2[i].width = 85;
    enemy2[i].height = 90;
  }
  for (i = 0; i < 5; i++)
  {
    enemy3[i].isExit = false;
    enemy3[i].hp = 30;
    enemy3[i].width = 70;
    enemy3[i].height = 70;
  }
  for (i = 0; i < 1; i++)
  {
    enemy4[i].isExit = false;
    enemy4[i].hp = 10000;
    enemy4[i].width = 450;
    enemy4[i].height = 300;
  }
  for (i = 0; i < 1; i++)
  {
    enemy5[i].isExit = false;
    enemy5[i].hp = 12000;
    enemy5[i].width = 500;
    enemy5[i].height = 375;
  }
  //初始化子弹
  bullet[i].x1; bullet[i].y1; bullet[i].x2; bullet[i].y2;
  for (int i = 0; i < bullet_max; i++)
  {
    bullet[i].isExit = false;
  }
  //初始化敌机子弹
  for (i = 0; i < enemy_bul_max; i++)
  {   
    enemy2_bullet[i].isExit = false;
    enemy2_bullet[i].x = 1;
    enemy2_bullet[i].y = 1;
  }
  for (i = 0; i < enemy_bul_max; i++)
  {   
    enemy3_bullet[i].isExit = false;
    enemy3_bullet[i].x = 5;
    enemy3_bullet[i].y = 5;
  }
  for (i = 0; i < enemy_bul_max; i++)
  {   
    enemy4_bullet[i].isExit = false;
    enemy4_bullet[i].x = 50;
    enemy4_bullet[i].y = 50;
  }
  for (i = 0; i < enemy_bul_max; i++)
  {   
    enemy5_bullet[i].isExit = false;
    enemy5_bullet[i].x = 50;
    enemy5_bullet[i].y = 50;
  }
  //加载背景音乐
  mciSendString(L"open level.mp3", 0, 0, 0);
  mciSendString(L"play level.mp3", 0, 0, 0);
}
void level_change()
{
  int ret = level(),i=0;
  if (level_change_count == 1 && score > 5000)
  {
    level_change_count += 1;
    myplane[i].hp = 500;
    EnemyClean();
  }
  if (level_change_count == 2 && score > 12000)
  {
    level_change_count += 1;
    myplane[i].hp = 500;
    EnemyClean();
  }
}
void FailMenu()
{
    initgraph(800, 240);
    setbkmode(TRANSPARENT);
    settextstyle(30, 0, L"宋体");
    outtextxy(10, 20, _T("游戏失败"));
    outtextxy(10, 70, _T("按Delete键退出"));
    outtextxy(10, 120, _T("按Space(空格键)复活并继续游戏"));
    while (1)
    {
      if (GetAsyncKeyState(VK_DELETE)) exit(0);
      if (GetAsyncKeyState(VK_SPACE)) break;
    }
      main();
}
void Judge()
{
  if (myplane->hp <= 0)
  {
    if (level() == 1)
    {
      score = 0;//第一关初试分数为0
    }
    if (level() == 2 && score < 8000)
    {
      score = 5001;//进入第二关,且第二关boss出现前,初始分数为5001
    }
    if (level() == 2 && score > 8000)
    {
      score = 8001;//第二关boss出现后,初始分数
    }
    if (level() == 3)
    {
      score = 12001;//进入第三关,初始分数
    }
    FailMenu();
  }
  if (score > 17000)
  {
    EndMenu();
  }
}
void DrawInterface()
{
  int   bgy=0;                                //主界面图片坐标
  while (1)
  {
    putimage(0, bgy, &bgimg);               //绘制主界面 
    ExMessage msg;
    if (peekmessage(&msg))
    {
      if (msg.message == WM_LBUTTONDOWN)  //按左键退出主界面循环
      break;
    }
  }
}
void UpdateBack()
{
  //背景移动
  bky0++;    
  bky1++;
  if (bky0 > HEIGHT)
    (bky0 = -HEIGHT);                       //如果背景移出初始界面,则放到下面
  if (bky1 > HEIGHT)
    (bky1 = -HEIGHT);
  bk1y0++;
  bk1y1++;
  if (bk1y0 > HEIGHT)
    (bk1y0 = -HEIGHT);                       //如果背景移出初始界面,则放到下面
  if (bk1y1 > HEIGHT)
    (bk1y1 = -HEIGHT);
  bk2y0++;
  bk2y1++;
  if (bk2y0 > HEIGHT)
    (bk2y0 = -HEIGHT);                       //如果背景移出初始界面,则放到下面
  if (bk2y1 > HEIGHT)
    (bk2y1 = -HEIGHT);
}
void DrawBullet()
{
  if (Timer(140))
  {
    //绘制子弹
    for (int i = 0; i < bullet_max; i++)
    {
      if (!bullet[i].isExit)                  //遍历所有子弹位,找到一个空位存放子弹
      {
        bullet[i].x1 = myplane->x + 18;   //若子弹存在初始化子弹坐标
        bullet[i].y1 = myplane->y + 25;
        bullet[i].x2 = myplane->x + 65;
        bullet[i].y2 = myplane->y + 25;
        bullet[i].isExit = true;
        break;                              //发射一次子弹
      }
    }
  }
}
void MoveBullet()
{
  //子弹移动
  for (int i = 0; i < bullet_max; i++)
  {
    if (bullet[i].isExit)
    {
      bullet[i].y1 -= 10;
      bullet[i].y2 -= 10;
      if (bullet[i].y1 > HEIGHT , bullet[i].y2 > HEIGHT )
        bullet[i].isExit = false;  //若子弹飞出则腾出一个子弹位 
    }
  }
}
void Bulletcrush()
{
  for (int i = 0; i < 10; i++)
  {
    if (!enemy1[i].isExit)
      continue;
    for (int j = 0; j < bullet_max; j++)
    {
      if (!bullet[j].isExit)
        continue;
      if ((bullet[j].x1 > enemy1[i].x && bullet[j].x1<enemy1[i].x + enemy1[i].width && bullet[j].y1>enemy1[i].y && bullet[j].y1 < enemy1[i].y + enemy1[i].height) || (bullet[j].x2>enemy1[i].x && bullet[j].x2<enemy1[i].x + enemy1[i].width
        && bullet[j].y2>enemy1[i].y && bullet[j].y2 < enemy1[i].y + enemy1[i].height))
      {
        enemy1[i].hp -= 1;
        if (Timer2(1))
        {
          setbkmode(TRANSPARENT);
          settextstyle(60, 0, L"华文行楷");
          outtextxy(enemy1[i].x, enemy1[i].y + rand() % (enemy1[i].height), _T("-1"));
        }
      }
    }
    if (enemy1[i].hp <= 0)
    {
      enemy1[i].isExit = false;
      score += 100;
      enemy1[i].hp = 30;
    }
  }//小飞机
  for (int i = 0; i < 5; i++)
  {
    if (!enemy2[i].isExit)
      continue;
    for (int j = 0; j < bullet_max; j++)
    {
      if (!bullet[j].isExit)
        continue;
      if ((bullet[j].x1 > enemy2[i].x && bullet[j].x1<enemy2[i].x + enemy2[i].width && bullet[j].y1>enemy2[i].y && bullet[j].y1 < enemy2[i].y + enemy2[i].height) || (bullet[j].x2>enemy2[i].x && bullet[j].x2<enemy2[i].x + enemy2[i].width && bullet[j].y2>enemy2[i].y && bullet[j].y2 < enemy2[i].y + enemy2[i].height))
      {
        enemy2[i].hp -= 1;
        if (Timer2(1))
        {
          setbkmode(TRANSPARENT);
          settextstyle(60, 0, L"华文行楷");
          outtextxy(enemy2[i].x, enemy2[i].y + rand() % (enemy2[i].height), _T("-1"));
        }
      }
    }
    if (enemy2[i].hp <= 0)
    {
      enemy2[i].isExit = false;
      score += 500;
      enemy2[i].hp = 50;
    }
  }//中飞机
  for (int i = 0; i < 5; i++)
  {
    if (!enemy3[i].isExit)
      continue;
    for (int j = 0; j < bullet_max; j++)
    {
      if (!bullet[j].isExit)
        continue;
      if ((bullet[j].x1 > enemy3[i].x && bullet[j].x1<enemy3[i].x + enemy3[i].width && bullet[j].y1>enemy3[i].y && bullet[j].y1 < enemy3[i].y + enemy3[i].height) || (bullet[j].x2>enemy3[i].x && bullet[j].x2<enemy3[i].x + enemy3[i].width && bullet[j].y2>enemy3[i].y && bullet[j].y2 < enemy3[i].y + enemy3[i].height))
      {
        enemy3[i].hp -= 1;
        setbkmode(TRANSPARENT);
        settextstyle(60, 0, L"华文行楷");
        if (Timer2(1))
        {
          outtextxy(enemy3[i].x, enemy3[i].y + rand() % (enemy3[i].height), _T("-1"));
        }
      }
    }
    if (enemy3[i].hp <= 0)
    {
      enemy3[i].isExit = false;
      score += 300;
      enemy3[i].hp = 30;
    }
  }//横行飞机
  for (int i = 0; i < 1; i++)
  {
    if (!enemy4[i].isExit)
      continue;
      for (int j = 0; j < bullet_max; j++)
      {
        if(!bullet[j].isExit)
          continue;
        if ((bullet[j].x1 > enemy4[i].x && bullet[j].x1<enemy4[i].x + enemy4[i].width && bullet[j].y1>enemy4[i].y && bullet[j].y1 < enemy4[i].y + enemy4[i].height) || (bullet[j].x2 > enemy4[i].x && bullet[j].x2<enemy4[i].x + enemy4[i].width && bullet[j].y2>enemy4[i].y && bullet[j].y2 < enemy4[i].y + enemy4[i].height))
        {
          enemy4[i].hp -= rand() % 4 + 1;
          setbkmode(TRANSPARENT);
          settextstyle(60, 0, L"华文行楷");
          if (Timer2(1))
          {
            if (enemy4[i].hp -= 1)
            {
              outtextxy(enemy4[i].x + rand() % (enemy4[i].width), enemy4[i].y + rand() % (enemy4[i].height), _T("-1"));
            }
            if (enemy4[i].hp -= 2)
            {
              outtextxy(enemy4[i].x + rand() % (enemy4[i].width), enemy4[i].y + rand() % (enemy4[i].height), _T("-2"));
            }
            if (enemy4[i].hp -= 3)
            {
              outtextxy(enemy4[i].x + rand() % (enemy4[i].width), enemy4[i].y + rand() % (enemy4[i].height), _T("-3"));
            }
            if (enemy4[i].hp -= 4)
            {
              outtextxy(enemy4[i].x + rand() % (enemy4[i].width), enemy4[i].y + rand() % (enemy4[i].height), _T("暴击 -4"));
            }
            if (enemy4[i].hp -= 5)
            {
              outtextxy(enemy4[i].x + rand() % (enemy4[i].width), enemy4[i].y + rand() % (enemy4[i].height), _T("暴击 -5"));
            }
          }
          printf("%d\n", enemy4[i].hp);
        }
        if (enemy4[i].hp <= 0)
        {
          enemy4[i].isExit = false;
          score += 4000;
        }
      }
  }
  //第二关BOSS
  for (int i = 0; i < 1; i++)
  {
    if (!enemy5[i].isExit)
      continue;
    for (int j = 0; j < bullet_max; j++)
    {
      if (!bullet[j].isExit)
        continue;
      if ((bullet[j].x1 > enemy5[i].x && bullet[j].x1<enemy5[i].x + enemy5[i].width && bullet[j].y1>enemy5[i].y && bullet[j].y1 < enemy5[i].y + enemy5[i].height && bullet[j].x2>enemy5[i].x) || (bullet[j].x2<enemy5[i].x + enemy5[i].width && bullet[j].y2>enemy5[i].y && bullet[j].y2 < enemy5[i].y + enemy5[i].height))
      {
        enemy5[i].hp -= rand() % 5 + 1;
        setbkmode(TRANSPARENT);
        settextstyle(60, 0, L"华文行楷");
        if (Timer2(1))
        {
          if (enemy5[i].hp -= 1)
          {
            outtextxy(enemy5[i].x + rand() % (enemy5[i].width), enemy5[i].y + rand() % (enemy5[i].height), _T("-1"));
          }
          if (enemy5[i].hp -= 2)
          {
            outtextxy(enemy5[i].x + rand() % (enemy5[i].width), enemy5[i].y + rand() % (enemy5[i].height), _T("-2"));
          }
          if (enemy5[i].hp -= 3)
          {
            outtextxy(enemy5[i].x + rand() % (enemy5[i].width), enemy5[i].y + rand() % (enemy5[i].height), _T("-3"));
          }
          if (enemy5[i].hp -= 4)
          {
            outtextxy(enemy5[i].x + rand() % (enemy5[i].width), enemy5[i].y + rand() % (enemy5[i].height), _T("暴击 -4"));
          }
          if (enemy5[i].hp -= 5)
          {
            outtextxy(enemy5[i].x + rand() % (enemy5[i].width), enemy5[i].y + rand() % (enemy5[i].height), _T("暴击 -5"));
          }
          if (enemy5[i].hp -= 6)
          {
            outtextxy(enemy5[i].x + rand() % (enemy5[i].width), enemy5[i].y + rand() % (enemy5[i].height), _T("暴击 -6"));
          }
        }
      }
      if (enemy5[i].hp <= 0)
      {
        enemy5[i].isExit = false;
        score += 5000;
        Judge();
      }
    }
  }
  //第三关BOSS
}
void EndMenu()
{
  EnemyClean();
  enemy5[0].isExit = false;
    loadimage(&bkimg3, L"bk3.jpg");
    int x = 10;
    int y = 20;
    Sleep(1000);
    initgraph(WIDTH, HEIGHT);
    putimage(0, 0, &bkimg3);
    TCHAR time_test1[50];
    TCHAR time_test2[50];
    TCHAR time_test3[50];
    _stprintf_s(time_test1, _T("许多年以后,"));
    _stprintf_s(time_test2, _T("当我再次仰望那片星空"));
    _stprintf_s(time_test3, _T("战机的轰鸣声依旧回荡在耳畔..."));
    setbkmode(TRANSPARENT);
    settextstyle(40, 0, L"华文行楷");
    Sleep(1000);
    outtextxy(x, y, time_test1);
    Sleep(2000);
    outtextxy(x, y + 50, time_test2);
    Sleep(3000);
    outtextxy(x, y + 100, time_test3);
    Sleep(4000);
    exit(0);
}
#include "雷霆飞机.h"
#include <conio.h>
#include<stdio.h>
#include<easyx.h>
#include<windows.h>
#include<mmsystem.h>
#pragma comment(lib,"Winmm.lib")
#define WIDTH 600
#define HEIGHT 850
#define bullet_max 5000//屏幕上同时出现的子弹上限
IMAGE Start;
IMAGE loading;
//将所有封装函数放入主函数进行调用
int count = 1;
int main()
{
  initgraph(WIDTH, HEIGHT,EX_SHOWCONSOLE);
  initGame();
  loadimg();
  DrawInterface();
  BeginBatchDraw();//双缓冲绘图
  while (1)
  {
    UpdateBack();
    level_change();
    if (level() == 1)
    {
      EnemyCreat_L1();
    }
    if (level() == 2)
    {
      EnemyCreat_L2();
    }
    if (level() == 3)
    {
      EnemyCreat_L3();
    }
    EnemyMove();
    Enemy_Bullet_Creat();
    Enemy_Bullet_Move();
    DrawGame();
    UpdatePlane();
    DrawBullet();
    MoveBullet();
    Bulletcrush();
    Enemy_Bullet_Crush();
    EnemyCrush();
    FlushBatchDraw();
    Sleep(2);
  }
  EndBatchDraw();
  return 0;
}

如果有哪里不懂,可以问我,当然如果有哪里有问题,也欢迎大佬提出哦

项目文档

一. 游戏概述

- 游戏类型和玩法

属于一款机战类具有挑战性和娱乐性的游戏

通过获取用户鼠标及键盘消息来控制界面转换和飞机移动以及释放子弹和技能

- 游戏目标和规则

普通模式:

通关最终BOSS,我方飞机受到敌机以及敌机子弹碰撞,则持续扣血,如果飞机血量为0,则返回失败界面(由用户选择复活继续游戏或退出游戏)

挑战模式:

采用无尽模式积分制,并且禁止实用技能,新增漏击判定(即敌机飞出画面认为被击毁,则我方飞机扣血),除非飞机血量为0或用户选择退出游戏,否则游戏持续进行,飞机血量为0,游戏结束并显示最终得分

二. 游戏设计

- 游戏界面设计

选用炫酷的飞机大战图片并且采取菜单模式,可以进行界面转换重复进行游戏

- 游戏关卡和难度设计

普通模式分为三关,分数达到则自动进入下一关卡,难度较小

挑战模式采用无尽模式积分,敌机创建频率增大,难度递增

三. 技术实现

- 游戏开发工具

采用VS2022,Easyx图形库,C语言/C++

- 游戏代码结构和模块划分

1.初始化游戏窗口

2.初始化游戏数据

3.循环游戏事件

编写玩家控制模块,碰撞模块,子弹发射模块,技能发射模块,关卡转换模块,界面转换模块

4.设置游戏结束标志

四. 测试和调试

- 游戏测试计划和用例

玩家控制模块:测试飞机移动边界以及按键响应时间

碰撞模块:测试敌机与子弹,敌机与技能,我方飞机与子弹,我方飞机与敌机碰撞会不会正常扣血与消失,会不会影响下一次敌机创建

子弹发射模块:检测子弹创建后能否按预定轨迹,并且从预定起始位置发射,子弹消失判定以及是否会影响下一次子弹创建

技能发射模块:检测技能创建后能否按预定轨迹,并且从预定起始位置发射,技能消失判定以及碰撞判定

关卡转换模块:分数达到后是否会正常切换关卡背景图,是否会按预定的方式和时间创建敌机和子弹,每次关卡转换之间是否会上一关的敌机和子弹,是否会初始化飞机血量

界面转换模块:检测获取鼠标消息后是否会转换界面以及响应时间,界面转换是否会影响游戏逻辑,如何通过界面转换将不同的模式联系在一起

- 游戏调试工具和方法

VS2022,先对各个模块单独调试,再对整个游戏逻辑(包括关卡转换,界面转换,计分等)进行调试

- 游戏修复和更新流程

1.0:未加入界面转换模块,未加入挑战模式,敌机子弹创建后不移动就消失,未加入暂停界面,未加入子弹发射,飞机移动,爆炸音效

2.0:修复1.0的bug,加入界面转换模块,加入子弹发射,飞机移动,爆炸音效

3.0:加入暂停界面,且通过暂停界面用户可选择继续游戏(保存之前的游戏数据),退出游戏,开启/关闭音效

五. 优化

- 游戏后续更新和改进计划

1.界面转换模块

问题:响应时间较长,且一次游戏结束后,用户选择返回菜单继续游戏,游戏画面会出现偶尔卡顿

猜想:游戏数据处理不当,内存无法及时释放导致卡顿

改进计划:引入数据结构,适当优化及存储游戏数据,增加游戏运行时间,流畅性

2.问题:持续按住攻击键不放,一段时间偶尔会出现卡顿

猜想:由按下攻击键后的音效引发,因为音效采用多线程,频繁调用多线程,且线程得不到及时释放会造成线程死锁,从而使程序卡顿

改进方法:设定线程存在时间,到达一定时间自动释放

六. 总结和展望

- 游戏开发过程中的经验和教训

增加我对C语言的使用熟练度,更好的掌握条件控制与循环控制程序运行

接触到一部分C++知识如IMAGE变量,MySQL数据库,多线程使用(基础版),有利于我之后进一步接触C++

对bug的调试更加熟练,同时掌握开发游戏最基础的逻辑,锻炼自己的逻辑思维

增加团队合作,增长团队合作精神

相关文章
|
1月前
|
安全 编译器 C语言
C++入门1——从C语言到C++的过渡
C++入门1——从C语言到C++的过渡
52 2
|
7天前
|
C语言 Windows
C语言课设项目之2048游戏源码
C语言课设项目之2048游戏源码,可作为课程设计项目参考,代码有详细的注释,另外编译可运行文件也已经打包,windows电脑双击即可运行效果
18 1
WK
|
16天前
|
机器学习/深度学习 人工智能 算法
那C++适合开发哪些项目
C++ 是一种功能强大、应用广泛的编程语言,适合开发多种类型的项目。它在游戏开发、操作系统、嵌入式系统、科学计算、金融、图形图像处理、数据库管理、网络通信、人工智能、虚拟现实、航空航天等领域都有广泛应用。C++ 以其高性能、内存管理和跨平台兼容性等优势,成为众多开发者的选择。
WK
37 1
|
1月前
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
262 3
|
1月前
|
C语言 C++
C 语言的关键字 static 和 C++ 的关键字 static 有什么区别
在C语言中,`static`关键字主要用于变量声明,使得该变量的作用域被限制在其被声明的函数内部,且在整个程序运行期间保留其值。而在C++中,除了继承了C的特性外,`static`还可以用于类成员,使该成员被所有类实例共享,同时在类外进行初始化。这使得C++中的`static`具有更广泛的应用场景,不仅限于控制变量的作用域和生存期。
53 10
|
2月前
|
C++
【C++案例】一个项目掌握C++基础-通讯录管理系统
这篇文章通过一个通讯录管理系统的C++项目案例,详细介绍了如何使用C++实现添加、显示、删除、查找、修改和清空联系人等功能。
42 3
|
2月前
|
算法 机器人 C语言
ROS仿真支持C++和C语言
ROS仿真支持C++和C语言
67 1
|
1月前
|
C语言 C++
实现两个变量值的互换[C语言和C++的区别]
实现两个变量值的互换[C语言和C++的区别]
19 0
|
3月前
|
编译器 Linux C语言
【C++小知识】为什么C语言不支持函数重载,而C++支持
【C++小知识】为什么C语言不支持函数重载,而C++支持
|
2月前
|
编译器 C语言 C++
从C语言到C++
本文档详细介绍了C++相较于C语言的一些改进和新特性,包括类型检查、逻辑类型 `bool`、枚举类型、可赋值的表达式等。同时,文档还讲解了C++中的标准输入输出流 `cin` 和 `cout` 的使用方法及格式化输出技巧。此外,还介绍了函数重载、运算符重载、默认参数等高级特性,并探讨了引用的概念及其应用,包括常引用和引用的本质分析。以下是简要概述: 本文档适合有一定C语言基础的学习者深入了解C++的新特性及其应用。