返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C++实现动态烟花效果
  • 967
分享到

C++实现动态烟花效果

2024-04-02 19:04:59 967人浏览 独家记忆
摘要

目录一、前言二、代码fire.hmain.cppfire.cpp三、实现效果一、前言 c++实现的放烟花程序 用到了EGE图形库,没有的需要自行安装 可调项:背景图和背景音乐、粒子模

一、前言

c++实现的放烟花程序

用到了EGE图形库,没有的需要自行安装

可调项:背景图和背景音乐、粒子模糊度、亮度以及上升速度的参数。

实现的动态烟花非常好看,可以做给女朋友或者表白用hhh

自己做出来玩玩也挺有意思的

二、代码

fire.h

#pragma once
#ifndef  FIREWORKS_H_
#define FIREWORKS_H_
#define myrand(m) ((float)rand() * m / 36565)
#include <graphics.h>

struct Speed {
	double x, y;
};

struct Pos {
	double x, y;
};

struct Particle
{
	Pos pos;
	Speed speed;
};


#define GROUND 580	//地面位置
class Fireworks//烟花类			
{
private:

	static const int NUM_PARTICLE = 200;
	static const double particleSpeed;
	Particle p[NUM_PARTICLE];

	color_t color;

	int delayTime;		//延迟时间
	int riseTime;		//上升时间
	int bloomTime;		//爆炸时间

	Pos risePos;		//上升阶段位置
	Speed riseSpeed;	//上升速度

public:
	//初始化
	Fireworks();
	void init();
	//更新位置等相关属性
	void update();
	//根据属性值绘画
	void draw(PIMAGE pimg = NULL);
};

#endif // ! FIREWORKS_H_

main.cpp

在这里插入代码片
#include <time.h>
#include <graphics.h>
#include "fire.h"
#define NUM_FIREWORKS 10	//烟花数量
int main()
{
	initgraph(1080, 720, INIT_RENDERMANUAL);
	srand((unsigned)time(NULL));
	//烟花
	Fireworks* fireworks = new Fireworks[NUM_FIREWORKS];
	PIMAGE bgPimg = newimage();
	getimage(bgPimg, "夜晚.jpg");
	//先绘制一下,不然前面有空白期
	putimage(0, 0, bgPimg);
	delay_ms(0);
	//背景音乐
	MUSIC bgMusic;
	bgMusic.OpenFile("MELANCHOLY.mp3");
	bgMusic.SetVolume(1.0f);
	if (bgMusic.IsOpen()) {
		bgMusic.Play(0);
	}
	
	//图像缓存, 因为要加背景图,直接加模糊滤镜会把背景图模糊掉
	//所以另设一个图像缓存来绘制烟花并加模糊滤镜,再绘制到窗口
	PIMAGE cachePimg = newimage(800, 800);
	
	//计时用,主要用来定时检查音乐播放
	int timeCount = 0;

	for (; is_run(); delay_fps(60))
	{
		//隔1秒检查一下,如果播放完了,重新播放
		if ((++timeCount % 60 == 0) && (bgMusic.GetPlayStatus() == MUSIC_MODE_STOP)) {
			bgMusic.Play(0);
		}
		//更新位置
		for (int i = 0; i < NUM_FIREWORKS; i++) {
			fireworks[i].update();
		}
		//绘制背景
		putimage(0, 0, bgPimg);
		//绘制烟花到图像缓存中
		for (int i = 0; i < NUM_FIREWORKS; i++) {
			fireworks[i].draw(cachePimg);
		}

		//模糊滤镜,拖尾效果
		//第二个参数,模糊度,越大越模糊,粒子也就越粗
		//第三个参数,亮度,越大拖尾越长
		//可以试试一下其它参数搭配,例如以下几组:
		//0x03, 0xff
		//0x0b, 0xe0
		//0xff, 0xff
		//imagefilter_blurring(cachePimg, 0x0a, 0xff);
		//imagefilter_blurring(cachePimg, 0x03, 0xff);
		//imagefilter_blurring(cachePimg, 0x0b, 0xe0);
		//imagefilter_blurring(cachePimg, 0xff, 0xff);
		//imagefilter_blurring(cachePimg, 0x01, 0xff);
		imagefilter_blurring(cachePimg, 0x0b, 0xff);
		//缓存绘制到窗口,模式为(最终颜色 = 窗口像素颜色 Or 图像像素颜色), 这样颜色会叠加起来
		putimage(0, 0, cachePimg, SRCPAINT);
	}
	delete[] fireworks;
	delimage(bgPimg);
	delimage(cachePimg);
	bgMusic.Close();
	closegraph();
	return 0;
}

fire.cpp

#include <cmath>
#define SHOW_CONSOLE
#include "fire.h"
const double Fireworks::particleSpeed = 3.0f;
Fireworks::Fireworks()
{
	init();
}
void Fireworks::init()
{
	delayTime = rand() % 300 + 20;
	riseTime = rand() % 80 + 160;
	bloomTime = 160;

	risePos.x = rand() % 450 + 300.0f;
	risePos.y = GROUND;

	riseSpeed.y = myrand(1.0f) - 3.0f;	//上升速度,根据坐标系需要是负的
	riseSpeed.x = myrand(0.4f) - 0.2f;	//可稍微倾斜
	//随机颜色
	color = HSVtoRGB(myrand(360.0f), 1.0f, 1.0f);
	//给每一个粒子设置初始速度
	for (int i = 0; i < NUM_PARTICLE - 1; i += 2)
	{
		//为了球状散开,设初始速度大小相等
		//初始随机速度水平角度和垂直角度,因为看到是平面的,所以求x, y分速度
		double levelAngle = randomf() * 360;
		double verticalAngle = randomf() * 360;
		//速度投影到xOy平面
		double xySpeed = particleSpeed * cos(verticalAngle);

		//求x, y分速度
		p[i].speed.x = xySpeed * cos(levelAngle);
		p[i].speed.y = xySpeed * sin(levelAngle);

		//动量守恒,每对速度反向
		if (i + 1 < NUM_PARTICLE)
		{
			p[i + 1].speed.x = -p[i].speed.x;
			p[i + 1].speed.y = -p[i].speed.y;
		}
	}
}

void Fireworks::draw(PIMAGE pimg)
{
	//未开始
	if (delayTime > 0)
		return;
	//烟花上升阶段
	else if (riseTime > 0)
	 {
		setfillcolor(color, pimg);
		//画四个点,这样大一些
		bar(risePos.x, risePos.y, risePos.x + 2, risePos.y + 2, pimg);
	}
	//烟花绽放阶段
	else 
	{
		setfillcolor(color, pimg);
		for (int i = 0; i < NUM_PARTICLE; i++)
		 {
			bar(p[i].pos.x, p[i].pos.y, p[i].pos.x + 2, p[i].pos.y + 2, pimg);
		}
	}
}

//更新位置等相关属性
void Fireworks::update()
{
	if (delayTime-- > 0)
		return;
	//处于上升阶段,只更新烟花位置
	else if (riseTime > 0) 
	{
		risePos.x += riseSpeed.x;
		risePos.y += riseSpeed.y;

		//重力作用
		riseSpeed.y += 0.005;

		//上升完毕,到达爆炸阶段
		if (--riseTime <= 0) 
		{
			//设粒子初始位置为烟花当前位置
			for (int i = 0; i < NUM_PARTICLE; i++)
			 {
				p[i].pos.x = risePos.x;
				p[i].pos.y = risePos.y;
			}
		}
	}
	//烟花绽放阶段
	else if (bloomTime-- > 0)
	 {
		//粒子散开,更新粒子位置
		for (int i = 0; i < NUM_PARTICLE; i++) 
		{
			p[i].pos.x += p[i].speed.x;
			p[i].pos.y += p[i].speed.y;
			//重力作用
			p[i].speed.y += 0.005;
			//速度减慢
			p[i].speed.x *= 0.982;
			p[i].speed.y *= 0.982;
		}
	}
	else
	 {
		//烟花重新开始
		init();
	}
}

三、实现效果

由于烟花是动态的,截图出来不是很好看,但是做出来动态的烟花其实是很好看的,大家可以去试试

到此这篇关于C++实现动态烟花效果的文章就介绍到这了,更多相关C++烟花内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C++实现动态烟花效果

本文链接: https://lsjlt.com/news/163270.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C++实现动态烟花效果
    目录一、前言二、代码fire.hmain.cppfire.cpp三、实现效果一、前言 C++实现的放烟花程序 用到了EGE图形库,没有的需要自行安装 可调项:背景图和背景音乐、粒子模...
    99+
    2024-04-02
  • python实现跨年烟花动态效果
    目录Pygame 绘制烟花的基本原理用Python和Tkinter设计烟花将烟花绽放转译成代码使用Tkinter模拟朋友们,有多久没放烟花了?今年你所在的地方允许放烟花么?既然我们不...
    99+
    2023-01-03
    python实现跨年烟花 python实现烟花效果 python烟花
  • Python粒子烟花动态效果实现
    目录效果展示实现代码剩下代码跨年倒计时还有18天?我已经开始整烟花了,虽然不是很好看吧,但是也能将就看看 这个的背景图,音乐,还有文字都是可以自己修改的哦 效果展示 依次导入本次...
    99+
    2023-01-03
    Python粒子烟花 Python动态烟花 Python烟花
  • C++实现动态烟花代码
    目录写在前面代码思路开始编写1 烟花结构体2 初始化烟花3 烟花上升4 烟花爆炸5 绘制烟花效果展示完整代码写在前面 首先,祝大家新年快乐! 即将迎来新的一年—&mdas...
    99+
    2023-01-28
    C++ 动态烟花 C++ 烟花
  • js实现炫酷的烟花效果
    本文实例为大家分享了js实现炫酷的烟花效果的具体代码,供大家参考,具体内容如下 我们要理清整个流程的思路。 首先建立一块画布,用于展示烟花的效果,然后就要去思考烟花燃放的流程,我们都...
    99+
    2024-04-02
  • 怎么用Python实现烟花效果
    本篇内容主要讲解“怎么用Python实现烟花效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“怎么用Python实现烟花效果”吧!效果如下:这里给出代码,祝各位老哥新年快乐。import&nbs...
    99+
    2023-06-29
  • 基于Html+CSS+JS实现手动放烟花效果
    目录效果展示实现代码HtmlCssJavaScript雷迪森安的乡亲们,欢迎来到老实人的前端课堂,上次写了一个新春小盲盒,这大过年的,我把烟花都给你们准备好了,今天我们来写个小烟花吧...
    99+
    2024-04-02
  • Python如何实现浪漫烟花效果
    这篇文章主要介绍了Python如何实现浪漫烟花效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。1 旖旎风景马上虎年了,也是我的生肖年,很激动!(不小心暴露了年龄,哈哈哈.....
    99+
    2023-06-29
  • 怎么用HTML5 Canvas实现烟花绽放动画效果
    这篇文章主要介绍“怎么用HTML5 Canvas实现烟花绽放动画效果”,在日常操作中,相信很多人在怎么用HTML5 Canvas实现烟花绽放动画效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方...
    99+
    2024-04-02
  • 基于Html+CSS+JS怎样实现手动放烟花效果
    基于Html+CSS+JS怎样实现手动放烟花效果,很多新手对此不是很清楚,为了帮助大家解决这个难题,下面小编将为大家详细讲解,有这方面需求的人可以来学习下,希望你能有所收获。效果展示注意看有两种模式哦,可以自由切换,鼠标点哪里哪里有烟花,还...
    99+
    2023-06-28
  • 基于JavaScript实现在线网页烟花效果
    目录实现效果关键步骤源码实现效果 关键步骤 随机颜色 var hue = Math.random() * 360;var hueVariance = 30; functio...
    99+
    2023-02-03
    JavaScript在线网页烟花效果 JavaScript 烟花效果 JavaScript烟花
  • 如何使用css3+js实现烟花绽放的动画效果
    这篇文章主要为大家展示了“如何使用css3+js实现烟花绽放的动画效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用css3+js实现烟花绽放的动画效果...
    99+
    2024-04-02
  • 基于Python实现烟花效果的示例代码
    python烟花代码 如下 # -*- coding: utf-8 -*- import math, random,time import threading import tki...
    99+
    2024-04-02
  • JavaScript实现带音效的烟花特效
    花了半个小时写的代码,这个html5 canvas新年烟花一定不会让大家失望! 首先我们看下静态的效果图: 文章末尾有动态的效果图,滑动即可看到!  JavaScript代码如下:...
    99+
    2024-04-02
  • JavaScript实现烟花和福字特效
    目录超能力一:放烟花超能力二:写福字隐藏能力:只有程序员能看懂的祝福虎虎生威、虎年大吉。 事事都如意,虎虎有生气…… 都2022了你还在从网上复制粘贴这些...
    99+
    2024-04-02
  • Htlm怎么实现鲜花盛开动态图效果
    本篇内容主要讲解“Htlm怎么实现鲜花盛开动态图效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Htlm怎么实现鲜花盛开动态图效果”吧!<!DOCTYP...
    99+
    2024-04-02
  • r语言怎么画动态烟花
    在R语言中,可以使用`animation`包来画动态烟花。下面是一个简单的例子:```R# 安装和加载animation包insta...
    99+
    2023-08-18
    r语言
  • JavaScript实现烟花特效(面向对象)
    本文实例为大家分享了JavaScript实现烟花特效的具体代码,供大家参考,具体内容如下 本特效使用面向对象编程 分析 OOA 点击触发事件 烟花运动分成两个阶段 ...
    99+
    2024-04-02
  • JavaScript实现五种不同烟花特效
    目录 一、简单大气的烟花二、在农村看到的烟花三、可点击的烟花四、3D旋转烟花五、可拖动视角的自定义烟花 一、简单大气的烟花 演示地址:http://haiyong...
    99+
    2024-04-02
  • 怎么使用canvas实现烟花特效
    小编给大家分享一下怎么使用canvas实现烟花特效,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!canvas可以实现不同动画效果,本文主要记录几种不同节日烟花效果...
    99+
    2023-06-09
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作