中文字幕日韩精品一区二区免费_精品一区二区三区国产精品无卡在_国精品无码专区一区二区三区_国产αv三级中文在线

css3+js如何實現(xiàn)煙花綻放的動畫效果-創(chuàng)新互聯(lián)

小編給大家分享一下css3+js如何實現(xiàn)煙花綻放的動畫效果,希望大家閱讀完這篇文章后大所收獲,下面讓我們一起去探討吧!

成都創(chuàng)新互聯(lián)公司-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價比黃龍網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式黃龍網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋黃龍地區(qū)。費用合理售后完善,十載實體公司更值得信賴。

動畫的實現(xiàn)原理:

動畫使用了兩個關(guān)鍵幀(keyframes):

一個是煙花筒上升的軌跡,另一個是煙花綻放中的火星碎片。在這里你可以看到正在進(jìn)行的基本草圖:

css3+js如何實現(xiàn)煙花綻放的動畫效果

css3+js如何實現(xiàn)煙花綻放的動畫效果

每個煙花筒沿著場地底部的線分配一個隨機的起始位置。它還在標(biāo)記的區(qū)域內(nèi)分配了一個隨機目標(biāo)。當(dāng)煙花筒接近其目標(biāo)點時,它會縮小為不可見(0x0像素)。

此時,耀斑變得可見。這些實際上是一系列以徑向方式向外指向的DIV,在向外的尖端有一種顏色 - 就像火柴棍一樣。為了模擬爆炸,他們只是增加了長度,使燈光向外移動。


JavaScript用于:


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


2、為每個煙花筒創(chuàng)建和分配關(guān)鍵幀 ; 和

3、指定顏色并將每個光斑旋轉(zhuǎn)到正確的位置。

代碼示例:


html代碼:


<!DOCTYPE html>
<html>
	<head>
		<meta charset="UTF-8">
		<title>煙花綻放</title>
		<link rel="stylesheet" type="text/css" href="css-fireworks.css">
	</head>
	<body>
		<div id="stage"><!-- 動畫效果發(fā)生在這里 --></div>
		<script type="text/javascript" src="css-fireworks.js"></script>
	</body>
</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如何實現(xiàn)煙花綻放的動畫效果有了一定的了解,想了解更多相關(guān)知識,歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝各位的閱讀!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。

當(dāng)前標(biāo)題:css3+js如何實現(xiàn)煙花綻放的動畫效果-創(chuàng)新互聯(lián)
本文地址:http://www.rwnh.cn/article28/pcgjp.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供建站公司、動態(tài)網(wǎng)站、標(biāo)簽優(yōu)化、網(wǎng)站內(nèi)鏈、ChatGPT、靜態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

成都網(wǎng)站建設(shè)公司
万山特区| 广德县| 曲靖市| 桦甸市| 苍山县| 西峡县| 宜宾市| 清水县| 孟州市| 湾仔区| 抚顺市| 富顺县| 中西区| 贵港市| 芒康县| 洛川县| 浪卡子县| 嘉黎县| 广州市| 韩城市| 潮州市| 峨山| 兴文县| 罗山县| 泸州市| 云林县| 成都市| 天峨县| 金乡县| 阿克陶县| 进贤县| 原平市| 当阳市| 增城市| 金川县| 京山县| 资源县| 淮南市| 阿荣旗| 玉门市| 星座|