首页 星云 工具 资源 星选 资讯 热门工具
:

PDF转图片 完全免费 小红书视频下载 无水印 抖音视频下载 无水印 数字星空

c语言实现非常漂亮祝福烟花效果

后端 5.66MB 28 需要积分: 1
立即下载

资源介绍:

c语言实现非常漂亮祝福烟花效果
/******************************************************** * * * 程序名称:祝福烟花,祝福朋友 * * 编译环境:VC++6.0 && easyx(立冬版) * * 作者相关:yy滺滺__<837943056@qq.com> * * 最后修改:2012.11.22 * * * ********************************************************/ /* 【自学去】网站收集 http://www.zixue7.com */ #include #include #include #include #include #include #include // 使用该计时器必须包含的文件 #pragma comment ( lib, "Winmm.lib" ) /***** 宏定义区 ******/ #define NUM 13 // 烟花种类数量宏定义 /***** 结构定义区 **********/ // 烟花结构 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]; // happy birthday 艺术字结构 struct HAPPY // 储存 Happy Birthday 艺术字图片 { int x, y; // 每个字的图片的左上角坐标 IMAGE img; // 储存单个字图片 static int num; // 字母序号 }Happy[NUM]; int HAPPY::num = 0; // For.2012の夭女 结构 struct WISH // 滚动祝福图片结构 { int x, y; // 图片左上角坐标 DWORD t1, t2, dt; // 图片运动时间间隔 IMAGE img; // 储存图片 int dxy; // 每次的移动量 byte dir : 1; // 限制两个滚动方向 }Wish; /**** 函数申明区 ****/ void Init ( int ); // 初始化烟花 void Load ( ); // 加载烟花图片 void Shoot ( ); // 发射烟花 void Chose ( DWORD& ); // 筛选烟花 void Wishing( ); // 滚动祝福 void Style ( DWORD& ); // 发射样式 void Show ( DWORD* ); // 绽放烟花 // 主函数 void main() { initgraph( 1200, 800 ); srand( time(0) ); // 播放背景音乐 mciSendString( "open ./fire/bk.mp3 alias bk", 0, 0, 0 ); mciSendString( "play bk repeat", 0, 0, 0 ); setfillstyle( 0 ); setfont ( 36, 0, "楷体" ); setcolor ( YELLOW ); outtextxy ( 370, 100, "yy滺滺__出厂 .... ^_^" ); 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 ); // 绽放烟花 Wishing ( ); // 滚动字符 Style ( st1 ); // 花样发射 FlushBatchDraw( ); // 显示前面的所有绘图操作 } } // 初始化烟花参数 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 ( 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 ); // 亮 } /***** 加载 Happy Birthday 图片 ********/ IMAGE hm; loadimage( &hm, "./fire/happy.jpg", 689, 115 ); SetWorkingImage( &hm ); for ( i = 0; i < 13; i++ ) { Happy[i].x = i * 90; Happy[i].y = rand() % 100 + 500; getimage( &Happy[i].img, i * 53, 0, 53, 115 ); } /***** 加载 For.2012の夭女 图片 *********/ Wish.x = 0; Wish.y = 100; Wish.t1 = timeGetTime(); Wish.dt = 46; Wish.dir = 0; Wish.dxy = rand() % 8 + 1; loadimage( &Wish.img, "./fire/yaojing.jpg", 490, 100 ); putimage( Wish.x, Wish.y, &Wish.img, SRCINVERT ); 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; // 停止发射 // 显示对应字母 putimage( Happy[HAPPY::num].x, Happy[HAPPY::num].y, &Happy[HAPPY::num].img,

资源文件列表:

c语言实现非常漂亮祝福烟花效果.zip 大约有25个文件
  1. c语言实现非常漂亮祝福烟花效果/
  2. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/
  3. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/
  4. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/
  5. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/bk.mp3 4.14MB
  6. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/bomb.wav 80.48KB
  7. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/flower.jpg 2.14MB
  8. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/happy.jpg 36.23KB
  9. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/shoot.jpg 17.35KB
  10. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/shoot.mp3 87.39KB
  11. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/fire/yaojing.jpg 27.58KB
  12. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/ico.aps 34.21KB
  13. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/ico.rc 1.68KB
  14. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/ico.rct 488B
  15. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/ico.res 3.68KB
  16. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.cpp 11.33KB
  17. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.dsp 3.41KB
  18. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.dsw 533B
  19. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.exe 296.04KB
  20. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.ncb 49KB
  21. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.opt 47.5KB
  22. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/main.plg 242B
  23. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/MSN.ICO 3.55KB
  24. c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/c语言实现非常漂亮祝福烟花效果/resource.h 452B
  25. c语言实现非常漂亮祝福烟花效果/新建文件夹/
0评论
提交 加载更多评论
其他资源 无标题界面跳转以及倒计时
啦啦啦啦啦啦啦
词法分析器,语义分析器
词法分析器,语义分析器
开源吃瓜密码查看系统源码
吃瓜群系统源码是一款基于付费进群功能的软件,主要应用于社群管理,尤其是对于需要进行付费会员服务的社交群体。这款系统的核心在于提供了一种安全便捷的方式,让用户通过支付一定的费用来加入特定的讨论群组。源码的分享使得开发者或者社群管理员能够自定义和部署这样的功能,以满足他们的特定需求
开源吃瓜密码查看系统源码
个人发卡程序手机版自适应源码 完美版对接免签约支付.zip
个人发卡程序手机版自适应源码 完美版对接免签约。正式运营版本首发,基本都测试了有的没截图就这样吧,免费分享了这套免签约自适应的自动发卡,卡密个人发卡,发卡程序源码,带手机版,支付对接好了只需要自己去填账号密码就行了。
mybatisplus&CodeGenerator源码.zip
mybatisplus&CodeGenerator源码
ConvNet ConvNeXt V1 - V2代码
A ConvNet for the 2020s 和 ConvNeXt V2: Co-designing and Scaling ConvNets with Masked Autoencoders的网络模型ConvNeXt V1 - V2代码
MATLAB车牌识别程序.zip
车牌检测是指通过图像处理技术,从图像中自动检测出车辆的车牌区域。在MATLAB中,可以使用以下步骤进行车牌检测: 1. 读取图像:使用imread函数读取待检测的车辆图像。 2. 图像预处理:对读取的图像进行预处理,如去噪、灰度化、图像增强等。 3. 车牌区域检测:使用图像处理技术,如边缘检测、形态学操作等,通过检测车牌的特征,找出可能的车牌区域。 4. 车牌区域精确定位:对可能的车牌区域进行精确定位,可以使用形状匹配、基于颜色的分割等方法。 5. 车牌字符分割:将车牌区域中的字符进行分割,可以使用图像处理技术,如投影法、连通区域分析等。 6. 字符识别:对分割出的字符进行识别,可以使用模式识别、机器学习技术等。 在MATLAB中,可以使用图像处理工具箱和机器学习工具箱来实现车牌检测。可以使用函数如imread、imfilter、imbinarize等进行图像处理;可以使用函数如edge、imdilate、imfill等进行车牌区域检测;可以使用函数如regionprops、bwconncomp等进行车牌区域精确定位和字符分割;可以使用机器学习工具箱中的分类器进行字符识别
RF-Power-ADS-DesignKit-ADS2024-3p0
这个基准比较了RF中的FET2模型实现Power Design Kit 3.0版本,与之前的版本进行历史比较。该试剂盒被重新编译为ADS2024。所有结果均显示为MS Windows 10 64bit和Red Hat 7 Linux。所有ADS版本都使用相同的测试DC-IV、单音谐波平衡、大信号s参数、小信号s参数和瞬态仿真。所有这些FET2模型都是相同的,除了输入的方法不同模型参数。FET2模型具有硬编码的模型参数进入仿真网表。编码的FET2模型读取加密的从文件中建模参数。文件名被硬编码到模拟中网表。新的FET2模型为波形工程提供支持进入内部漏极到源和电容电流。的波形 工程FET2模型与FET2模型的不同之处在于模型名称和终端的数量。该波形工程FET2模型使其首次出现在ADS2016.01。此外,两款新车型首次亮相:fe2e WFE和fe2ee WFE。这些新型号增加了热增强功能。
RF-Power-ADS-DesignKit-ADS2024-3p0 RF-Power-ADS-DesignKit-ADS2024-3p0 RF-Power-ADS-DesignKit-ADS2024-3p0