日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

js模擬實現煙花特效

瀏覽:179日期:2024-05-19 17:39:32

本文實例為大家分享了js實現煙花特效的具體代碼,供大家參考,具體內容如下

如下圖

js模擬實現煙花特效

首先描繪圓周運動

// d1/*css*/div{ height: 4px; width: 4px; background: red; position: absolute;}//jsvar div = document.getElementById(’div’); // 畫運動點document.getElementsByTagName(’body’)[0].appendChild(tdiv); // 添加節點var deg = 0; // 運動角度var r = 100; // 半徑var center = [300, 300] // 圓心var dd = Math.PI/180; // PI和角度之間的轉換setInterval(function(){ deg++; div.style.left = center[0] + Math.cos(deg * dd) * r + ’px’; div.style.top = center[1] + Math.sin(deg * dd) * r + ’px’;},16);

以上代碼運行后可以看到一個圓周運動紅色方塊 完成上述步驟后,有什么用呢? 煙花的綻放,想象一下,可以當成很多方塊從一個從圓心開始向四周擴算的一種運動方式。 一束煙花,有10個綻放點,那就是每隔360 / 10 = 36度,就有一條運動軌跡。 這樣就好辦了

// d2var divs = []; // 保存煙花節點var len = 10; // 煙花節點個數var temp = 360 / len; // 運動軌跡所隔角度for(var i = 0; i < len; i++){ var tdiv = document.createElement(’div’); var tr1 = r; // 半徑 var deg = i * temp; // 當前軌跡所在的角度值 var left = center[0] + Math.cos(deg * dd) * tr1 var topLen = center[1] + Math.sin(deg * dd) * tr1 tdiv.style.left = left +’px’; tdiv.style.top = topLen +’px’; tdiv.data = { // 存放節點的位置信息 deg : deg, r : tr1, left : left, top : topLen }; document.getElementsByTagName(’body’)[0].appendChild(tdiv); divs.push(tdiv);}

上述代碼運行后可以看到

js模擬實現煙花特效

看起來是有點煙花的意思了,但是煙花的運動軌跡可沒這么工整,同一個地點出發,同一個地點結束。 而這個結束點就是半徑的長度值,所以只需將半徑進行變化就可打亂。

// d3function getRanR(a,b){ // 隨機得到a-b的值 return Math.floor(Math.random()*(b-a+1)+a);}

將for循環里的 tr1 改為 getRanR(0,200); 就可看到下圖

js模擬實現煙花特效

看著很亂,完全沒點煙花的樣子。沒關系,讓它運動起來就可以看出來了。 為了讓這個動起來就要讓上面 d2 的js代碼進行修改。讓各個節點的起始位置為圓心。同時為了省點力,用css3進行運動。

/*css*/div{ height: 4px; width: 4px; background: red; position: absolute; transition: 1s all; // 就添加這一句}// jstdiv.style.left = center[0] +’px’;tdiv.style.top = center[1] +’px’;

運動軌跡從 d2 可以看出來已經全部存放到了節點里。用divs可以拿到各個節點。所以只需操作divs就可以了

document.onclick = function () { for(var i = 0; i < divs.length; i++){ divMove(divs[i]) }}function divMove(div){ var data = div.data; div.style.left = data.left + ’px’; div.style.top = data.top + ’px’;}

運動如下圖:

js模擬實現煙花特效

這樣就可以看到一個簡易的煙花效果。就這么一個簡易的煙花連續起來就可達到圖1的效果。 所以首先要對這個簡易的煙花效果進行封裝。 動畫方面為了方便操作,所以引入jquery。 以下為html + css

<html><head> <meta charset='utf-8'> <style> *{ padding: 0; margin: 0; } div.boom-div{ height: 4px; width: 4px; background: orange; position: absolute; border-radius: 50%; } #container{ width: 100%; height: 100%; position: relative; } .input-container{ position: absolute; z-index: 1; } </style></head><body> <div class='input-container'> <input type='button' value='重繪'> <input type='button' value='清零'> <input type='button' value='保存'> </div> <div id='container'></div></body></html>

JS部分

var boom = { init: function (center, len, container, type) { this.len = len || 20; // 煙花節點個數 this.maxR = 100; // 最大半徑 this.speed = 1500; // 速度 this.divs = []; // 存放煙花節點 this.center = center; // 圓心 this.type = type; // 類型 this.container = container; // 容器 this.paint(); }, getRanR: function (a, b) { // 得到隨機數 return Math.floor(Math.random() * (b - a + 1 )+ a); }, // 畫出煙花節點所在點,以及保存去往點信息 // 圓心, 半徑, 容器, 類型 paint: function () { var that = this; var center = that.center.slice(), len = that.len, container = that.container, type = that.type, dd = Math.PI / 180, temp = 360 / len; for (var i= 0; i < len; i++) { var div = document.createElement(’div’); var deg = i * temp; // 當前軌跡所在的角度值 var cc = []; // 節點的結束點 var tr = that.getRanR(0, that.maxR); // 半徑 var left = 0; // 煙花節點所在的位置 var topLen = 0; // 煙花節點所在的位置 var xCenter = center[0], yCenter = center[1]; if (type) { // 當類型為真時,整個煙花效果就是向外擴張 left = xCenter; // 為假時則是向內收縮,本質一樣都是拿到開始點和結束點 topLen = yCenter; // 只是將開始和結束換了個位置 cc = [xCenter + Math.cos(deg * dd) * tr, yCenter + Math.sin(deg * dd) * tr]; } else { left = xCenter + Math.cos(deg * dd) * tr; topLen = yCenter + Math.sin(deg * dd) * tr; cc = [xCenter, yCenter]; } div.className = ’boom-div’; div.style.left = left + ’px’; div.style.top = topLen + ’px’; div.data = { left: cc[0], // 節點的結束點 top: cc[1], // 節點的結束點 } that.divs.push(div); container.appendChild(div); } // 使節點運動起來 that.move(); }, // 運動 move: function () { var that = this; var len = that.len, container = that.container, divLen = that.divs.length; for (var i = 0; i < divLen; i++) { var div = that.divs[i]; $(div).animate({ left: div.data.left, top: div.data.top, opacity: 0, }, that.speed, 'linear', function() { // 運動完結后刪除節點 this.parentNode.removeChild(this); }); } }}

控制特效

var container = $(’#container’)[0];var arr = []; // 存放鼠標點擊位置var iCount = -1;$(container).on(’mousedown’, function(e) { iCount++; e = e || window.event; boom.init([e.clientX, e.clientY], 20,container, 1) arr[iCount] = []; // 每點擊一次,增加一個二位數組 $(container).on(’mousemove’, function(e) { e = e || window.event; boom.init([e.clientX, e.clientY], 20, container, 1) arr[iCount].push([e.clientX, e.clientY]) // 鼠標每移動一次,添加鼠標位置 }) $(container).on(’mouseup’, function() { $(container).off(’mousemove’) })});// 重繪$(’#repaint’).click(function() { // console.log(arr) if( !arr.length ){ return; } var tempArr= []; // 將所有點取出來,轉換為二維數組 for(var i = 0; i < arr.length; i++){ for(var j = 0; j< arr[i].length; j++){ tempArr.push(arr[i][j]) } } var count = 0; var timmer = setInterval(function(){ if( ++ count >= tempArr.length){ clearInterval(timmer) } boom.init(tempArr[count],20,container,1) },16)});$(’#zero’).click(function(){ iCount=-1; arr=[]});

煙花節點可以用背景圖代替,比如用小愛心或者五角星啥的,只是大小得適當調整。

更多JavaScript精彩特效分享給大家:

Javascript菜單特效大全

javascript仿QQ特效匯總

JavaScript時鐘特效匯總

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲成人va| 美女精品在线| 欧美天堂一区二区| 日韩精品乱码av一区二区| 日韩精品高清不卡| 国产精品午夜av| 国产欧美日韩影院| 欧美激情日韩| 中文在线资源| 亚洲五月婷婷| 中文字幕免费一区二区| 国产毛片久久久| 国产精品久久久久蜜臀| 久久精品观看| 综合一区二区三区| 欧美激情网址| 久久久久91| 中文字幕日韩亚洲| 国产一区二区三区视频在线| 欧美特黄一级大片| 日日夜夜免费精品| 九九99久久精品在免费线bt| 久久一区二区三区电影| 免费在线观看不卡| 鲁大师精品99久久久| 肉色欧美久久久久久久免费看| 欧美成人午夜| 日韩欧美激情| 国产99久久| 人人精品久久| 日韩欧美二区| 综合激情一区| 精品国模一区二区三区| 亚洲精品在线国产| 国产一区二区三区探花| 亚洲免费毛片| 国内不卡的一区二区三区中文字幕| 丝袜亚洲另类欧美| 亚洲专区一区| 国产精品蜜月aⅴ在线| av最新在线| 亚洲精选91| 亚洲天堂资源| 亚洲人成毛片在线播放女女| 精品三区视频| 免费看黄色91| 日韩精品第一区| 日韩极品在线观看| 999国产精品视频| 久久99免费视频| 视频一区二区欧美| 国产+成+人+亚洲欧洲在线| 中文一区一区三区免费在线观 | 亚洲ab电影| 日韩国产在线| 麻豆免费精品视频| 亚洲精品乱码| 在线视频观看日韩| 久久这里只有| 日韩三级精品| 在线亚洲观看| 色在线中文字幕| 免费在线亚洲欧美| 婷婷综合电影| 日韩精品社区| 中文字幕人成乱码在线观看| 亚洲精品乱码久久久久久蜜桃麻豆 | 欧美一区91| 日韩高清不卡| 国际精品欧美精品| 国产精品v亚洲精品v日韩精品| 国产精品字幕| 国产一区福利| 国产精品亚洲综合色区韩国| 一本综合精品| 久久福利精品| 男女精品网站| 成人在线免费观看网站| 国产亚洲欧美日韩精品一区二区三区 | 国产二区精品| 黄色网一区二区| 国产精品主播| 日韩精品久久理论片| 99热精品在线| 久久精品国产大片免费观看| 欧美精品高清| 99视频精品全部免费在线视频| 久久久91麻豆精品国产一区| 在线看片不卡| 精品资源在线| 精品一区二区三区中文字幕在线| 国产精品99精品一区二区三区∴| 青青国产精品| 国产欧美日韩精品一区二区三区| 日韩不卡手机在线v区| 美日韩精品视频| 国产午夜久久| 久久亚洲风情| 伊人精品久久| 日韩国产在线观看| 日韩视频二区| 天海翼精品一区二区三区| 综合欧美亚洲| 亚洲精品日韩久久| 国产探花一区在线观看| 国产专区精品| 精品三级久久| 99视频精品| 日韩国产在线观看| 国产午夜久久av| 国产美女久久| 国产高清不卡| 国产精品美女久久久浪潮软件| 亚洲视频二区| 美女视频黄免费的久久| 国产福利片在线观看| 欧美日韩黑人| 亚洲欧美一级| 精品99在线| 国产亚洲毛片在线| 日韩精品导航| 不卡专区在线| 国产亚洲福利| 国产剧情在线观看一区| 日韩欧美一区二区三区在线视频 | 欧美a级一区二区| 日韩av中文字幕一区| 国产婷婷精品| 伊伊综合在线| 精品一区二区三区免费看| 久久国产中文字幕| 国产日韩欧美一区在线| 久久爱www成人| 亚洲成a人片| 欧洲毛片在线视频免费观看| 免费在线观看不卡| 精品视频网站| 男人操女人的视频在线观看欧美| 国产精品亚洲综合色区韩国| 日韩免费福利视频| 亚洲精品中文字幕99999| 奇米狠狠一区二区三区| 国产一区二区三区国产精品| 欧美日韩国产一区二区三区不卡| 婷婷精品久久久久久久久久不卡| 欧美aaaaaa午夜精品| 免费观看亚洲| 日本不卡视频在线观看| 中文字幕在线免费观看视频| 亚洲综合中文| 国产白浆在线免费观看| 野花国产精品入口| 另类综合日韩欧美亚洲| 免费不卡在线视频| 四季av一区二区凹凸精品| 99在线|亚洲一区二区| 欧美精品1区| 中文日韩欧美| se01亚洲视频 | 国产精品99久久久久久董美香| 日本一区二区高清不卡| 日韩精品一卡二卡三卡四卡无卡| 国产精品国码视频| 久久精品播放| 国产精品啊v在线| 亚洲在线免费| 国产夫妻在线| 欧美日韩一区二区三区不卡视频| 日韩中文字幕高清在线观看| 青青伊人久久| 日韩午夜av| 国产白浆在线免费观看| 蜜臀av一区二区在线免费观看| 久久精品一区二区三区中文字幕| 欧美va亚洲va日韩∨a综合色| 免费在线观看一区| 亚洲三级精品| 午夜国产精品视频| 国产精品高潮呻吟久久久久| 亚洲婷婷免费| 国产精品欧美一区二区三区不卡| 久久先锋影音| 日本 国产 欧美色综合| 久久字幕精品一区| 日韩激情综合| 欧美日韩精品免费观看视欧美高清免费大片 | 日韩三区在线| 欧美在线精品一区| 美女久久久久久| 日韩中文字幕91| 国产99久久久国产精品成人免费| 卡一精品卡二卡三网站乱码| 亚洲精品免费观看| 美女日韩在线中文字幕| 高清av不卡| 精品亚洲自拍| 亚洲午夜免费| 亚洲成人精选| 久久免费高清| 日韩欧美另类一区二区|