转载:Flappy Bird源代码 win32 console版
#include"StdAfx.h" #include<stdio.h> #include<stdlib.h> #include<conio.h>
#include<time.h>
#include<Windows.h>
/********函数变量声明********/
#define PR_Box printf("■")
#define PR_Gold printf("★")
#define PR_Ag printf("☆")
#define PR_FBird printf("Ю")
#define PR_DBird printf("Ф")
#define PR_Land printf("┳┳┯")
#define PR_Bg_TL printf("╔")
#define PR_Bg_TR printf("╗")
#define PR_Bg_DL printf("╚")
#define PR_Bg_DR printf("╝")
#define PR_Bg_X printf("═")
#define PR_Bg_Y printf("║")
#define PR_Blank printf(" "); int Grade = , C_Gold = , C_Ag = , Score = , Delay_time = ,Max_blank=,Distance=; struct Birds
{
int x, y;
int condition;
}; Birds *Bird = (Birds*)malloc(sizeof(Birds)); struct Bg
{
int x, y;
int l_blank;
int reward[];
Bg *pri;
Bg *next;
}; Bg *Bg1 = new Bg[sizeof(Bg)]; void Position(int x, int y)
{
COORD pos = { x - , y - };
HANDLE Out = GetStdHandle(STD_OUTPUT_HANDLE);
SetConsoleCursorPosition(Out, pos);
} void CreatBird()
{
Bird->x=;
Bird->y=;
Bird->condition =;
} void CreatBg()
{
Bg *Bg2 = (Bg*)malloc(sizeof(Bg)); Bg1->x=;Bg1->y =;
Bg2->x=Bg1->x+Distance;Bg2->y =; Bg1->l_blank =Max_blank-Grade;
Bg2->l_blank =Max_blank-Grade; //循环链表?
Bg1->next=Bg2;
Bg1->pri=Bg2;
Bg2->next=Bg1;
Bg2->pri=Bg1;
} void InsertBg(Bg *p)
{
int temp;
Bg *Bgs = (Bg*)malloc(sizeof(Bg));
Bgs->x=p->pri->x+Distance;
Bgs->l_blank =Max_blank-Grade;
srand((int)time());
temp=rand();
if(temp%==)//++
{
if((temp%+p->pri->y+Max_blank-Grade)<)
Bgs->y=p->pri->y+temp%;
else
Bgs->y=p->pri->y;
}
else
{
if((p->pri->y-temp%)>)
Bgs->y=p->pri->y-temp%;
else
Bgs->y=p->pri->y;
} Bgs->pri=p->pri;
Bgs->next =p;
p->pri->next=Bgs;
p->pri =Bgs;
} void Check_Bg(Bg *q)
{
Bg *p=q;int i=,temp;
while(++i<=)
{
if(p->x>-)
p=p->next;
else
{
srand((int)time());
temp=rand();
if(temp%==)//++
{
if((temp%+p->y+Max_blank-Grade)<)
p->y=p->y+temp%;
else
p->y=p->y;
p->x=p->pri->x+Distance;
p->l_blank=Max_blank-Grade;
}
else
{
if((p->y-temp%)>)
p->y=p->y-temp%;
else
p->y=p->y;
p->x=p->pri->x+Distance;
p->l_blank=Max_blank-Grade;
}
} } }
void Loop_Bg(Bg *q)
{
Bg *p=q;int i=;
while(++i<=)
{
p->x=p->x-;
p=p->next ;
if(Bird->x==p->x)
{
Score+=;
if(Score%==&&Grade<)
Grade++;
}
}
} void Prt_Bg(Bg *q)
{
Bg *p=q;int i=,k,j;
while(++i<=)
{
if(p->x>&&p->x<=)
{ for(k=;k<p->y;k++)
{
Position(p->x+,k);
PR_Box;PR_Box;PR_Blank
}
Position(p->x,p->y);
PR_Box;PR_Box;PR_Box;PR_Blank;
Position(p->x,p->y+p->l_blank);
PR_Box;PR_Box;PR_Box;PR_Blank;
k=k+p->l_blank+;
for(k;k<=;k++)
{
Position(p->x+,k);
PR_Box;PR_Box;PR_Blank;
}
Position(p->x,);
for(k=;k<Distance/-;k++)
PR_Land;
}
p=p->next;
if(p->x==)
{
for(j=;j<p->y;j++)
{ Position(p->x+,j);
PR_Blank;PR_Blank;
}
Position(p->x+,p->y);
PR_Blank;PR_Blank;PR_Blank;
Position(p->x+,p->y+Max_blank-Grade);
PR_Blank;PR_Blank;PR_Blank;
j=j+Max_blank-Grade+;
for(j;j<=;j++)
{Position(p->x+,j);
PR_Blank;PR_Blank;
}
}
}
}
void PrtBg()
{
int i;
Position(,);PR_Bg_TL;
Position(,);PR_Bg_TR;
Position(,);PR_Bg_DL;
Position(,);PR_Bg_DR;
for(i=;i<=;i+=)
{
Position(i,);PR_Bg_X;
Position(i,);PR_Bg_X;
}
/*for(i=2;i<=23;i++)
{ Position(1,i);PR_Bg_Y;printf("%d",i-1);
Position(79,i);PR_Bg_Y;
}*/
}
void PrtBird()
{
Position(Bird->x,Bird->y-);
PR_Blank;
Position(Bird->x,Bird->y);
PR_FBird;
Position(,);
printf("Score:%d",Score);
}
int CheckYN(Bg *q)
{
Bg *p=q;int i=;
while(++i<=)
{
if(Bird->y>)
return ;
if(Bird->x==p->x&&Bird->y<=p->y)
return ;
if((Bird->x==p->x||Bird->x==p->x+||Bird->x==p->x+)&&Bird->y==p->y)
return ;
if(Bird->x==p->x&&Bird->y>p->y+p->l_blank)
return ;
if((Bird->x==p->x||Bird->x==p->x+||Bird->x==p->x+)&&Bird->y==p->y+p->l_blank)
return ;
p=p->next;
}
return ;
}
void Prtfirst()
{
printf("══════════════════════════════════════\n");
printf(" ■■ ■■\n");
printf(" ■■ ■■\n");
printf(" ■■ ■■\n");
printf(" ■■ ■■\n");
printf(" ■■ ■■ C语言版 Flappy Bird\n");
printf(" ■■ ■■ 瞎搞人:yyposs\n");
printf(" ■■ ■■ 瞎搞日期:2014.2\n");
printf(" ■■ ■■ 耗时:4小时\n");
printf(" ■■■ ■■ 游戏说明:\n");
printf(" ■■ 1-按上箭头使鸟起飞\n");
printf(" ■■ 2-等级越高,难度越大!\n");
printf(" Ю ■■■\n");
printf("\n");
printf(" \n\n\n\n\n\n\n\n");
printf(" ┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳┳┯┳\n");
system("pause");
Position(,);
int i=;
while(i++<*)
PR_Blank;
}
void main()
{
int i=;char ch;
Prtfirst(); PrtBg();
CreatBg();
InsertBg(Bg1);
InsertBg(Bg1);
InsertBg(Bg1);
CreatBird();
while()
{
if(!CheckYN(Bg1))
break;
Check_Bg(Bg1);
Prt_Bg(Bg1);
PrtBird();
Loop_Bg(Bg1);
Bird->y=Bird->y+;
if(GetAsyncKeyState(VK_UP))
{
Position(Bird->x,Bird->y-);
PR_Blank;
Bird->y=Bird->y-;
}
while(i++<);
{
Sleep();
}
i=;
}
Position(,);
printf("You Lost!");
Position(,);
system("pause");
}
在校内上看到这份代码,对vs进行些配置后可以运行,mark在此。
转载:Flappy Bird源代码 win32 console版的更多相关文章
- Flappy bird源代码(略吊)
#include<stdio.h> #include<stdlib.h> #include<conio.h> #include<time.h> #inc ...
- HTML5 版的flappy bird
Flappy Bird这款简单的小游戏累计下载量已经超过5000万次,每天收入至少5万美元.然而,2月10日其开发者Dong Nguyen却将Flappy Bird从苹果App Store和Googl ...
- C语言版flappy bird黑白框游戏
在此记录下本人在大一暑假,2014.6~8这段时间复习C语言,随手编的一个模仿之前很火热的小游戏----flappy bird.代码bug基本被我找光了,如果有哪位兄弟找到其他的就帮我留言下吧,谢谢了 ...
- 也来山寨一版Flappy Bird (js版)
随着Flappy Bird的火爆,各种实现的版也不断出现,于是也手痒简单实现了一版. 其实本来只是想实现一下这只笨鸟的飞翔运动的,后来没忍住,就直接实现一个完整游戏了…… 因为这个游戏本身实现起来就没 ...
- flappy bird游戏源代码揭秘和下载
转:http://blog.csdn.net/touchsnow/article/details/19071961 背景: 最近火爆全球的游戏flappy bird让笔者叹为观止,于是花了一天的时间山 ...
- 教你从头到尾利用DQN自动玩flappy bird(全程命令提示,GPU+CPU版)【转】
转自:http://blog.csdn.net/v_JULY_v/article/details/52810219?locationNum=3&fps=1 目录(?)[-] 教你从头到尾利用D ...
- cocos2dx-html5 实现网页版flappy bird游戏
我也是第一次使用cocos2d_html5,对js和html5也不熟,看引擎自带的例子和引擎源码,边学边做,如果使用过cocos2d-x的话,完成这个游戏还是十分简单的.游戏体验地址: http:// ...
- [Win32::Console]Perl终端版生命游戏
环境,WinXP/Win7 Perl 5.16 默认循环1000次,按ESC提前退出 use strict; use Term::ReadKey; use Win32::Console; use T ...
- 自己动手写游戏:Flappy Bird
START:最近闲来无事,看了看一下<C#开发Flappy Bird游戏>的教程,自己也试着做了一下,实现了一个超级简单版(十分简陋)的Flappy Bird,使用的语言是C#,技术采用了 ...
随机推荐
- 【MySQL】mac环境下使用navicat premium连接mysql乱码问题
---恢复内容开始--- 最重要的两点:使用navicat premium创建mysql连接和在mysql连接里面创建数据库时,需要注意. 1.创建连接时,Encoding不需要手动选择,保持Auto ...
- 【windows】win7 sp1 系统语言中英文切换
注:Windows 7 Ultimate and Windows 7 Enterprise (旗舰版和企业版) 可以直接在控制面板/地区和语言中修改显示语言,其他系统不行 进入网站下载相关的MUI包安 ...
- PHP获取文件夹内所有文件包括子目录文件的名称或路径
/* * new getFile($_dir[,$_emptyDir,$_fileType]); * @parma $_dir 是目录名称 * @parma $_emptyDir 是否获取空文件夹,选 ...
- python可视化动态图表: 关于pyecharts的sankey桑基图绘制
最近因工作原因,需要处理一些数据,顺便学习一下动态图表的绘制.本质是使具有源头的流动信息能够准确找到其上下级关系和流向. 数据来源是csv文件 导入成为dataframe之后,列为其车辆的各部件供应商 ...
- leetcode-13-basic-binaryTree
101. Symmetric Tree 解题思路: 递归的方法如下.分几种情况考虑,如果左子树和右子树都是空,那么返回true:如果不同时为空,返回false:如果都不为空,则 判断其值是否相等,不相 ...
- exp分析
1 from pwn import* 2 3 local =1 4 debug = 1 5 6 if local: 7 p = process('./pwn1') 8 else: 9 p = remo ...
- LeetCode(219) Contains Duplicate II
题目 Given an array of integers and an integer k, find out whether there are two distinct indices i an ...
- Mysql操作规范
(1)linux下开启.关闭.重启mysql服务命令 一. 启动1.使用 service 启动:service mysql start2.使用 mysqld 脚本启动:/etc/inint.d/mys ...
- 枚举进程——暴力搜索内存(Ring0)
上面说过了隐藏进程,这篇博客我们就简单描述一下暴力搜索进程. 一个进程要运行,必然会加载到内存中,断链隐藏进程只是把EPROCESS从链表上摘除了,但它还是驻留在内存中的.这样我们就有了找到它的方法. ...
- 00018_流程控制语句switch
1.选择结构switch switch 条件语句也是一种很常用的选择语句,它和if条件语句不同,它只能针对某个表达式的值作出判断,从而决定程序执行哪一段代码. 2.switch语句的语法格式 swit ...