c语言烟花百度云,C语言实现放烟花的程序

这是一个利用C语言编写放烟花的程序(同时也可以播放音乐),供大家参考,具体内容如下

代码如下

#pragma once

#include

#include //图形界面库头文件

#include //计算圆形的轨迹坐标

#include

#include

#include

#include

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

//#include 包含头文件

//#pragma comment(lib."文件名称") 包含库文件

constexpr auto WND_WIDTH = 1000;

constexpr auto WND_HEIGHT = 600;

constexpr auto PI = 3.141592653589793238;

constexpr auto NUM = 14;

/***********结构****************/

struct JET //烟花弹

{

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

int hx, hy; //最高点坐标 爆炸坐标

int height; //高度 最高点y 发射点y的差值

bool isshoot; //是否发射状态

DWORD t1, t2, dt; //保存时间 时间可以用来描述发射速度

IMAGE img[2]; //保存烟花一明一暗的图片

byte n : 1; //保存烟花弹的明暗状态 位段

//字节为单位 int 4 char 1 n一个位 0-1

}jet[NUM]; //结构体数组13 img这个数组

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];

void welcome();

void init(int i);

void loadimages();

void choice(DWORD& t1);

void shoot();

void Show(DWORD* pMem);

void clss(int a);

void delay(int a);

void detabase(int a);

int main()

{

//res 1.wav

PlaySound(L"sound.dll", NULL, SND_LOOP | SND_FILENAME | SND_ASYNC);

//mp3播放

//mciSendString(L"open 1.mp3 alias bkmusic", NULL, 0, NULL);

//mciSendString(L"play bkmusic repeat", NULL, 0, NULL);

int a;

for (a = 0; a < 5; a++)

{

detabase(a);

delay(100000);

clss(1);

}

delay(500000);

initgraph(WND_WIDTH, WND_HEIGHT); //init初始化 graph图形界面 窗口

srand((unsigned int)time(NULL));

DWORD t1 = timeGetTime();

DWORD* pMem = GetImageBuffer();

//第一个界面

welcome();

//初始化

for (int i = 0; i < NUM; i++)

{

init(i);

}

loadimages();

BeginBatchDraw();

while (!_kbhit())

{

//Sleep(10);

for (int i = 0; i < 1000; i++)

{

for (int j = 0; j < 3; j++)

{

int px1 = rand() % 1000;

int py1 = rand() % 600;

if (py1 < 599)

{

pMem[py1 * 1000 + px1] = pMem[py1 * 1000 + px1 + 1] = BLACK;

}

}

}

choice(t1);

shoot();

Show(pMem);

EndBatchDraw();

}

return 0;

}

void welcome()

{

settextcolor(YELLOW);

for (int i = 0; i < 50; i++)

{

//圆心(500,300) 半径150 60个均匀点的x,y

int x = 500 + int(150 * sin(PI * 2 * i / 60));

int y = 300 + int(150 * cos(PI * 2 * i / 60));

cleardevice();

settextstyle(i, 0, L"微软雅黑");

outtextxy(x - 100, y - 150, L"测试使用1234567890"); //在指定的位置去输出字符

outtextxy(x, y - 100, L"测试1234567890");

Sleep(25);

}

//_getch(); //接收字符 不回显 直接接收

Sleep(2000);

cleardevice();

settextstyle(25, 0, L"宋体");

outtextxy(400, 150, L"1,");

outtextxy(400, 200, L"2");

outtextxy(400, 250, L"3,");

outtextxy(400, 300, L"4,");

outtextxy(400, 350, L"5");

outtextxy(560, 400, L"---6");

Sleep(3000);

//_getch();

}

void init(int i)

{

int r[14] = { 120,120,155,123,130,147,138,138,130,135,140,132,155,160 };

int x[14] = { 120,120,110,117,110,93,102,102,110,105,100,108,110,132 };

int y[14] = { 120,120,85,118,120,105,103,110,110,120,1201,04,85,145 };

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;

//初始化 烟花弹

jet[i].x = 0;

jet[i].y = 0;

jet[i].hx = 0;

jet[i].hy = 0;

jet[i].height = 0;

jet[i].t1 = timeGetTime(); //获取系统时间

jet[i].dt = rand() % 10; //0-9的随机时间

jet[i].n = 0;

jet[i].isshoot = false;

}

void loadimages()

{

IMAGE fm, gm;

loadimage(&fm, L"flower.dll", 3120, 240);

for (int i = 0; i < NUM; 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 jetimg;

loadimage(&jetimg, L"shoot.dll", 200, 50);

//set设置 working正在工作的 image图片

SetWorkingImage(&jetimg);

for (int i = 0; i < NUM; i++)

{

int n = rand() % 5; //0-4的随机数

getimage(&jet[i].img[0], n * 20, 0, 20, 50);

getimage(&jet[i].img[1], (n + 5) * 20, 0, 20, 50);

}

SetWorkingImage(NULL);

}

void choice(DWORD& t1)

{

DWORD t2 = timeGetTime();

if (t2 - t1 > 2) //2ms产生一个烟花弹

{

int n = rand() % 200; //0-199

if (n < NUM && jet[n].isshoot == false && fire[n].show == false)

{

//重置烟花弹

jet[n].x = rand() % (WND_WIDTH - 20);

jet[n].y = rand() % 100 + 400; //450-549

jet[n].hx = jet[n].x;

jet[n].hy = rand() % 400; //0-399

jet[n].height = jet[n].y - jet[n].hy;

jet[n].isshoot = true;

//n

putimage(jet[n].x, jet[n].y, &jet[n].img[jet[n].n]);

}

t1 = t2;

}

}

void shoot()

{

for (int i = 0; i < NUM; i++)

{

jet[i].t2 = timeGetTime();

if (jet[i].t2 - jet[i].t1 > jet[i].dt && jet[i].isshoot == true)

{

putimage(jet[i].x, jet[i].y, &jet[i].img[jet[i].n]);

if (jet[i].hy < jet[i].y)

{

jet[i].n++; //0-1 明暗交替

jet[i].y -= 5;

}

putimage(jet[i].x, jet[i].y, &jet[i].img[jet[i].n]);

if (jet[i].y <= jet[i].hy)

{

fire[i].y = jet[i].hy;

fire[i].x = jet[i].hx;

fire[i].show = true;

jet[i].isshoot = false;

}

jet[i].t1 = jet[i].t2;

}

}

}

void Show(DWORD* pMem)

{

int drt[16] = { 5,5,5,5,5,6,25,25,25,25,25,55,55,55,55,55 }; //dt

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 < 1000 && yy < 600 && yy>0)

{

pMem[yy * 1000 + xx] = BGR(fire[i].xy[x1][y1]);

}

}

}

fire[i].draw = true;

}

}

}

void clss(int a)

{

system("cls");

}

void delay(int a)

{

while (a)

{

a--;

}

}

void detabase(int a)

{

switch (a)

{

case 1:

{

//printf("■■■■■■■■■■■■■■■■■■■■■■■■■\n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■■■■■■■■■\n");

printf(" ■■■ ■■■■■■■■ \n");

printf(" ■■■■■■■■■■■■ ■■ \n");

printf(" ■■■■■■■■■■■■ ■■ \n");

printf(" ■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf("■■■■■■■■■■■■■ ■■■■■■■■■■\n");

printf("■■■■■■■■■■■■■■ ■■■■■■■■■■\n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■■■■■■■■■■■ ■■ ■■ \n");

printf(" ■■■■■■■■■■■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■ ■■ ■ ■■ ■■ \n");

printf(" ■■■ ■■ ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■■ ■■ ■■ \n");

printf("■■■ ■■ ■ ■■ ■■ \n");

printf("■■ ■■ ■■ ■■ \n");

printf(" ■■■■ ■■■ ■■ \n");

printf(" ■■■■ ■ ■■ \n");

}

break;

case 2:

{

//printf("■■■■■■■■■■■■■■■■■■■■■■■■\n");

printf(" ■■■ \n");

printf(" ■■■ \n");

printf(" ■■ \n");

printf(" ■■■ \n");

printf(" ■■■■■■■■■■■■■■■■■■■ \n");

printf(" ■■■ ■■■ ■ \n");

printf(" ■■■ ■■ \n");

printf(" ■■■ ■■ \n");

printf(" ■■■■ ■■ \n");

printf("■■■■ ■■ \n");

printf(" ■■ ■■■■■■■■■■■■■■■■■ \n");

printf(" ■■■■■■■■■■■■■■■■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf("■■■■■■■■■■■■■■■■■■■■■■■■\n");

printf("■■■■■■■■■■■■■■■■■■■■■■■■\n");

printf(" ■■ \n");

printf(" ■■ \n");

printf(" ■■ \n");

printf(" ■■ \n");

printf(" ■■ \n");

printf(" ■■ \n");

printf(" ■■ \n");

}

break;

case 3:

{

//printf("■■■■■■■■■■■■■■■■■■■■■■■■■\n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■■■■■■■■■■ \n");

printf(" ■■ ■■■■■■■■■■■■ \n");

printf(" ■■ ■■ ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ ■■ ■■ \n");

printf("■■ ■■ ■■ ■■ ■■ \n");

printf("■■ ■■ ■■■ ■■ ■■ \n");

printf("■■ ■■ ■■ ■■ \n");

printf("■■ ■■ ■■ ■■ \n");

printf("■■ ■■ ■■ ■■■ \n");

printf(" ■■ ■■■■■■■■■■■■■■■■\n");

printf(" ■■ ■■■■■■■■■ ■■■\n");

printf(" ■■ ■■■ \n");

printf(" ■■ ■■■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■ \n");

printf(" ■■ ■■ ■■■ \n");

printf(" ■■ ■■■ ■■■ \n");

printf(" ■■ ■■■ ■■■■ \n");

printf(" ■■ ■■■■ ■■■■\n");

printf(" ■■ ■■■ ■■ \n");

printf(" ■■ ■ \n");

}

break;

case 4:

{

//不用 不用

//printf("■■■■■■■■■■■■■■■■■■■■■■■■■\n");

printf(" ■■ \n");

printf(" ■■ ■■■■■■■■■■■■■■ \n");

printf(" ■■■■■■■■■■■■■■■■■■■ \n");

printf(" ■■■ \n");

printf(" ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■ ■■ \n");

printf(" ■■■ ■■ \n");

printf(" ■■■ ■■ \n");

printf(" ■■■■■■■■■■■■■■■■■■■■■ \n");

printf(" ■■■■ ■■■ ■ \n");

printf(" ■■ \n");

printf(" ■■ \n");

printf(" ■ ■■ \n");

printf(" ■■■■ ■■ ■■■ \n");

printf(" ■■■ ■■ ■■■■ \n");

printf(" ■■■ ■■ ■■■■ \n");

printf(" ■■■ ■■ ■■■■ \n");

printf(" ■■■ ■■ ■■■■ \n");

printf(" ■■■ ■■ \n");

printf(" ■■■ ■■ \n");

printf(" ■■■■■ \n");

printf(" ■■■■ \n");

printf(" ■■ \n");

}

break;

case 5:

{

printf("happy spring festival!");

}

break;

}

}

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

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/259414.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

决定人生的七条公式

1 .积跬步以致千里&#xff0c;积怠惰以致深渊 1.01^365 37.80.99^365 0.032.拖延症 U EV/ID U完成任务的程度 E对成功的信心 V 对任务的愉悦度 I 你的分心程度 D你多久会获得回报3.三天打鱼两天晒网&#xff0c;终将一无所获 1.01^3 x 0.99^2 < 1.01 4.爱因斯坦的成…

strncpy与strcpy的区别与注意事项

strncpy 是 C语言的库函数之一&#xff0c;来自 C语言标准库&#xff0c;定义于 string.h&#xff0c;char *strncpy(char *dest, char *src, int n)&#xff0c;把src所指字符串的前n个字节复制到dest所指的数组中&#xff0c;并返回指向dest的指针。 strcpy只是复制字符串&am…

使用ssh公钥实现免密码登录

ssh 无密码登录要使用公钥与私钥。linux下可以用用ssh-keygen生成公钥/私钥对&#xff0c;下面我以CentOS为例。 有机器A(192.168.1.155)&#xff0c;B(192.168.1.181)。现想A通过ssh免密码登录到B。 首先以root账户登陆为例。 1.在A机下生成公钥/私钥对。 [rootA ~]# ssh-keyg…

15款的视频处理软件免费下载

因为需要购买昂贵的视频处理软件和高性能图形计算机&#xff0c;所以视频处理是一项比较耗费金钱的技术活。正是由于这样&#xff0c;一部分人选择使用性能较好的免费在线编辑软件&#xff0c;无需太多视频处理知识便可在浏览器中剪切和编辑视频。然而&#xff0c;当我们无法连…

液位系统c语言程序,超声波自动测量物体液位系统的设计

超声波自动测量物体液位系统的设计(任务书,毕业论文15000字)摘要本系统以STC89C52单片机为核心&#xff0c;通过硬件电路连接和软件程序的编写实现通用型超声波自动测量物体液位系统的设计。其主要原理是由单片机控制超声波发射电路发射超声波&#xff0c;超声波接收电路接收遇…

android-sdk-windows版本号下载

Android SDK 4.0.3 开发环境配置及执行 近期又装了一次最新版本号的ADK环境 眼下最新版是Android SDK 4.0.3 本文的插图和文本尽管是Android2.2的 步骤都是一样的&#xff0c;假设安装的过程中遇到什么问题&#xff0c;能够留言&#xff0c;我会尽快回复&#xff01; 系统环境的…

string中c_str()、data()、copy(p,n)函数的用法

转载&#xff1a;http://www.cnblogs.com/qlwy/archive/2012/03/25/2416937.html 标准库的string类提供了3个成员函数来从一个string得到c类型的字符数组&#xff1a;c_str()、data()、copy(p,n)。 1. c_str()&#xff1a;生成一个const char*指针&#xff0c;指向以空字符终止…

POJ2402 Palindrome Numbers 回文数

题目链接: http://poj.org/problem?id2402 题目大意就是让你找到第n个回文数是什么. 第一个思路当然是一个一个地构造回文数直到找到第n个回文数为止(也许大部分人一开始都是这样的思路). 很明显找到第n个之前的所有操作都是浪费, 这也是这个方法的最大弱点. 抱着侥幸心理(谁知…

离散卷积的c语言编程实验,数字信号处理实验一离散卷积c语言编程.ppt

数字信号处理实验一离散卷积c语言编程实验一 离散卷积的C语言编程实验 DSP实验室 2005 实验性质 综合设计性实验 实验目的 1 了解和认识常用的各种信号&#xff1b; 2 掌握卷积的定义和计算方法&#xff1b; 3 掌握在计算机中生成以及绘制信号序列图的方法。 实验原理 离散时间…

async-await原理解析

在用async包裹的方法体中&#xff0c;可以使用await关键字以同步的方式编写异步调用的代码。那么它的内部实现原理是什么样的呢&#xff1f;我们是否可以自定义await以实现定制性的需求呢&#xff1f;先来看一个简单的例子&#xff1a; 1 class Test {2 public sta…

emacs-w3m查看html帮助手册

<?xml version"1.0" encoding"utf-8"?> emacs-w3m查看html帮助手册emacs-w3m查看html帮助手册 Table of Contents 1. 使用效果2. 为什么要用emacs-w3m来查看html的帮助手册&#xff1f;3. 什么是w3m?4. 配置5. 额外资源1 使用效果 使用快捷键C-c …

c语言生命游戏代码大全,c++生命游戏源码

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼glViewport( 0, 0, width, height );glMatrixMode( GL_PROJECTION );glLoadIdentity( );}//程序入口int main(int argc, char *argv[]){//随机生成细胞的状态MapRand();std::cout<//SDL初始化const SDL_VideoInfo* info NULL;i…

初学React,setState后获取到的thisstate没变,还是初始state?

问题&#xff1a;(javascript)初学React&#xff0c;setState后获取到的thisstate没变&#xff0c;还是初始state&#xff1f;描述: getInitialState(){return {data:[]};},componentDidMount(){var data [ { author: "Pete Hunt", text: "This is one comment…

sizeof(数组名)和sizeof(指针)

转载&#xff1a;http://blog.csdn.net/kangroger/article/details/20653255 在做这道题时&#xff1a; 32位环境下&#xff0c;int *pnew int[10];请问sizeof(p)的值为&#xff08;&#xff09; A、4 B、10 C、40 D、8 我以为正确答…

工作中的问题

今天写一专题页面&#xff0c;写出的结果在各个浏览器下都不同&#xff0c;心情不好。。。 就是红线的地方老对不齐。。。 在朋友指导下改了下样式好了 右边代码结构 1 <div class"fr Img"> 2 <h3>相关专题</h3> 3 <a href"#"…

数组的sizeof

转载&#xff1a;http://blog.163.com/chen_xinghuan/blog/static/17220158220112182838196/ 数组的sizeof值等于数组所占用的内存字节数&#xff0c;如&#xff1a;   char a1[] “abc”;   int a2[3];   sizeof( a1 ); // 结果为4&#xff0c;字符 末尾还存在一个…

数据结构行编辑成簇 c语言,索引的数据结构及底层存储

索引是帮助数据库高效获取数据的数据结构索引的数据结构1.hash表a.利用hash存储的话需要将所有的数据文件添加到内存&#xff0c;比较耗费内存空间b.hash表存储的是无序数据&#xff0c;范围查找的时候需要挨个进行遍历&#xff0c;比较耗费时间。2.二叉树二叉树规定左子树必须…

卓同学的 Swift 面试题

我觉得应该掌握的知识点&#xff0c;没有实际意义。 class 和 struct 的区别不通过继承&#xff0c;代码复用&#xff08;共享&#xff09;的方式有哪些Set 独有的方法有哪些&#xff1f;实现一个 min 函数&#xff0c;返回两个元素较小的元素map、filter、reduce 的作用map 与…

使用CImage双缓冲

一普通显示&#xff1a;现在的VC显示图片非常方便&#xff0c;远不是VC6.0那个年代的技术可比&#xff0c;而且支持多种格式的如JPG&#xff0c;PNG。 CImage _img; 初始化&#xff1a; _img.Load(L"map.png"); 显示&#xff1a;OnPaint事件中 CRect rect; this…

汇编语言学习系列 for循环实现

假如汇编语言要实现如下C语言的功能&#xff0c;编译环境Ubuntu14.04&#xff08;32位&#xff09;。 #include<stdio.h> int fact_for(int n) {int i;int result 1;for(i 2; i < n; i)result * i;return result; }int main(){printf("%d\n", fact_for(3)…