专栏首页信息传播C语言和图形界面编程打造——浪漫的表白程序
原创

C语言和图形界面编程打造——浪漫的表白程序

#include

#include

#include

#include

#include

#include

#pragma comment ( lib, "Winmm.lib" )

/***** 宏定义区 ******/

#define NUM13// 烟花种类数量宏定义

/***** 结构定义区 **********/

// 烟花结构

struct FIRE

{

int r;// 当前爆炸半径

int max_r;// 爆炸中心距离边缘最大半径

int x, y;// 爆炸中心在窗口的坐标

int cen_x, cen_y;// 爆炸中心相对图片左上角的坐标

int width, height;// 图片的宽高

int xy[240][240];// 储存图片像素点

bool show;// 是否绽放

bool draw;// 开始输出像素点

DWORD t1, t2, dt;// 绽放速度

}Fire[NUM];

// 烟花弹结构

struct JET

{

int x, y;// 喷射点坐标

int hx, hy;// 最高点坐标------将赋值给 FIRE 里面的 x, y

int height;// 烟花高度

bool shoot;// 是否可以发射

DWORD t1, t2, dt;// 发射速度

IMAGE img[2];// 储存花弹一亮一暗图片

byte n : 1;// 图片下标

}Jet[NUM];

/**** 函数申明区 ****/

void welcome();

void Init(int);// 初始化烟花

void Load();// 加载烟花图片

void Shoot();// 发射烟花

void Chose(DWORD&);// 筛选烟花

void Style(DWORD&);// 发射样式

void Show(DWORD*);// 绽放烟花

// 主函数

void main()

{

initgraph(1200, 800);

srand(time(0));

// 播放背景音乐

mciSendString("open ./fire/小幸运.mp3 alias bk", 0, 0, 0);

mciSendString("play bk repeat", 0, 0, 0);

welcome();

DWORD t1 = timeGetTime();// 筛选烟花计时

DWORD st1 = timeGetTime();// 播放花样计时

DWORD* pMem = GetImageBuffer();// 获取窗口显存指针

for (int i = 0; i

{

Init(i);

}

Load();// 将烟花图片信息加载进相应结构中

BeginBatchDraw();// 开始批量绘图

while (!kbhit())

{

Sleep(10);

// 随机选择 4000 个像素点擦除

for (int clr = 0; clr

{

for (int j = 0; j

{

int px1 = rand() % 1200;

int py1 = rand() % 800;

if (py1

pMem[py1 * 1200 + px1] = pMem[py1 * 1200 + px1 + 1] = BLACK;// 对显存赋值擦出像素点

}

}

Chose(t1);// 筛选烟花

Shoot();// 发射烟花

Show(pMem);// 绽放烟花

Style(st1);// 花样发射

FlushBatchDraw();// 显示前面的所有绘图操作

}

}

void welcome()

{

//setfillstyle(0);

setcolor(YELLOW);

for (int i = 0; i

{

int x = 600 + int(180 * sin(PI * 2 * i / 60));

int y = 200 + int(180 * cos(PI * 2 * i / 60));

cleardevice();

settextstyle(i, 0, "楷体");

outtextxy(x, y, "双十一,不剁手!");

outtextxy(x-130, y+100, "写段代码送女友!");

Sleep(25);

}

getchar();

cleardevice();

settextstyle(25, 0, "楷体");

outtextxy(400, 200, "原来你是我最想留住的幸运");

outtextxy(400, 250, "原来我们和爱情曾经靠得那么近");

outtextxy(400, 300, "那为我对抗世界的决定");

outtextxy(400, 350, "那陪我淋的雨");

outtextxy(400, 400, "一幕幕都是你");

outtextxy(400, 450, "一尘不染的真心。");

outtextxy(600, 500, "----《小幸运》");

getchar();

}

原创声明,本文系作者授权云+社区发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • java语言下的应用

    卜卜-Totoro
  • Git使用心得及总结(包含Git Bash 和 Git GUI)简单易懂

    其实为什么要写这个心得,主要是因为每次自己使用git的时候遇到一些比较棘手的问题时,总是不好找到解决方法,在使用并且学习的时候我也买过书,也在网上Google了...

    卜卜-Totoro
  • 欢迎使用Markdown编辑器

    你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的...

    卜卜-Totoro
  • 洛谷P2831 愤怒的小鸟(状压dp)

    直接状压dp一下,\(f[sta]\)表示干掉\(sta\)这个集合里面的鸟的最小操作数

    attack
  • BZOJ2754: [SCOI2012]喵星球上的点名(AC自动机)

    attack
  • POJ 刷题系列:1753. Flip Game

    POJ 刷题系列:1753. Flip Game 传送门:POJ 1753. Filp Game 题意: 一个4*4的矩阵,每一格要么是白色,要么是黑色。现在...

    用户1147447
  • 程序员进阶之算法练习(三十五)LeetCode专场

    LeetCode上的题目是大公司面试常见的算法题,今天的目标是拿下5道算法题: 题目1是基于链表的大数加法,既考察基本数据结构的了解,又考察在处理加法过程中的...

    落影
  • 挑战程序竞赛系列(8):2.1一往直前!贪心法(其他)

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.n...

    用户1147447
  • BZOJ3498: PA2009 Cakes(三元环)

    如果\(v\)的度数\(\leqslant M\),那么就再暴力枚举\(v\)连出去的点\(t\),看\(u\)与\(t\)是否联通(打标记)

    attack
  • 算法导论中的四种基本排序

                                                            by方阳

    努力努力再努力F

扫码关注云+社区

领取腾讯云代金券