Toggle navigation
在线编辑器
在线代码
文本比较
jQuery下载
前端库
在线手册
登录/注册
下载代码
html
css
js
分享到微信朋友圈
X
html
css
* { margin: 0; padding: 0; box-sizing: border-box; background: black; } canvas { position: absolute; top: 50%; left: 50%; width: 572px; height: 352px; transform: translate(-50%, -50%); } footer, article { font-family: monospace; width: 100%; color: white; font-size: 15px; margin-left: 5px; text-shadow: 1px 1px 1px #737373; } article { padding: 10px; } footer { position: absolute; bottom: 0; width: 95%; text-align: left; padding-bottom: 15px; } footer a{ color: orangered; } article { width: 48%; font-size: 15px; }
JavaScript
const image = new Image(); image.src = ''; image.addEventListener('load', function(){ const canvas = document.getElementById('canvas1'); const ctx = canvas.getContext('2d'); canvas.width = 572; canvas.height = 352; let particlesArray = []; const numberOfParticles = 12000; const detail = 1; ctx.drawImage(image, 0, 0, canvas.width, canvas.height); const pixels = ctx.getImageData(0, 0, canvas.width, canvas.height); ctx.clearRect(0, 0, canvas.width, canvas.height); let grid = []; for (let y = 0; y < canvas.height; y += detail){ let row = []; for (let x = 0; x < canvas.width; x += detail){ const red = pixels.data[(y * 4 * pixels.width) + (x * 4)] const green = pixels.data[(y * 4 * pixels.width) + (x * 4 + 1)] const blue = pixels.data[(y * 4 * pixels.width) + (x * 4 + 2)] const color = 'rgb(' + red +',' + green + ',' + blue + ')'; const brightness = calculateBrightness(red, green, blue)/100; row.push(brightness); } grid.push(row); } class Particle { constructor(){ this.x = Math.random() * canvas.width; this.y = 0; //this.prevX = this.x; this.speed = 0; this.velocity = Math.random() * 0.7; this.size = Math.random() * 2 + .1; } update () { this.speed = grid[Math.floor(this.y / detail)][Math.floor(this.x / detail)]; let movement = (2.5 - this.speed) + this.velocity; this.y += movement; if (this.y >= canvas.height) { this.y = 0; this.x = Math.random() * canvas.width; } //console.log(this.x += movement) } draw(){ ctx.beginPath(); ctx.fillStyle = 'white'; ctx.arc(this.x, this.y, this.size, 0, 2 * Math.PI); ctx.fill(); } } function init(){ for (let i = 0; i < numberOfParticles; i++){ particlesArray.push(new Particle()); } } init(); function animate () { ctx.globalAlpha = 0.05; ctx.fillStyle = 'rgb(0, 0,0)'; ctx.fillRect(0, 0, canvas.width, canvas.height); ctx.globalAlpha = 0.2; for (let i = 0; i < particlesArray.length; i++) { particlesArray[i].update(); ctx.globalAlpha = particlesArray[i].speed * 0.3; particlesArray[i].draw(); } requestAnimationFrame( animate ); } animate(); function calculateBrightness(red, green, blue){ return Math.sqrt( (red * red) * 0.299 + (green * green) * 0.587 + (blue * blue) * 0.114 ); } });
粒子
时间
文字
hover
canvas
3d
游戏
音乐
火焰
水波
轮播图
鼠标跟随
动画
css
加载动画
导航
菜单
按钮
滑块
tab
弹出层
统计图
svg
×
Close
在线代码下载提示
开通在线代码永久免费下载,需支付20jQ币
开通后,在线代码模块中所有代码可终身免费下!
您已开通在线代码永久免费下载,关闭提示框后,点下载代码可直接下载!
您已经开通过在线代码永久免费下载
对不起,您的jQ币不足!可通过发布资源 或
直接充值获取jQ币
取消
开通下载
<!doctype html> <html> <head> <meta charset="utf-8"> <title>图片粒子雨-jq22.com</title> <script src="https://www.jq22.com/jquery/jquery-1.10.2.js"></script> <style>
</style> </head> <body>
<script>
</script>
</body> </html>
2012-2021 jQuery插件库版权所有
jquery插件
|
jq22工具库
|
网页技术
|
广告合作
|
在线反馈
|
版权声明
沪ICP备13043785号-1
浙公网安备 33041102000314号