栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

C语言简易版flappy bird小游戏

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

C语言简易版flappy bird小游戏

假期在家无聊,想随便码点东西,故有此简陋的小游戏诞生。觉着可能对初学C语言的小伙伴练习有点帮助,故写此博客。游戏界面如下:


首先,先画出整个小游戏实现的流程图,如下:


思路很简单,整个游戏界面是由一个大的char类型数组构成,更新数组的值然后不停的打印出来就形成了动态效果。

由上图看,大循环是保证游戏一直不断的进行下去,小循环是让小鸟的速度大于游戏界面里背景(由#构成的柱子)的速度(小鸟动四下柱子才动一下)。

下面是具体代码(水平有限大家多多见谅,但是效果还是有的!)

Bird.c文件

#include 
#include 
#include "Interface.h"

int main(void)
{
 InitialInterface();
 for(;;)
 { 
  newinterface();
  scoring();//过一个柱子计一次分,所以和柱子更新速度一致
  for (int i = 0; i < 4; i++)//小鸟的速度是柱子的4倍
  {
   birdmove();
   draw();
   Sleep(50);
  } 
 }
 return 0;
}

Interface.h文件

#ifndef INTERFACE_H
#define INTERFACE_H

#define M 20
#define N 36

void InitialInterface(void);
void newinterface(void);
void birdmove(void);
void scoring(void);
void draw(void);

#endif

Interface.c文件

#include 
#include 
#include
#include "interface.h"


char interf[M][N] = {{ 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,32,32 },
     { 32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,32,32 },
     { 38,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 },
     { 32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 },
     { 32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35,32,32,32,32,32,32,32,32,32,32,35,35 }, };
//初始界面矩阵,ASCII码中“ ”是32,“&”是38表示小鸟,“#”是35用来画柱子

int num = 0;//用于计数输出并排两列黑柱子同一位置
int black;//黑方块位置
int p= M/2 ;//小鸟初始位置
int score = 0;//分数


void InitialInterface(void)
{
  printf("n   作者:xhyang,博客地址:http://blog.csdn.net/weixin_39449570n");
  printf("   按"w"使小鸟跳起来,别落地,顺利穿过尽可能多的柱子!n");
  for (int i = 0; i < M; i++)
  {
   printf("   ");
   for (int j = 0; j < N; j++)
   {
    printf("%c", interf[i][j]);
   }
   printf("n");
  }
}



void newinterface(void)
{

 if (interf[0][1] == 35 && num==0)//当矩阵第二列为黑色方块时,计算出下一次黑柱子上半部分的位置
 { 
  black = 5 + rand() % 5;
  num = 2;//黑柱子是两列#组成,第二列与第一列位置一样,用num保证两列位置一致
 }
 for (int i = 0; i < M; i++)
 {

  for (int j = 0; j < N - 1; j++)
  {
   interf[i][j] = interf[i][j + 1];
  }
  if (interf[0][0] == 35 && (i < black || i>(black + 5)))//此时上面的第二列变成了第一列,更新下一个黑柱子,有了黑柱子上半部分位置+5即是下半部分的起始位置
  {
   interf[i][N-1] = 35;
  }
  else
  {
   interf[i][N-1] = 32;
  }
 }
 if (num > 0)
  num--;
}



void birdmove(void)
{
 for (int a = 0; a < 3; a++)
 {
  if (a == 2 && p > 0)//减缓鸟的速度,使按键上跳速度是下落的4倍
  {
   p = p + 1;
  }
  if (_kbhit())
  {
   if (_getch() == 'w' || _getch() == 'W')
   {
    p = p - 3;
   }
  }
 }
}


void scoring(void)
{
 if (p > 20 || interf[p][0] == 35)
 {
  system("cls");
  printf("nn   游戏结束!nn");
  printf("   最终得分:%dnnn", score);
  system("pause");
 }

 if (interf[0][0] == 35 && interf[0][1] == 32 )
  score++;
}


void draw(void)
{
 system("cls");
 printf("n   作者:xhyang,博客地址:http://blog.csdn.net/weixin_39449570n");
 printf("   按"w"使小鸟跳起来,别落地,顺利穿过尽可能多的柱子!n");
 for (int i = 0; i < M; i++)
 {
  printf("   ");
  for (int j = 0; j < N; j++)
  {
   if (i == p && j == 0 && interf[p][0] != 35)
    printf("%c", 38);
   else
    printf("%c", interf[i][j]);
  }
  printf("n");

 }
 printf("   得分:%d n", score);
}

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

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/62661.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号