亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C語言簡易版flappy bird小游戲

 更新時間:2018年12月21日 15:34:16   作者:叫我小紅  
這篇文章主要為大家詳細介紹了C語言簡易版flappy bird小游戲,具有一定的參考價值,感興趣的小伙伴們可以參考一下

假期在家無聊,想隨便碼點東西,故有此簡陋的小游戲誕生。覺著可能對初學C語言的小伙伴練習有點幫助,故寫此博客。游戲界面如下:


首先,先畫出整個小游戲實現(xiàn)的流程圖,如下:


思路很簡單,整個游戲界面是由一個大的char類型數(shù)組構成,更新數(shù)組的值然后不停的打印出來就形成了動態(tài)效果。

由上圖看,大循環(huán)是保證游戲一直不斷的進行下去,小循環(huán)是讓小鳥的速度大于游戲界面里背景(由#構成的柱子)的速度(小鳥動四下柱子才動一下)。

下面是具體代碼(水平有限大家多多見諒,但是效果還是有的!)

Bird.c文件

#include <stdio.h>
#include <windows.h>
#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 <stdio.h>
#include <stdlib.h>
#include<conio.h>
#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;//用于計數(shù)輸出并排兩列黑柱子同一位置
int black;//黑方塊位置
int p= M/2 ;//小鳥初始位置
int score = 0;//分數(shù)

/*初始化界面*/
void InitialInterface(void)
{
  printf("\n   作者:xhyang,博客地址:http://blog.csdn.net/weixin_39449570\n");
  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("\n\n   游戲結束!\n\n");
  printf("   最終得分:%d\n\n\n", 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_39449570\n");
 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);
}

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能

    C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能

    LibCurl是一個開源的免費的多協(xié)議數(shù)據(jù)傳輸開源庫,該框架具備跨平臺性,開源免費,并提供了包括HTTP、FTP、SMTP、POP3等協(xié)議的功能,本文將給大家介紹C++使用LibCurl實現(xiàn)Web隱藏目錄掃描功能
    2023-11-11
  • C語言進階學習之指針

    C語言進階學習之指針

    關于指針,其是C語言的重點,C語言學的好壞,其實就是指針學的好壞。其實指針并不復雜,學習指針,要正確的理解指針,本片文章能給就來學習一下
    2021-09-09
  • 一些C語言中字符串的算法問題解決實例小結

    一些C語言中字符串的算法問題解決實例小結

    這篇文章主要介紹了一些C語言中字符串的算法問題解決實例小結,包括將字符串轉化為int類型的數(shù)及旋轉字符串等操作,需要的朋友可以參考下
    2016-03-03
  • C語言文件操作實現(xiàn)數(shù)據(jù)持久化(幫你快速了解文件操作函數(shù))

    C語言文件操作實現(xiàn)數(shù)據(jù)持久化(幫你快速了解文件操作函數(shù))

    持久數(shù)據(jù)其實就是將數(shù)據(jù)保存到數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關于C語言文件操作實現(xiàn)數(shù)據(jù)持久化(幫你快速了解文件操作函數(shù))的相關資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-11-11
  • Visual Studio C++指針靠前靠后的問題全面解析

    Visual Studio C++指針靠前靠后的問題全面解析

    這篇文章主要介紹了Visual Studio C++指針靠前靠后的問題全面解析,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-04-04
  • C++?std::chrono庫使用示例(實現(xiàn)C++?獲取日期,時間戳,計時等功能)

    C++?std::chrono庫使用示例(實現(xiàn)C++?獲取日期,時間戳,計時等功能)

    std::chrono是C++標準庫中的一個組件,用于表示和處理時間,這篇文章主要介紹了C++?std::chrono庫使用指南(實現(xiàn)C++?獲取日期,時間戳,計時等功能),需要的朋友可以參考下
    2023-06-06
  • 淺談時間戳與日期時間互轉C語言

    淺談時間戳與日期時間互轉C語言

    下面小編就為大家?guī)硪黄獪\談時間戳與日期時間互轉C語言。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-06-06
  • C++冒泡排序與選擇排序詳解

    C++冒泡排序與選擇排序詳解

    大家好,本篇文章主要講的是C++冒泡排序與選擇排序詳解,感興趣的同學趕快來看一看吧,對你有幫助的話記得收藏一下,方便下次瀏覽
    2021-12-12
  • C語言基本排序算法之shell排序實例

    C語言基本排序算法之shell排序實例

    這篇文章主要介紹了C語言基本排序算法之shell排序,結合具體實例形式分析了基于C語言的shell排序原理與實現(xiàn)技巧,代碼注釋中備有詳細的說明,需要的朋友可以參考下
    2017-09-09
  • 詳解C語言的隨機數(shù)生成及其相關題目

    詳解C語言的隨機數(shù)生成及其相關題目

    這篇文章主要介紹了詳解C語言的隨機數(shù)生成及其相關題目,作者還列舉了阿里巴巴的一道相關的面試題,需要的朋友可以參考下
    2015-08-08

最新評論