色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

js實(shí)現(xiàn)點(diǎn)擊煙花特效

瀏覽:91日期:2024-04-16 13:57:14

代碼:

<script type='text/javascript'>function clickEffect() { let balls = []; let longPressed = false; let longPress; let multiplier = 0; let width, height; let origin; let normal; let ctx; const colours = ['#F73859', '#14FFEC', '#00E0FF', '#FF99FE', '#FAF15D']; const canvas = document.createElement('canvas'); document.body.appendChild(canvas); canvas.setAttribute('style', 'width: 100%; height: 100%; top: 0; left: 0; z-index: 99999; position: fixed; pointer-events: none;'); const pointer = document.createElement('span'); pointer.classList.add('pointer'); document.body.appendChild(pointer); if (canvas.getContext && window.addEventListener) { ctx = canvas.getContext('2d'); updateSize(); window.addEventListener(’resize’, updateSize, false); loop(); window.addEventListener('mousedown', function(e) { pushBalls(randBetween(10, 20), e.clientX, e.clientY); document.body.classList.add('is-pressed'); longPress = setTimeout(function() {document.body.classList.add('is-longpress');longPressed = true; }, 500); }, false); window.addEventListener('mouseup', function(e) { clearInterval(longPress); if (longPressed == true) {document.body.classList.remove('is-longpress');pushBalls(randBetween(50 + Math.ceil(multiplier), 100 + Math.ceil(multiplier)), e.clientX, e.clientY);longPressed = false; } document.body.classList.remove('is-pressed'); }, false); window.addEventListener('mousemove', function(e) { let x = e.clientX; let y = e.clientY; pointer.style.top = y + 'px'; pointer.style.left = x + 'px'; }, false); } else { console.log('canvas or addEventListener is unsupported!'); } function updateSize() { canvas.width = window.innerWidth * 2; canvas.height = window.innerHeight * 2; canvas.style.width = window.innerWidth + ’px’; canvas.style.height = window.innerHeight + ’px’; ctx.scale(2, 2); width = (canvas.width = window.innerWidth); height = (canvas.height = window.innerHeight); origin = { x: width / 2, y: height / 2 }; normal = { x: width / 2, y: height / 2 }; } class Ball { constructor(x = origin.x, y = origin.y) { this.x = x; this.y = y; this.angle = Math.PI * 2 * Math.random(); if (longPressed == true) {this.multiplier = randBetween(14 + multiplier, 15 + multiplier); } else {this.multiplier = randBetween(6, 12); } this.vx = (this.multiplier + Math.random() * 0.5) * Math.cos(this.angle); this.vy = (this.multiplier + Math.random() * 0.5) * Math.sin(this.angle); this.r = randBetween(8, 12) + 3 * Math.random(); this.color = colours[Math.floor(Math.random() * colours.length)]; } update() { this.x += this.vx - normal.x; this.y += this.vy - normal.y; normal.x = -2 / window.innerWidth * Math.sin(this.angle); normal.y = -2 / window.innerHeight * Math.cos(this.angle); this.r -= 0.3; this.vx *= 0.9; this.vy *= 0.9; } } function pushBalls(count = 1, x = origin.x, y = origin.y) { for (let i = 0; i < count; i++) { balls.push(new Ball(x, y)); } } function randBetween(min, max) { return Math.floor(Math.random() * max) + min; } function loop() { ctx.fillStyle = 'rgba(255, 255, 255, 0)'; ctx.clearRect(0, 0, canvas.width, canvas.height); for (let i = 0; i < balls.length; i++) { let b = balls[i]; if (b.r < 0) continue; ctx.fillStyle = b.color; ctx.beginPath(); ctx.arc(b.x, b.y, b.r, 0, Math.PI * 2, false); ctx.fill(); b.update(); } if (longPressed == true) { multiplier += 0.2; } else if (!longPressed && multiplier >= 0) { multiplier -= 0.4; } removeBall(); requestAnimationFrame(loop); } function removeBall() { for (let i = 0; i < balls.length; i++) { let b = balls[i]; if (b.x + b.r < 0 || b.x - b.r > width || b.y + b.r < 0 || b.y - b.r > height || b.r < 0) {balls.splice(i, 1); } } }}clickEffect();//調(diào)用</script>

效果:

js實(shí)現(xiàn)點(diǎn)擊煙花特效

以上就是js實(shí)現(xiàn)點(diǎn)擊煙花特效的詳細(xì)內(nèi)容,更多關(guān)于js 煙花特效的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 男人操女人逼逼视频 | 久久影院在线 | 手机看片自拍自自拍日韩免费 | 国产精品高清视亚洲一区二区 | 91在线免费公开视频 | 久久久免费观成人影院 | 一区二区国产精品 | 日韩精品另类天天更新影院 | 最刺激黄a大片免费观看 | 亚洲欧美久久精品一区 | 精品国产欧美另类一区 | 18成人免费观看网站入口 | 成人影院久久久久久影院 | 国产精品成人一区二区三区 | 不卡一区二区在线观看 | 久草视频免费看 | 亚洲一级毛片中文字幕 | 精品一区二区三区视频在线观看免 | 中文字幕一区二区精品区 | 亚洲国产精品自产拍在线播放 | 国内精品免费一区二区观看 | 黄色毛片a | 全部精品孕妇色视频在线 | 波多野结衣手机视频一区 | 国产福利微拍精品一区二区 | 免费一级视频在线播放 | 精品一区二区三区亚洲 | 性视频网站在线 | 国产九九精品 | 99热在线获取最新地址 | 欧美高清在线精品一区二区不卡 | 深夜福利国产 | 成年片人免费www | 国产午夜精品久久理论片小说 | 国产91精品久久久久久久 | 国产三级做爰在线观看∵ | 精品亚洲一区二区三区 | 中文字幕在线免费观看视频 | 国产操操 | 国产成人yy精品1024在线 | 国产成人亚洲综合网站不卡 |