這篇文章給大家分享的是有關JS怎么實現(xiàn)煙花爆炸效果的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
桑植ssl適用于網(wǎng)站、小程序/APP、API接口等需要進行數(shù)據(jù)傳輸應用場景,ssl證書未來市場廣闊!成為創(chuàng)新互聯(lián)的ssl證書銷售渠道,可以享受市場價格4-6折優(yōu)惠!如果有意向歡迎電話聯(lián)系或者加微信:18980820575(備注:SSL證書合作)期待與您的合作!具體內(nèi)容如下
<!DOCTYPE html> <html> <head lang="en"> <meta charset="UTF-8"> <title></title> <style> * { margin: 0; padding: 0; } html, body { width: 100%; height: 100%; background-color: black; overflow: hidden; } </style> </head> <body> <canvas id="canvas"></canvas> <script> var canvas = document.getElementById("canvas"); canvas.width = window.innerWidth; canvas.height = window.innerHeight; var content2d = canvas.getContext("2d"); var balls = []; //存儲對象 //小球的基本屬性 function ball() { this.x = null; this.y = null; this.angle = null; this.vx=null; this.vy=null; this.r = null; this.color = null; this.init = function (x, y) { //初始化屬性值 this.x = x; this.y = y; //隨機角度 this.angle = Math.random() * Math.PI * 2; //隨機小球的大小 this.r = this.randomNum(10,25); this.vx=(this.randomNum(6,12)+Math.random()*0.5)*Math.cos(this.angle); this.vy=(this.randomNum(6,12)+Math.random()*0.5)*Math.sin(this.angle); this.color = this.randomColor(); }; //隨機小球顏色 this.randomColor = function () { return "#" + parseInt(Math.random() * 16777216).toString(16); }; //隨機大小 this.randomNum = function (min, max) { return Math.random() * max + min; }; //重繪時需移動 this.move=function(){ this.x+=this.vx; this.y+=this.vy; this.r-=0.3; this.vx*=0.93; this.vy*=0.93; } } //創(chuàng)建小球 function createBall(x, y) { var count = parseInt(Math.random() * 30 + 10); for (var i = 0; i < count; i++) { var b = new ball(); b.init(x, y); balls.push(b); } } //畫小球 function Draw(){ for(var i=0;i<balls.length;i++){ var circle=balls[i]; circle.move(); content2d.beginPath(); content2d.fillStyle=circle.color; content2d.arc(circle.x,circle.y,circle.r,0,Math.PI*2); content2d.fill(); content2d.closePath(); } } //移除小球 function removeBall(){ for(var i=0;i<balls.length;i++){ var circle=balls[i]; if(circle.r<0.3){ balls.splice(i,1); i--; } } } //計時器,即重繪 loop(); function loop(){ //清除整個canvas content2d.clearRect(0,0,canvas.width,canvas.height); Draw(); removeBall(); window.requestAnimationFrame(loop); } canvas.onmouseup = function (e) { var x = e.pageX; var y = e.pageY; createBall(x, y); } </script> </body> </html>
感謝各位的閱讀!關于“JS怎么實現(xiàn)煙花爆炸效果”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
當前標題:JS怎么實現(xiàn)煙花爆炸效果-創(chuàng)新互聯(lián)
瀏覽地址:http://aaarwkj.com/article44/ccpshe.html
成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供做網(wǎng)站、域名注冊、網(wǎng)站策劃、響應式網(wǎng)站、建站公司、軟件開發(fā)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉載,或轉載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容