-
Notifications
You must be signed in to change notification settings - Fork 268
/
Copy pathtrail.js
47 lines (39 loc) · 1.56 KB
/
trail.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
document.addEventListener('DOMContentLoaded', () => {
const coords = { x: 0, y: 0 };
const circles = [];
const colors = [
"#ffffff", "#ffffff", "#ffffff", "#ffffff", "#ffffff", "#ffffff",
"#ffffff", "#ffffff", "#f0f0f0", "#f0f0f0", "#f0f0f0", "#f0f0f0",
"#f0f0f0", "#f0f0f0", "#f0f0f0", "#f0f0f0", "#f0f0f0", "#f0f0f0",
"#f0f0f0", "#f0f0f0", "#f0f0f0", "#f0f0f0", "#f0f0f0"
];
for (let i = 0; i < colors.length; i++) {
const circle = document.createElement('div');
circle.className = 'circle';
circle.style.backgroundColor = colors[i];
document.body.appendChild(circle);
circles.push(circle);
}
window.addEventListener('mousemove', (e) => {
coords.x = e.clientX;
coords.y = e.clientY + window.scrollY;
});
function animateCircles() {
let x = coords.x;
let y = coords.y;
circles.forEach((circle, index) => {
circle.style.left = `${x}px`;
circle.style.top = `${y}px`;
const maxSize = 28;
const minSize = 5;
const size = maxSize - (index * ((maxSize - minSize) / (circles.length - 1)));
circle.style.width = `${size}px`;
circle.style.height = `${size}px`;
const nextCircle = circles[index + 1] || circles[0];
x += (parseInt(nextCircle.style.left || 0, 10) - x) * 0.3;
y += (parseInt(nextCircle.style.top || 0, 10) - y) * 0.3;
});
requestAnimationFrame(animateCircles);
}
animateCircles();
});