C語言簡易版flappy bird小游戲
假期在家無聊,想隨便碼點(diǎn)東西,故有此簡陋的小游戲誕生。覺著可能對初學(xué)C語言的小伙伴練習(xí)有點(diǎn)幫助,故寫此博客。游戲界面如下:
首先,先畫出整個(gè)小游戲?qū)崿F(xiàn)的流程圖,如下:
思路很簡單,整個(gè)游戲界面是由一個(gè)大的char類型數(shù)組構(gòu)成,更新數(shù)組的值然后不停的打印出來就形成了動(dòng)態(tài)效果。
由上圖看,大循環(huán)是保證游戲一直不斷的進(jìn)行下去,小循環(huán)是讓小鳥的速度大于游戲界面里背景(由#構(gòu)成的柱子)的速度(小鳥動(dòng)四下柱子才動(dòng)一下)。
下面是具體代碼(水平有限大家多多見諒,但是效果還是有的!)
Bird.c文件
#include <stdio.h> #include <windows.h> #include "Interface.h" int main(void) { InitialInterface(); for(;;) { newinterface(); scoring();//過一個(gè)柱子計(jì)一次分,所以和柱子更新速度一致 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;//用于計(jì)數(shù)輸出并排兩列黑柱子同一位置 int black;//黑方塊位置 int p= M/2 ;//小鳥初始位置 int score = 0;//分?jǐn)?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"); } } /*更新界面各個(gè)柱子*/ void newinterface(void) { if (interf[0][1] == 35 && num==0)//當(dāng)矩陣第二列為黑色方塊時(shí),計(jì)算出下一次黑柱子上半部分的位置 { 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)))//此時(shí)上面的第二列變成了第一列,更新下一個(gè)黑柱子,有了黑柱子上半部分位置+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; } } } } /*計(jì)分*/ void scoring(void) { if (p > 20 || interf[p][0] == 35) { system("cls"); printf("\n\n 游戲結(jié)束!\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)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
C++使用LibCurl實(shí)現(xiàn)Web隱藏目錄掃描功能
LibCurl是一個(gè)開源的免費(fèi)的多協(xié)議數(shù)據(jù)傳輸開源庫,該框架具備跨平臺性,開源免費(fèi),并提供了包括HTTP、FTP、SMTP、POP3等協(xié)議的功能,本文將給大家介紹C++使用LibCurl實(shí)現(xiàn)Web隱藏目錄掃描功能2023-11-11一些C語言中字符串的算法問題解決實(shí)例小結(jié)
這篇文章主要介紹了一些C語言中字符串的算法問題解決實(shí)例小結(jié),包括將字符串轉(zhuǎn)化為int類型的數(shù)及旋轉(zhuǎn)字符串等操作,需要的朋友可以參考下2016-03-03C語言文件操作實(shí)現(xiàn)數(shù)據(jù)持久化(幫你快速了解文件操作函數(shù))
持久數(shù)據(jù)其實(shí)就是將數(shù)據(jù)保存到數(shù)據(jù)庫,下面這篇文章主要給大家介紹了關(guān)于C語言文件操作實(shí)現(xiàn)數(shù)據(jù)持久化(幫你快速了解文件操作函數(shù))的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-11-11Visual Studio C++指針靠前靠后的問題全面解析
這篇文章主要介紹了Visual Studio C++指針靠前靠后的問題全面解析,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-04-04C++?std::chrono庫使用示例(實(shí)現(xiàn)C++?獲取日期,時(shí)間戳,計(jì)時(shí)等功能)
std::chrono是C++標(biāo)準(zhǔn)庫中的一個(gè)組件,用于表示和處理時(shí)間,這篇文章主要介紹了C++?std::chrono庫使用指南(實(shí)現(xiàn)C++?獲取日期,時(shí)間戳,計(jì)時(shí)等功能),需要的朋友可以參考下2023-06-06淺談時(shí)間戳與日期時(shí)間互轉(zhuǎn)C語言
下面小編就為大家?guī)硪黄獪\談時(shí)間戳與日期時(shí)間互轉(zhuǎn)C語言。小編覺得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2016-06-06

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