只要代码写得好,程序员每天都是情人节,这里放一个浪漫炫酷烟花表白代码,先看看最终效果图:

按下回车会出现一段用来表白的话,可根据自己需求修改

等待音乐放到特定地方会绽放烟花,时不时会出现爱心形状

接下来直接放源码

/********************************************************
*                                                       *
*   程序名称:    表白烟花                                    *
*   编译环境:    VS2019 && easyx(浪漫限定版)              *
*                                                       *
*********************************************************/
#include <graphics.h>
#include <conio.h>
#include <math.h>
#include <time.h>
#include <stdio.h>
#include <Mmsystem.h>
#pragma comment ( lib, "Winmm.lib" )/***** 宏定义区 ******/#define NUM        13          // 烟花种类数量宏定义
#define PI      3.1415926548/***** 结构定义区 **********/// 烟花结构
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, yint 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 < NUM; i++)      // 初始化烟花{Init(i);}Load();                               // 将烟花图片信息加载进相应结构中BeginBatchDraw();                 // 开始批量绘图while (!kbhit()){Sleep(10);// 随机选择 4000 个像素点擦除for (int clr = 0; clr < 1000; clr++){for (int j = 0; j < 2; j++){int px1 = rand() % 1200;int py1 = rand() % 800;if (py1 < 799)              // 防止越界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 < 50; 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-80, y, "浪漫表白日");outtextxy(x-10, 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();
}// 初始化烟花参数
void Init(int i)
{// 分别为:烟花中心到图片边缘的最远距离、烟花中心到图片左上角的距离 (x、y) 两个分量int r[13] = { 120, 120, 155, 123, 130, 147, 138, 138, 130, 135, 140, 132, 155 };int x[13] = { 120, 120, 110, 117, 110, 93, 102, 102, 110, 105, 100, 108, 110 };int y[13] = { 120, 120, 85, 118, 120, 103, 105, 110, 110, 120, 120, 104, 85 };/**** 初始化烟花 *****/Fire[i].x = 0;             // 烟花中心坐标Fire[i].y = 0;Fire[i].width = 240;               // 图片宽Fire[i].height = 240;                // 图片高Fire[i].max_r = r[i];                // 最大半径Fire[i].cen_x = x[i];               // 中心距左上角距离Fire[i].cen_y = y[i];Fire[i].show = false;         // 是否绽放Fire[i].dt = 5;             // 绽放时间间隔Fire[i].t1 = timeGetTime();Fire[i].r = 0;                // 从 0 开始绽放/**** 初始化烟花弹 *****/Jet[i].x = -240;             // 烟花弹左上角坐标Jet[i].y = -240;Jet[i].hx = -240;              // 烟花弹发射最高点坐标Jet[i].hy = -240;Jet[i].height = 0;              // 发射高度Jet[i].t1 = timeGetTime();Jet[i].dt = rand() % 10;     // 发射速度时间间隔Jet[i].n = 0;               // 烟花弹闪烁图片下标Jet[i].shoot = false;          // 是否发射
}// 加载图片
void Load()
{/**** 储存烟花的像素点颜色 ****/IMAGE fm, gm;loadimage(&fm, "./fire/flower.jpg", 3120, 240);for (int i = 0; i < 13; i++){SetWorkingImage(&fm);getimage(&gm, i * 240, 0, 240, 240);SetWorkingImage(&gm);for (int a = 0; a < 240; a++)for (int b = 0; b < 240; b++)Fire[i].xy[a][b] = getpixel(a, b);}/**** 加载烟花弹 ************/IMAGE sm;loadimage(&sm, "./fire/shoot.jpg", 200, 50);for (int i = 0; i < 13; i++){SetWorkingImage(&sm);int n = rand() % 5;getimage(&Jet[i].img[0], n * 20, 0, 20, 50);            // 暗getimage(&Jet[i].img[1], (n + 5) * 20, 0, 20, 50);     // 亮}SetWorkingImage();     // 设置回绘图窗口
}// 在一定范围内筛选可发射的烟花,并初始化发射参数,输出烟花弹到屏幕,播放声音
void Chose(DWORD& t1)
{DWORD t2 = timeGetTime();if (t2 - t1 > 100){int n = rand() % 20;if (n < 13 && Jet[n].shoot == false && Fire[n].show == false){/**** 重置烟花弹,预备发射 *****/Jet[n].x = rand() % 1200;Jet[n].y = rand() % 100 + 600;Jet[n].hx = Jet[n].x;Jet[n].hy = rand() % 400;Jet[n].height = Jet[n].y - Jet[n].hy;Jet[n].shoot = true;putimage(Jet[n].x, Jet[n].y, &Jet[n].img[Jet[n].n], SRCINVERT);/**** 播放每个烟花弹的声音 *****//*char c1[50], c2[30], c3[30];sprintf(c1, "open ./fire/shoot.mp3 alias s%d", n);sprintf(c2, "play s%d", n);sprintf(c3, "close n%d", n);mciSendString(c3, 0, 0, 0);mciSendString(c1, 0, 0, 0);mciSendString(c2, 0, 0, 0);*/}t1 = t2;}
}// 扫描烟花弹并发射
void Shoot()
{for (int i = 0; i < 13; i++){Jet[i].t2 = timeGetTime();if (Jet[i].t2 - Jet[i].t1 > Jet[i].dt && Jet[i].shoot == true){/**** 烟花弹的上升 *****/putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT);if (Jet[i].y > Jet[i].hy){Jet[i].n++;Jet[i].y -= 5;}putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT);/**** 上升到高度的 3 / 4,减速 *****/if ((Jet[i].y - Jet[i].hy) * 4 < Jet[i].height)Jet[i].dt = rand() % 4 + 10;/**** 上升到最大高度 *****/if (Jet[i].y <= Jet[i].hy){// 播放爆炸声/*char c1[50], c2[30], c3[30];sprintf(c1, "open ./fire/bomb.wav alias n%d", i);sprintf(c2, "play n%d", i);sprintf(c3, "close s%d", i);mciSendString(c3, 0, 0, 0);mciSendString(c1, 0, 0, 0);mciSendString(c2, 0, 0, 0);*/putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT);  // 擦掉烟花弹Fire[i].x = Jet[i].hx + 10;                                           // 在烟花弹中间爆炸Fire[i].y = Jet[i].hy;                                              // 在最高点绽放Fire[i].show = true;                  // 开始绽放Jet[i].shoot = false;                   // 停止发射}Jet[i].t1 = Jet[i].t2;}}
}// 显示花样
void Style(DWORD& st1)
{DWORD st2 = timeGetTime();if (st2 - st1 >20000)        // 一首歌的时间{// 心形坐标int x[13] = { 60, 75, 91, 100, 95, 75, 60, 45, 25, 15, 25, 41, 60 };int y[13] = { 65, 53, 40, 22, 5, 4, 20, 4, 5, 22, 40, 53, 65 };for (int i = 0; i < NUM; i++){//cleardevice();/**** 规律分布烟花弹 ***/Jet[i].x = x[i] * 10;Jet[i].y = (y[i] + 75) * 10;Jet[i].hx = Jet[i].x;Jet[i].hy = y[i] * 10;Jet[i].height = Jet[i].y - Jet[i].hy;Jet[i].shoot = true;Jet[i].dt = 7;putimage(Jet[i].x, Jet[i].y, &Jet[i].img[Jet[i].n], SRCINVERT);  // 显示烟花弹/**** 设置烟花参数 ***/Fire[i].x = Jet[i].x + 10;Fire[i].y = Jet[i].hy;Fire[i].show = false;Fire[i].r = 0;/**** 播放发射声音 ***//*char c1[50], c2[30], c3[30];sprintf(c1, "open ./fire/shoot.mp3 alias s%d", i);sprintf(c2, "play s%d", i);sprintf(c3, "close n%d", i);mciSendString(c3, 0, 0, 0);mciSendString(c1, 0, 0, 0);mciSendString(c2, 0, 0, 0);*/}st1 = st2;}
}// 绽放烟花
void Show(DWORD* pMem)
{// 烟花个阶段绽放时间间隔,制作变速绽放效果int drt[16] = { 5, 5, 5, 5, 5, 6, 25, 25, 25, 25, 55, 55, 55, 55, 55 };for (int i = 0; i < NUM; i++){Fire[i].t2 = timeGetTime();// 增加爆炸半径,绽放烟花,增加时间间隔做变速效果if (Fire[i].t2 - Fire[i].t1 > Fire[i].dt && Fire[i].show == true){if (Fire[i].r < Fire[i].max_r){Fire[i].r++;Fire[i].dt = drt[Fire[i].r / 10];Fire[i].draw = true;}if (Fire[i].r >= Fire[i].max_r - 1){Fire[i].draw = false;Init(i);}Fire[i].t1 = Fire[i].t2;}// 如果该号炮花可爆炸,根据当前爆炸半径画烟花,颜色值接近黑色的不输出。if (Fire[i].draw){for (double a = 0; a <= 6.28; a += 0.01){int x1 = (int)(Fire[i].cen_x + Fire[i].r * cos(a));               // 相对于图片左上角的坐标int y1 = (int)(Fire[i].cen_y - Fire[i].r * sin(a));if (x1 > 0 && x1 < Fire[i].width && y1 > 0 && y1 < Fire[i].height)    // 只输出图片内的像素点{int b = Fire[i].xy[x1][y1] & 0xff;int g = (Fire[i].xy[x1][y1] >> 8) & 0xff;int r = (Fire[i].xy[x1][y1] >> 16);// 烟花像素点在窗口上的坐标int xx = (int)(Fire[i].x + Fire[i].r * cos(a));int yy = (int)(Fire[i].y - Fire[i].r * sin(a));// 较暗的像素点不输出、防止越界if (r > 0x20 && g > 0x20 && b > 0x20 && xx > 0 && xx < 1200 && yy > 0 && yy < 800)pMem[yy * 1200 + xx] = BGR(Fire[i].xy[x1][y1]);    // 显存操作绘制烟花}}Fire[i].draw = false;}}
}

需要下面资源包和完整源码的欢迎加群【806041599】找管理员领取哦!群里有一些资料可以帮助大家更好的学习,在学习C语言的过程中遇到任何的问题,都可以发出来一起讨论,大家都是学习C/C++的,或是转行,或是大学生,还有工作中想提升自己能力的前端党,如果你是正在学习C/C++的小伙伴可以加入学习。

C语言情人节浪漫烟花表白代码相关推荐

  1. ❀520七夕情人节告白网页代码❀—浪漫梦幻3D相册(樱花主题)HTML+CSS+JavaScript

    ❀ 520七夕情人节告白网页代码❀-浪漫梦幻3D相册(樱花主题)HTML+CSS+JavaScript 520七夕节告白,也就是中国的情人节,你除了送花你还会什么?? 快来制作高端大气上档次的D立体动 ...

  2. HTML5七夕情人节表白网页 一场浪漫烟花表白 HTML+CSS+JavaScript

    HTML5七夕情人节表白网页 一场浪漫烟花表白 HTML+CSS+JavaScript 这是程序员表白系列中的100款网站表白之一,旨在让任何人都能使用并创建自己的表白网站给心爱的人看. 此波共有10 ...

  3. c++代码表白_推荐!在浪漫的日子里程序猿如何用C语言实现520表白代码

    跨年,新年是浪漫的好日子这篇文章主要为大家详细介绍了C语言实现520表白代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下.告白的代码如下,献丑献丑: #include #include int ...

  4. 520七夕情人节告白网页代码—浪漫3D相册

    520七夕情人节告白网页代码-浪漫梦幻3D相册html+css 520七夕节告白,也就是中国的情人节,你除了送花你还会什么?? 快来制作高端大气上档次的D立体动态相册表白网页吧! 七夕节是一个十分浪漫 ...

  5. HTML5七夕情人节表白网页 ❤ 一场浪漫烟花表白 ❤ HTML+CSS+JavaScript

    HTML5七夕情人节表白网页 ❤ 一场浪漫烟花表白 ❤ HTML+CSS+JavaScript 这是程序员表白系列中的100款网站表白之一,旨在让任何人都能使用并创建自己的表白网站给心爱的人看. 此波 ...

  6. 快乐玩前端:情人节请用代码表达你的爱意,女友收到都哭了

    情人节请用代码表达你的爱意,女友收到都哭了 以程序员的方式撒狗粮,专业浪漫,值得拥有! 效果演示 代码 //css代码 *{padding:0;margin:0; } .all{width:1400p ...

  7. 语言小型心形图案代码_c语言心形告白代码实现

    c语言心形告白代码实现 1.彩色告白 include include include include define U 0.1 define V 0.053 void SetColor(unsigne ...

  8. python浪漫表白代码

    python浪漫表白代码 示例代码: import turtle import random# 在(x, y)处画爱心lalala def love(x, y):lv = turtle.Turtle( ...

  9. 真分数c语言,C语言列出真分数序列代码及解析

    原标题:C语言列出真分数序列代码及解析 按递增顺序依次列出所有分母为60,分子小于60的最简分数. 分子.分母只有公因数1的分数叫做最简分数或者说分子和分母是互质数的分数,叫做最简分数,又称既约分数, ...

  10. c语言万年历查询程序代码,C语言 万年历程序(示例代码)

    C语言 万年历程序 原代码:[email protected]:~/c++$ cat 123.c #include #define Mon   1 #define Tues  2 #define We ...

最新文章

  1. Aspx页面生命周期(转)
  2. 2020黑群晖最稳定版本_80%用户的选择!win10最稳定好用的版本更新,你敢升级吗?...
  3. linux下ftp服务器搭建详解
  4. 【转自CDDN】随笔:sysobjects.Xtype
  5. attr与prop的区别
  6. Nginx For Windows 路由配置
  7. android学习笔记---61_Widgets,窗口小部件的制作...
  8. 拓端tecdat|Excel实例:排序和筛选2
  9. excel制作甘特图模板
  10. #Linux中的GCC编程# 20170731 C培训作业
  11. SEO引擎首页优化 - 2016百度搜索引擎算法
  12. R语言使用lm函数构建简单线性回归模型(建立线性回归模型)、拟合回归直线、可视化散点图并添加简单线性回归直线、添加模型拟合值数据点、添加拟合值点和实际数据点之间的线段表示残差大小、col参数自定义设置
  13. 淘宝/天猫获取sku详细信息 API 返回值说明
  14. 游戏中基于物理的渲染
  15. SpringSecurity OAuth2.0认证授权-part1
  16. 【论文阅读】Sentiment Classification情感分类
  17. 单容水箱液位pid控制实验报告_实验二、单容水箱液位PID控制系统
  18. Ubuntu下android-4.0.3_r1源码下载,阅读工具安装配置,源码编译详解
  19. U盘病毒GHO.exe
  20. 11g用户密码过期处理办法

热门文章

  1. 校园网里,一账号多人上网或者多账号多人上网的宿舍路由器设置方法
  2. windows环境如何测试端口
  3. 基于java的在校大学生贷款管理系统
  4. Spring 常用注解
  5. STM32 - Cube介绍
  6. java 偏向锁_Java 偏向锁
  7. 对计算机网络考研知识点归纳(不断更新中T)
  8. 三星固态硬盘装linux,三星T5 SSD制作ubuntu18.04随身携带即插即用与win10共享文件真爽~(简单粗暴安装大法一步到位)...
  9. MySQL+Navicat安装配置
  10. 工业级Pass云平台SpringCloudAlibaba综合项目实战(一):序言