html实现烟花绽放,css3+js如何实现烟花绽放的动画效果

本文详细介绍了如何使用CSS3和JavaScript合作,实现烟花绽放的动画效果。通过关键帧动画、DOM操作和颜色变换,模拟烟花发射、上升及绽放过程。适合前端开发者学习CSS3动画和JavaScript交互应用。
摘要由CSDN通过智能技术生成

css3+js如何实现烟花绽放的动画效果

发布时间:2020-10-19 16:44:04

来源:亿速云

阅读:88

作者:小新

小编给大家分享一下css3+js如何实现烟花绽放的动画效果,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!

动画的实现原理:

动画使用了两个关键帧(keyframes):

一个是烟花筒上升的轨迹,另一个是烟花绽放中的火星碎片。在这里你可以看到正在进行的基本草图:

92f73ed05c7b46b47e66673608c6587c.png

a963b141d797d7660003476fd404e0b4.png

每个烟花筒沿着场地底部的线分配一个随机的起始位置。它还在标记的区域内分配了一个随机目标。当烟花筒接近其目标点时,它会缩小为不可见(0x0像素)。

此时,耀斑变得可见。这些实际上是一系列以径向方式向外指向的DIV,在向外的尖端有一种颜色 - 就像火柴棍一样。为了模拟爆炸,他们只是增加了长度,使灯光向外移动。

JavaScript用于:

1、将所有必需的元素添加到页面(DOM);

2、为每个烟花筒创建和分配关键帧 ; 和

3、指定颜色并将每个光斑旋转到正确的位置。

代码示例:

html代码:

烟花绽放

css代码(css-fireworks.css)@-webkit-keyframes explosion {

from {

width: 0;

opacity: 0;

}

33% {

width: 0;

opacity: 0;

}

34% {

width: 10px;

opacity: 1.0;

}

40% {

width: 80px;

opacity: 1.0;

}

to {

width: 90px;

opacity: 0;

}

}

@-moz-keyframes explosion {

from {

width: 0;

opacity: 0;

}

33% {

width: 0;

opacity: 0;

}

34% {

width: 10px;

opacity: 1.0;

}

40% {

width: 80px;

opacity: 1.0;

}

to {

width: 90px;

opacity: 0;

}

}

#stage {

position: relative;

width: 600px;

height: 400px;

margin: 100px auto;

background: #000 url(img/outerspace.jpg);

}

.launcher {

position: absolute;

-webkit-animation-duration: 4s;

-webkit-animation-iteration-count: infinite;

-moz-animation-duration: 4s;

-moz-animation-iteration-count: infinite;

background: red;

border-bottom: 3px solid yellow;

}

.launcher div {

position: absolute;

opacity: 0;

-webkit-animation-name: explosion;

-webkit-animation-duration: 4s;

-webkit-animation-iteration-count: infinite;

-moz-animation-name: explosion;

-moz-animation-duration: 4s;

-moz-animation-iteration-count: infinite;

left: 3px;

top: 3px;

width: 10px;

height: 4px;

border-right: 4px solid yellow;

border-radius: 2px;

-webkit-transform-origin: 0 0;

-moz-transform-origin: 0 0;

}

js代码(css-fireworks.js)document.addEventListener("DOMContentLoaded", function() {

var num_launchers = 12;

var num_flares = 20;

var flare_colours = ['red', 'aqua', 'violet', 'yellow', 'lightgreen', 'white', 'blue'];

var cssIdx = document.styleSheets.length - 1;

function myRandom(from, to)

{

return from + Math.floor(Math.random() * (to-from));

}

var keyframes_template = "from { left: LEFTFROM%; top: 380px; width: 6px; height: 12px; }\n"

+ "33% { left: LEFTTOP%; top: TOPTOPpx; width: 0; height: 0; }\n"

+ " to { left: LEFTEND%; top: BOTBOTpx; width: 0; height: 0; }";

for(var i=0; i < num_launchers; i++) {

leftfrom = myRandom(15, 85);

lefttop = myRandom(30, 70);

toptop = myRandom(20, 200);

leftend = lefttop + (lefttop-leftfrom)/2;

botbot = toptop + 100;

csscode = keyframes_template;

csscode = csscode.replace(/LEFTFROM/, leftfrom);

csscode = csscode.replace(/LEFTTOP/, lefttop);

csscode = csscode.replace(/TOPTOP/, toptop);

csscode = csscode.replace(/LEFTEND/, leftend);

csscode = csscode.replace(/BOTBOT/, botbot);

try { // WebKit browsers

csscode2 = "@-webkit-keyframes flight_" + i + " {\n" + csscode + "\n}";

document.styleSheets[cssIdx].insertRule(csscode2, 0);

} catch(e) { }

try { // Mozilla browsers

csscode2 = "@-moz-keyframes flight_" + i + " {\n" + csscode + "\n}";

document.styleSheets[cssIdx].insertRule(csscode2, 0);

} catch(e) { }

}

for(var i=0; i < num_launchers; i++) {

var rand = myRandom(0, flare_colours.length - 1);

var rand_colour = flare_colours[rand];

var launch_delay = myRandom(0,100) / 10;

csscode = ".launcher:nth-child(" + num_launchers + "n+" + i + ") {\n"

+ " -webkit-animation-name: flight_" + i + ";\n"

+ " -webkit-animation-delay: " + launch_delay + "s;\n"

+ " -moz-animation-name: flight_" + i + ";\n"

+ " -moz-animation-delay: " + launch_delay + "s;\n"

+ "}";

document.styleSheets[cssIdx].insertRule(csscode, 0);

csscode = ".launcher:nth-child(" + num_launchers + "n+" + i + ") div {"

+ " border-color: " + rand_colour + ";\n"

+ " -webkit-animation-delay: " + launch_delay + "s;\n"

+ " -moz-animation-delay: " + launch_delay + "s;\n"

+ "}";

document.styleSheets[cssIdx].insertRule(csscode, 0);

}

for(var i=0; i < num_flares; i++) {

csscode = ".launcher div:nth-child(" + num_flares + "n+" + i + ") {\n"

+ " -webkit-transform: rotate(" + (i * 360/num_flares) + "deg);\n"

+ " -moz-transform: rotate(" + (i * 360/num_flares) + "deg);\n"

+ "}";

document.styleSheets[cssIdx].insertRule(csscode, 0);

}

for(var i=0; i < num_launchers; i++) {

var newdiv = document.createElement("div");

newdiv.className = "launcher";

for(var j=0; j < num_flares; j++) {

newdiv.appendChild(document.createElement("div"));

}

document.getElementById("stage").appendChild(newdiv);

}

}, false);

看完了这篇文章,相信你对css3+js如何实现烟花绽放的动画效果有了一定的了解,想了解更多相关知识,欢迎关注亿速云行业资讯频道,感谢各位的阅读!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值