本文最后更新于 3190 天前,其中的信息可能已经有所发展或是发生改变。
看网站顶上那堆往上飘的球就知道效果了→_→
或者看下面,就是酱紫:
添加方法:
先把下面的js代码引入网页(搞成js文件比较好哈):
(function() { var width, height, largeHeader, canvas, ctx, circles, target, animateHeader = true; // Main initHeader(); addListeners(); function initHeader() { width = window.innerWidth; height = document.getElementById('banner').offsetHeight; target = {x: 0, y: height}; largeHeader = document.getElementById('banner'); largeHeader.style.height = height+'px'; canvas = document.getElementById('demo-canvas'); canvas.width = width; canvas.height = height; ctx = canvas.getContext('2d'); // create particles circles = []; for(var x = 0; x < width*0.8; x++) { var c = new Circle(); circles.push(c); } animate(); } // Event handling function addListeners() { window.addEventListener('scroll', scrollCheck); window.addEventListener('resize', resize); } function scrollCheck() { if(document.body.scrollTop > height) animateHeader = false; else animateHeader = true; } function resize() { width = window.innerWidth; height = document.getElementById('banner').offsetHeight; largeHeader.style.height = height+'px'; canvas.width = width; canvas.height = height; } function animate() { if(animateHeader) { ctx.clearRect(0,0,width,height); for(var i in circles) { circles[i].draw(); } } requestAnimationFrame(animate); } // Canvas manipulation function Circle() { var _this = this; // constructor (function() { _this.pos = {}; init(); console.log(_this); })(); function init() { _this.pos.x = Math.random()*width; _this.pos.y = height+Math.random()*100; _this.alpha = 0.3+Math.random()*0.3; _this.scale = 0.3+Math.random()*0.3; _this.velocity = Math.random(); } this.draw = function() { if(_this.alpha <= 0) { init(); } _this.pos.y -= _this.velocity; _this.alpha -= 0.0005; ctx.beginPath(); ctx.arc(_this.pos.x, _this.pos.y, _this.scale*10, 0, 2 * Math.PI, false); ctx.fillStyle = 'rgba(255,200,255,'+ _this.alpha+')'; ctx.fill(); }; } })();
然后,在banner的div结束前加入以下遮罩代码:
<canvas class="demo-canvas" id="demo-canvas"></canvas>
(不要吐槽id名23333)
然后就全部搞定啦~
简直是CPU的灾难23333
意料之内的卡炸
次一点的服务器估计就跑满了
没看懂诶w
谢谢分享!!!
感谢大佬的分享