css3+js实现烟花绽放的动画效果(代码示例)

本篇文章给大家介绍通过js+css3的transforms属性和keyframes属性来实现烟花绽放的动画效果的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。

首先我们来看看效果:

1.gif

动画的实现原理:

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

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

立即学习“前端免费学习笔记(深入)”;

1.jpg 

2.jpg

每个烟花筒沿着场地底部的线分配一个随机的起始位置。它还在标记的区域内分配了一个随机目标。当烟花筒接近其目标点时,它会缩小为不可见(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教程!

以上就是css3+js实现烟花绽放的动画效果(代码示例)的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1613138.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月24日 03:25:49
下一篇 2025年12月24日 03:26:11

相关推荐

  • css3线性渐变语法的详解(代码示例)

    本篇文章给大家带来的内容是css3线性渐变语法的详解(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 线性渐变的完整语法: .demo { background: linear-gradient(to left, black, white);} 效果: 兼容性写法: 立…

    2025年12月24日 好文分享
    000
  • 详解css3径向渐变如何定义中心和大小形状(代码示例)

    本篇文章给大家带来的内容是详解css3径向渐变如何定义中心和大小形状(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 为了让径向渐变–radial-gradient()在所有支持的浏览器中都能正常工作,并让一些新增功能可以涵盖任何未来的支持。我们可以这样写:…

    2025年12月24日 好文分享
    000
  • css3径向渐变详解之精确定义渐变的形状大小、添加多种终止颜色

    本篇文章给大家带来的内容是css3径向渐变详解之精确定义渐变的形状大小、添加多种终止颜色。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 定义明确的形状和大小 在之前的文章【详解css3径向渐变如何定义中心和大小形状】中我们介绍定义渐变中心、使用关键字定义渐变形状与大小的方法,大家…

    2025年12月24日 好文分享
    000
  • css如何实现幻灯片效果?幻灯片的实现方法(代码示例)

    本篇文章给大家带来的内容是介绍css如何实现幻灯片效果?幻灯片的实现方法(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 下面我们就通过代码来一步步实现幻灯片切换(淡入淡出)的效果: 1、建立html文件,编写demo 首先我们要在页面上设置图像列表,包含在div盒子中…

    2025年12月24日
    000
  • css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)

    本篇文章给大家带来的内容是介绍css+js如何在幻灯片上添加文字?实现幻灯片的旋转切换(附代码)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在之前的文章【css如何实现幻灯片效果?幻灯片的实现方法】中介绍了实现淡入淡出幻灯片的实现方法,本篇文章就在其基础上去解释如何在幻灯片上…

    2025年12月24日
    000
  • css3的重复渐变是什么?如何使用?(代码示例)

    本篇文章给大家带来的内容是介绍css3的重复渐变是什么?如何使用?(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们就来介绍一下重复渐变是什么? 在css3中除了可以实现线性渐变【linear-gradient()】,径向渐变【radial-gradient()…

    2025年12月24日
    000
  • css如何创建3D立体的条形图?创建3D立体的条形图的示例

    本篇文章给大家介绍css创建3d立体的条形图的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 本文介绍的创建立体条形图的示例,使用了透视和旋转的3D效果,而不仅仅是倾斜变换。 结果是一个图表,可以从任何方向查看。 下面我们来一步一步介绍如何建立,示例代码在WebKit浏览器中…

    2025年12月24日 好文分享
    000
  • css如何实现弹跳球动画效果?现弹跳球动画的实现示例

    css如何实现弹跳球动画效果?本篇文章给大家通过代码示例介绍css是如何实现弹跳球动画效果的。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 1、定义动画关键帧 对于这个动画,我们将使用两个关键帧 – 一个用恒定速度水平平移球,另一个用于应用大致抛物线垂直弹跳运动。可以…

    2025年12月24日
    000
  • css中linear-gradient()可以干什么?linear-gradient()的使用

    本篇文章给大家介绍的是css中linear-gradient()可以干什么?linear-gradient()的使用。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 渐变是从一种颜色平滑地淡化到另一种颜色的图像,可以让你在两个或多个指定的颜色之间显示平稳的过渡。这些通常用于背景图像…

    2025年12月24日 好文分享
    000
  • css中radial-gradient()是什么?radial-gradient()的使用

    本篇文章给大家介绍的是css中radial-gradient()是什么?radial-gradient()的使用。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 在css中我们可以通过设置渐变(gradients)来实现两个或多个指定的颜色之间显示的平稳过渡。且因为渐变(gradi…

    2025年12月24日 好文分享
    000
  • css3如何设置动画?css设置简单动画的方法

    css3如何设置动画?本篇文章给大家带来的内容是介绍css3设置简单动画的方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来了解一下css3实现简单动画需要用到的属性:animation属性,@keyframes “规则”。 animation属性和@keyframe…

    好文分享 2025年12月24日
    000
  • css3新增属性all是什么?有什么用?

    为了web前端开发的方便,css3新增了许多属性(新特性),本篇文章就给大家介绍css3新增属性all是什么,让大家了解all属性的作用和使用方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。【想要了解更多css3相关知识,推荐视频学习:css3教程】 首先我们了解一下css3 …

    2025年12月24日 好文分享
    000
  • calc怎么用?css3 calc()函数的使用总结

    calc是什么意思?怎么使用?本篇文章给大家带来的内容是介绍css3中的calc()函数是什么,有什么用,如何使用。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 css3中的calc()是什么?可以做什么? calc()从字面看我们可以把它理解为一个function函数。其实ca…

    2025年12月24日
    000
  • calc()可以做什么?实现css的灵活布局

    本篇文章给大家带来的内容是介绍calc()可以做什么?实现css的灵活布局。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 创建一个漂亮的CSS自适应布局首先要为Web应用程序中的所有内容分配好大小空间。一个高度的特征要求拥有可以混合使用长度单位来指定尺寸的能力。 例如,如何能够保…

    2025年12月24日
    000
  • css如何实现禁止文本被选中,禁止复制?(代码示例)

    在前端开发中,有时会出现这样一种情况:双击文字后,文字就会被选中,特别丑,一点也不美观,也很不方便;而且有时候在某些网页模块上我们就是就是需要文字不可以被选中或复制。 那么如何实现这种需求,实现文本不被选中或复制?本篇文章就给大家介绍css实现禁止文本被选中,禁止复制的方法。有一定的参考价值,有需要…

    2025年12月24日
    000
  • css+js如何实现简单的动态进度条效果?(代码实例)

    css+js如何实现简单的动态进度条?本篇文章就给大家用css+js制作一个简单的动态进度条效果,并将页面动态进度条滚动加载的代码分享给大家,感兴趣的小伙伴可以参考借鉴一下,希望对你们有所帮助。 我们要知道,这里主要使用了css3的animation动画属性,首先将进度条设置为一个初始宽度为0,背景…

    2025年12月24日
    000
  • 总结CSS中单位的计算(代码示例)

    本篇文章给大家带来的内容是关于总结css中单位的计算(代码示例),有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。 CSS单位总结 公共部分css body { background-color: #000; color: skyblue; margin: 0; padding: 0;…

    2025年12月24日 好文分享
    000
  • CSS3如何实现2D转换?2D转换的实现(代码示例)

    本篇文章给大家带来的内容是介绍css3如何实现2d转换?2d转换的实现(代码示例)。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 transform 参考W3手册 transform 属性向元素应用从2D 或3D转换。该属性允许我们对元素进行旋转、缩放、移动或者倾斜。 1、格式:…

    2025年12月24日
    000
  • 纯CSS3实现页面圆圈加载(loading)动画特效

    在网速不好的情况下打开网站或者观看视频,页面加载会很慢,这时一般会提示用户“页面正在加载中,请稍后”,而且会有一个圆圈一直在转动。正在学习html和css的小伙伴,你会用css3实现圆圈加载动画效果吗?这篇文文章就给大家分享一个纯css3实现的圆圈(loading)加载动画特效,感兴趣的小伙伴可以参…

    2025年12月24日
    000
  • css3怎么给文字加描边?css3实现字体描边样式的方法(代码详解)

    css3怎么给文字加描边?本篇文章就给大家介绍css3给文字加描边的方法,让大家了解css text-stroke属性实现字体描边样式的具体方法。有一定的参考价值,有需要的朋友可以参考一下,希望对你们有所帮助。 首先我们来通过简单的代码示例介绍一下css3中的text-stroke属性给文字添加描边…

    2025年12月24日
    000

发表回复

登录后才能评论
关注微信