C语言实现代码雨效果

 更新时间:2022年05月13日 08:54:26   作者:辉小歌  
这篇文章主要为大家详细介绍了C语言实现代码雨效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了C语言实现代码雨效果的具体代码,供大家参考,具体内容如下

一、项目描述和最终的效果展示

项目:   让字符从上到下依次的下落,呈现出代码雨。

最终效果图如下所示:

二、静态的代码雨

代码如下:

#include<graphics.h>
#include<time.h>
#include<conio.h>

#define High 800//游戏画面
#define Width 1000
#define CharSize 25//每个字符显示的大小

int main(void)
{
    int highNum=High/CharSize;
    int widthNum=Width/CharSize;

    //CharRain存储对应字符矩阵中需要输出字符的ASCII码
    int CharRain[Width/CharSize][High/CharSize];
    int CNum[Width/CharSize];//每一列的有效字符个数
    int i,j,x,y;
    srand((unsigned)time(NULL));//设置随机函数种子

    for(i=0;i<widthNum;i++)//初始化字符矩阵
    {
        CNum[i]=(rand()%(highNum*9/10))+highNum/10;//这一列的有效字符个数
        for(j=0;j<CNum[i];j++)
            CharRain[j][i]=(rand()%26)+65;//产生A~Z的随机字符
    }

    initgraph(Width,High);
    BeginBatchDraw();
    setfont(25,10,"Courier");//设置字体
    setcolor(GREEN);

    for(i=0;i<widthNum;i++)//输出整个字符矩阵
    {
        x=i*CharSize;//当前字符的x坐标
        for(j=0;j<CNum[i];j++)
        {
            y=j*CharSize;//当前字符的y坐标
            outtextxy(x,y,CharRain[j][i]);//输出当前字符
        }
    }
    FlushBatchDraw();
    EndBatchDraw();
    getch();
    closegraph();
    return 0;
}

效果图如下:

三、一场动态的代码雨

代码如下:

#include<graphics.h>
#include<time.h>
#include<conio.h>

#define High 800//游戏画面
#define Width 1000
#define CharSize 25//每个字符显示的大小

int main(void)
{
    int highNum=High/CharSize;
    int widthNum=Width/CharSize;

    //CharRain存储对应字符矩阵中需要输出字符的ASCII码
    int CharRain[Width/CharSize][High/CharSize];
    int CNum[Width/CharSize];//每一列的有效字符个数
    int i,j,x,y;
    srand((unsigned)time(NULL));//设置随机函数种子

    for(i=0;i<widthNum;i++)//初始化字符矩阵
    {
        CNum[i]=(rand()%(highNum*9/10))+highNum/10;//这一列的有效字符个数
        for(j=0;j<CNum[i];j++)
            CharRain[j][i]=(rand()%26)+65;//产生A~Z的随机字符
    }

    initgraph(Width,High);
    BeginBatchDraw();
    setfont(25,10,"Courier");//设置字体
    setcolor(RGB(0,255,0));

    while(1)
    {
        for(i=0;i<widthNum;i++)
        {
            if(CNum[i]<highNum-1)//当这一列字符没有填满时
            {
                for(j=CNum[i]-1;j>=0;j--)//每个字符向下移动一格
                {
                    CharRain[j+1][i]=CharRain[j][i];
                }
                CharRain[0][i]=(rand()%26)+65;//最上一格再重新随机的产生一个字符
                CNum[i]=CNum[i]+1;//这一列的字符数加1
            }
        }
        for(i=0;i<widthNum;i++)//输出整个字符矩阵
        {
            x=i*CharSize;//当前字符的x坐标
            for(j=0;j<CNum[i];j++)
            {
                y=j*CharSize;//当前字符的y坐标
                outtextxy(x,y,CharRain[j][i]);//输出当前字符
            }
        }
        FlushBatchDraw();
        Sleep(200);
        clearrectangle(0,0,Width-1,High-1);//清空画面
    }
    
    EndBatchDraw();
    getch();
    closegraph();
    return 0;
}

效果图如下:

四、实现代码雨动画

代码如下:

#include<graphics.h>
#include<time.h>
#include<conio.h>

#define High 800//游戏画面
#define Width 1000
#define CharSize 25//每个字符显示的大小

int main(void)
{
    int highNum=High/CharSize;
    int widthNum=Width/CharSize;

    //CharRain存储对应字符矩阵中需要输出字符的ASCII码
    int CharRain[Width/CharSize][High/CharSize];
    int CNum[Width/CharSize];//每一列的有效字符个数
    int ColorG[Width/CharSize];//每一列字符的颜色
    int i,j,x,y;
    srand((unsigned)time(NULL));//设置随机函数种子

    for(i=0;i<widthNum;i++)//初始化字符矩阵
    {
        CNum[i]=(rand()%(highNum*9/10))+highNum/10;//这一列的有效字符个数
        ColorG[i]=255;
        for(j=0;j<CNum[i];j++)
            CharRain[j][i]=(rand()%26)+65;//产生A~Z的随机字符
    }

    initgraph(Width,High);
    BeginBatchDraw();
    setfont(25,10,"Courier");//设置字体

    while(1)
    {
        for(i=0;i<widthNum;i++)
        {
            if(CNum[i]<highNum-1)//当这一列字符没有填满时
            {
                for(j=CNum[i]-1;j>=0;j--)//每个字符向下移动一格
                {
                    CharRain[j+1][i]=CharRain[j][i];
                }
                CharRain[0][i]=(rand()%26)+65;//最上一格再重新随机的产生一个字符
                CNum[i]=CNum[i]+1;//这一列的字符数加1
            }
            else
            {
                if(ColorG[i]>40)
                    ColorG[i]=ColorG[i]-20;//让满的这一列逐渐变暗
                else
                {
                    CNum[i]=(rand()%(highNum/3))+highNum/10;//这一列字符的个数
                    ColorG[i]=(rand()%75)+180;//这一列字符的颜色
                    for(j=0;j<CNum[i];j++)//重新初始化这一列字符
                    {
                        CharRain[j][i]=(rand()%26)+65;
                    }
                }
            }
        }
        for(i=0;i<widthNum;i++)//输出整个字符矩阵
        {
            x=i*CharSize;//当前字符的x坐标
            for(j=0;j<CNum[i];j++)
            {
                y=j*CharSize;//当前字符的y坐标
                setcolor(RGB(0,ColorG[i],0));
                outtextxy(x,y,CharRain[j][i]);//输出当前字符
            }
        }
        FlushBatchDraw();
        Sleep(100);
        clearrectangle(0,0,Width-1,High-1);//清空画面
    }
    
    EndBatchDraw();
    getch();
    closegraph();
    return 0;
}

效果图如下:

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

相关文章

  • matlab GUI指纹识别门禁系统介绍及源码实现

    matlab GUI指纹识别门禁系统介绍及源码实现

    这篇文章主要为大家介绍了matlab GUI指纹识别门禁系统的介绍及源码实现,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步
    2022-02-02
  • C++实现在文本中找出某个单词的位置信息

    C++实现在文本中找出某个单词的位置信息

    本文给大家分享的是使用C++实现在文本中找出某个单词的位置信息,就是给出此单词所在的行和列,有需要的小伙伴可以参考下。
    2016-02-02
  • Qt如何设置窗口屏幕居中显示以及设置大小

    Qt如何设置窗口屏幕居中显示以及设置大小

    这篇文章主要介绍了Qt如何设置窗口屏幕居中显示以及设置大小的相关资料,需要的朋友可以参考下
    2017-01-01
  • C++ 面向对象程序设计--内存分区详解

    C++ 面向对象程序设计--内存分区详解

    这篇文章主要介绍了剖析C++的面向对象编程思想,C++的面向对象特性是其对C语言的重要拓展之处,需要的朋友可以参考下,希望能够给你带来帮助
    2021-08-08
  • C语言数组按协议存储与按协议解析数据的实现

    C语言数组按协议存储与按协议解析数据的实现

    今天小编就为大家分享一篇关于C语言数组按协议存储与按协议解析数据的实现,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧
    2018-12-12
  • C++实现LeetCode(126.词语阶梯之二)

    C++实现LeetCode(126.词语阶梯之二)

    这篇文章主要介绍了C++实现LeetCode(126.词语阶梯之二),本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下
    2021-07-07
  • C++中push_back()函数的具体使用

    C++中push_back()函数的具体使用

    本文主要介绍了C++中push_back()函数的具体使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2025-01-01
  • C语言行优先和列优先的问题深入分析

    C语言行优先和列优先的问题深入分析

    这篇文章主要介绍了C语言行优先和列优先的问题深入分析的相关资料,需要的朋友可以参考下
    2017-01-01
  • win32 api实现2048游戏示例

    win32 api实现2048游戏示例

    这篇文章主要介绍了win32 api实现2048游戏示例,需要的朋友可以参考下
    2014-05-05
  • C++红黑树的底层实现机制详解

    C++红黑树的底层实现机制详解

    红黑树与AVL树一样,也是一种自平衡的二叉搜索树,它在每个结点上增加一个存储位表示结点的颜色,可以是Red或Black,通过对任何一条从根到叶子的路径上各个结点着色方式的限制,本文介绍了C++红黑树的底层实现机制,需要的朋友可以参考下
    2024-08-08

最新评论