C语言数字雨--90行代码
发布日期:2021-05-06 10:51:32 浏览次数:16 分类:技术文章

本文共 2216 字,大约阅读时间需要 7 分钟。

C语言数字雨–90行代码

上图

在这里插入图片描述

前期准备:

因为我们用C语言写会用到图形库,所以需要进行环境的搭建;
我这里用的VS2019,先到官方下载一个EasyX.exe;
具体在我的文章"雷霆战机"叙述过

#include
#include
#include
#include
#define MAXSTRNUMBER 128 //最多出现多少串#define MAXLONG 20 //字串最大长度#define SPACE 15 //两个串之间的距离#define X 1920 //屏幕横最大坐标#define Y 1080 //屏幕最大纵坐标struct Posiation { int x, y; int speed; char str[MAXLONG];}strNumber[MAXSTRNUMBER];char getRandChar() { char temp; int flag = rand() % 3; if (flag == 0) { return temp = rand() % 10 + '0'; } else if (flag == 1) { return temp = rand() % 26 + 'a'; } else if (flag == 2) { return temp = rand() % 26 + 'A'; }}void initializationStr() { for (int i = 0; i < MAXSTRNUMBER;++i) { strNumber[i].x = i * SPACE;//初始化x坐标,随着i++,x坐标不断增大,最小为0,最大不超过X strNumber[i].y = rand()%Y;//初始化y坐标,y是随机的,这也就意味着y可以出现任何地方, //只要保证y在Y范围内就行了 strNumber[i].speed = rand() % 5 + 5;//速度随机在5-10之间; } for (int i = 0; i < MAXSTRNUMBER;++i) { for (int j = 0; j < MAXLONG;++j) { strNumber[i].str[j] = getRandChar();//随机对每一个串中的每一个元素赋值 } }}void printXY() { cleardevice(); //这里的strNumber.y- j * SPACE;即随着j++y值越来越小,所以,所有元素 //都在某一x坐标上,然后紧随第一个元素,y坐标不同,排列在一起,就成一个串了; for (int i = 0; i < MAXSTRNUMBER;++i) { for (int j = 0; j < MAXLONG;++j) { outtextxy(strNumber[i].x, strNumber[i].y - j*SPACE, strNumber[i].str[j]); settextcolor(RGB(0,255 - j*13,0)); } }}void changeXY() { //我们需要当每一次字串落下完毕以后,改变,重置其位置,否则,就只能看到一阵流星划过 //然后就啥也没有了,所以当我们某一个字符串的尾部,到达最低端的时候,就重置 // for (int i = 0; i < MAXSTRNUMBER;++i) { strNumber[i].y += strNumber[i].speed;//不断改变y坐标位置; if (strNumber[i].y - SPACE*MAXLONG > Y) { strNumber[i].y = 0; } }}void changeStr() { //我们还需要随机选择结构体中的随机数组中的随机某个元素进行随机改变 for (int i = 0; i < MAXSTRNUMBER;++i) { strNumber[rand()%MAXSTRNUMBER].str[rand()%MAXLONG] = getRandChar(); }}int main() { srand(GetTickCount()); initgraph(X,Y); initializationStr(); //sleep不建议使用,它是暂停了,整个程序20毫秒,而我们另一种方法,是局部暂停 //那就是获取时间差,当差值>20的时候,就执行; DWORD time1, time2; time1 = time2 = GetTickCount(); while (1) { BeginBatchDraw(); printXY(); changeStr(); if (time2 - time1 > 20) { changeXY(); time1 = time2; } time2 = GetTickCount(); EndBatchDraw(); } getchar(); closegraph(); return 0;}
上一篇:数据结构大作业--迷宫问题
下一篇:C语言雷霆战机

发表评论

最新留言

逛到本站,mark一下
[***.202.152.39]2025年03月30日 12时56分18秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

java编程常见类型题 --- 面向对象编程、程序逻辑(金字塔)、多线程同步 2019-03-04
java编程常见类型题 --- 程序逻辑(最小台阶)、多线程(计算读取)、Swing布局(国际棋盘) 2019-03-04
【MapReduce】基础案例 ---- 自定义OutputFormat <根据内容输出到指定文件目录中> 2019-03-04
【Android】 模拟器上运行程序报错 2019-03-04
【sklearn练习】KMeans ---- iris(鸢尾花)数据集聚类评估 2019-03-04
【HTML5 CSS】display和visibility的区别 2019-03-04
java线程(4)——使用多个线程操作同一个对象(买票的例子) 2019-03-04
前端HTML中表单action属性的作用 2019-03-04
java线程(17)——Lock锁,三个线程抢票加上lock锁后变成三个线程排队买票 2019-03-04
java线程(19)——信号灯法,电视播放,生产者与消费者的案例 2019-03-04
java线程(20)——Runnable线程池 2019-03-04
计算机网络ip知识点 2019-03-04
react(3)——导入了正确的包,但是运行不出来,原因是因为导入包的顺序有问题 2019-03-04
react(10)——三大属性state,props,refs,总结其特点 2019-03-04
javascript(7)——定义函数的两种方式以及使用的时候传入多个参数的情况,arguments和...rest 2019-03-04
react(20)——使用函数的柯里化实现获取表单的数据 2019-03-04
react(28)——react脚手架public目录下文件讲解 2019-03-04
看领导者系列第二部《成为领导者》的几点感悟 2019-03-04
mybatis(11)——在mybatis中配置并使用log4j日志 2019-03-04
不同路径--动态规划 2019-03-04