小編給大家分享一下js模擬如何實(shí)現(xiàn)煙花特效,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)基于成都重慶香港及美國(guó)等地區(qū)分布式IDC機(jī)房數(shù)據(jù)中心構(gòu)建的電信大帶寬,聯(lián)通大帶寬,移動(dòng)大帶寬,多線(xiàn)BGP大帶寬租用,是為眾多客戶(hù)提供專(zhuān)業(yè)綿陽(yáng)電信機(jī)房機(jī)柜租用報(bào)價(jià),主機(jī)托管價(jià)格性?xún)r(jià)比高,為金融證券行業(yè)服務(wù)器托管,ai人工智能服務(wù)器托管提供bgp線(xiàn)路100M獨(dú)享,G口帶寬及機(jī)柜租用的專(zhuān)業(yè)成都idc公司。
如下圖
首先描繪圓周運(yùn)動(dòng)
// d1 /*css*/ div{ height: 4px; width: 4px; background: red; position: absolute; } //js var div = document.getElementById('div'); // 畫(huà)運(yùn)動(dòng)點(diǎn) document.getElementsByTagName('body')[0].appendChild(tdiv); // 添加節(jié)點(diǎn) var deg = 0; // 運(yùn)動(dòng)角度 var r = 100; // 半徑 var center = [300, 300] // 圓心 var dd = Math.PI/180; // PI和角度之間的轉(zhuǎn)換 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);
以上代碼運(yùn)行后可以看到一個(gè)圓周運(yùn)動(dòng)紅色方塊
完成上述步驟后,有什么用呢?
煙花的綻放,想象一下,可以當(dāng)成很多方塊從一個(gè)從圓心開(kāi)始向四周擴(kuò)算的一種運(yùn)動(dòng)方式。
一束煙花,有10個(gè)綻放點(diǎn),那就是每隔360 / 10 = 36度,就有一條運(yùn)動(dòng)軌跡。
這樣就好辦了
// d2 var divs = []; // 保存煙花節(jié)點(diǎn) var len = 10; // 煙花節(jié)點(diǎn)個(gè)數(shù) var temp = 360 / len; // 運(yùn)動(dòng)軌跡所隔角度 for(var i = 0; i < len; i++){ var tdiv = document.createElement('div'); var tr1 = r; // 半徑 var deg = i * temp; // 當(dāng)前軌跡所在的角度值 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 = { // 存放節(jié)點(diǎn)的位置信息 deg : deg, r : tr1, left : left, top : topLen }; document.getElementsByTagName('body')[0].appendChild(tdiv); divs.push(tdiv); }
上述代碼運(yùn)行后可以看到
看起來(lái)是有點(diǎn)煙花的意思了,但是煙花的運(yùn)動(dòng)軌跡可沒(méi)這么工整,同一個(gè)地點(diǎn)出發(fā),同一個(gè)地點(diǎn)結(jié)束。
而這個(gè)結(jié)束點(diǎn)就是半徑的長(zhǎng)度值,所以只需將半徑進(jìn)行變化就可打亂。
// d3 function getRanR(a,b){ // 隨機(jī)得到a-b的值 return Math.floor(Math.random()*(b-a+1)+a); }
將for循環(huán)里的 tr1 改為 getRanR(0,200);
就可看到下圖
看著很亂,完全沒(méi)點(diǎn)煙花的樣子。沒(méi)關(guān)系,讓它運(yùn)動(dòng)起來(lái)就可以看出來(lái)了。
為了讓這個(gè)動(dòng)起來(lái)就要讓上面 d2 的js代碼進(jìn)行修改。讓各個(gè)節(jié)點(diǎn)的起始位置為圓心。同時(shí)為了省點(diǎn)力,用css3進(jìn)行運(yùn)動(dòng)。
/*css*/ div{ height: 4px; width: 4px; background: red; position: absolute; transition: 1s all; // 就添加這一句 } // js tdiv.style.left = center[0] +'px'; tdiv.style.top = center[1] +'px';
運(yùn)動(dòng)軌跡從 d2 可以看出來(lái)已經(jīng)全部存放到了節(jié)點(diǎn)里。用divs可以拿到各個(gè)節(jié)點(diǎn)。所以只需操作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'; }
運(yùn)動(dòng)如下圖:
這樣就可以看到一個(gè)簡(jiǎn)易的煙花效果。就這么一個(gè)簡(jiǎn)易的煙花連續(xù)起來(lái)就可達(dá)到圖1的效果。
所以首先要對(duì)這個(gè)簡(jiǎn)易的煙花效果進(jìn)行封裝。
動(dòng)畫(huà)方面為了方便操作,所以引入jquery。
以下為html + css
JS部分
var boom = { init: function (center, len, container, type) { this.len = len || 20; // 煙花節(jié)點(diǎn)個(gè)數(shù) this.maxR = 100; // 最大半徑 this.speed = 1500; // 速度 this.divs = []; // 存放煙花節(jié)點(diǎn) this.center = center; // 圓心 this.type = type; // 類(lèi)型 this.container = container; // 容器 this.paint(); }, getRanR: function (a, b) { // 得到隨機(jī)數(shù) return Math.floor(Math.random() * (b - a + 1 )+ a); }, // 畫(huà)出煙花節(jié)點(diǎn)所在點(diǎn),以及保存去往點(diǎn)信息 // 圓心, 半徑, 容器, 類(lèi)型 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; // 當(dāng)前軌跡所在的角度值 var cc = []; // 節(jié)點(diǎn)的結(jié)束點(diǎn) var tr = that.getRanR(0, that.maxR); // 半徑 var left = 0; // 煙花節(jié)點(diǎn)所在的位置 var topLen = 0; // 煙花節(jié)點(diǎn)所在的位置 var xCenter = center[0], yCenter = center[1]; if (type) { // 當(dāng)類(lèi)型為真時(shí),整個(gè)煙花效果就是向外擴(kuò)張 left = xCenter; // 為假時(shí)則是向內(nèi)收縮,本質(zhì)一樣都是拿到開(kāi)始點(diǎn)和結(jié)束點(diǎn) topLen = yCenter; // 只是將開(kāi)始和結(jié)束換了個(gè)位置 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], // 節(jié)點(diǎn)的結(jié)束點(diǎn) top: cc[1], // 節(jié)點(diǎn)的結(jié)束點(diǎn) } that.divs.push(div); container.appendChild(div); } // 使節(jié)點(diǎn)運(yùn)動(dòng)起來(lái) that.move(); }, // 運(yùn)動(dòng) 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() { // 運(yùn)動(dòng)完結(jié)后刪除節(jié)點(diǎn) this.parentNode.removeChild(this); }); } } }
控制特效
var container = $('#container')[0]; var arr = []; // 存放鼠標(biāo)點(diǎn)擊位置 var iCount = -1; $(container).on('mousedown', function(e) { iCount++; e = e || window.event; boom.init([e.clientX, e.clientY], 20,container, 1) arr[iCount] = []; // 每點(diǎn)擊一次,增加一個(gè)二位數(shù)組 $(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]) // 鼠標(biāo)每移動(dòng)一次,添加鼠標(biāo)位置 }) $(container).on('mouseup', function() { $(container).off('mousemove') }) }); // 重繪 $('#repaint').click(function() { // console.log(arr) if( !arr.length ){ return; } var tempArr= []; // 將所有點(diǎn)取出來(lái),轉(zhuǎn)換為二維數(shù)組 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=[] });
煙花節(jié)點(diǎn)可以用背景圖代替,比如用小愛(ài)心或者五角星啥的,只是大小得適當(dāng)調(diào)整。
1.可以使網(wǎng)頁(yè)具有交互性,例如響應(yīng)用戶(hù)點(diǎn)擊,給用戶(hù)提供更好的體驗(yàn)。 2.可以處理表單,檢驗(yàn)用戶(hù)的輸入,并提供及時(shí)反饋節(jié)省用戶(hù)時(shí)間。 3.可以根據(jù)用戶(hù)的操作,動(dòng)態(tài)的創(chuàng)建頁(yè)面。 4使用JavaScript可以通過(guò)設(shè)置cookie存儲(chǔ)在瀏覽器上的一些臨時(shí)信息。
以上是“js模擬如何實(shí)現(xiàn)煙花特效”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!