mirror of
https://github.com/mudler/LocalAI.git
synced 2025-01-20 19:49:33 +00:00
chore(ux): allow to create and drag dots in the animation (#3287)
Make the animation more interactive! Signed-off-by: Ettore Di Giacinto <mudler@localai.io>
This commit is contained in:
parent
73c9b3598d
commit
0c84c7b1cc
@ -1,29 +1,46 @@
|
|||||||
const canvas = document.getElementById('networkCanvas');
|
const canvas = document.getElementById('networkCanvas');
|
||||||
const ctx = canvas.getContext('2d');
|
const ctx = canvas.getContext('2d');
|
||||||
|
|
||||||
canvas.width = window.innerWidth;
|
let particles = [];
|
||||||
canvas.height = window.innerHeight;
|
let isDragging = false;
|
||||||
|
let dragParticle = null;
|
||||||
|
const maxParticles = 100; // Maximum number of particles
|
||||||
|
const dragAreaRadius = 10; // Increased area for easier dragging
|
||||||
|
|
||||||
const particles = [];
|
// Function to resize canvas based on aspect ratio
|
||||||
const lines = [];
|
function resizeCanvas() {
|
||||||
|
canvas.width = window.innerWidth;
|
||||||
|
canvas.height = Math.min(window.innerHeight, 400); // Maintain a max height of 400px
|
||||||
|
}
|
||||||
|
|
||||||
|
// Adjust the canvas size when the window resizes
|
||||||
|
window.addEventListener('resize', resizeCanvas);
|
||||||
|
|
||||||
|
// Initialize canvas size
|
||||||
|
resizeCanvas();
|
||||||
|
|
||||||
class Particle {
|
class Particle {
|
||||||
constructor(x, y) {
|
constructor(x, y) {
|
||||||
this.x = x;
|
this.x = x;
|
||||||
this.y = y;
|
this.y = y;
|
||||||
this.radius = 2 + Math.random() * 2;
|
this.radius = 4;
|
||||||
this.color = `rgba(0, 255, 204, ${Math.random()})`;
|
this.color = `rgba(0, 255, 204, 1)`;
|
||||||
this.speed = Math.random() * 2 + 1;
|
this.speedX = (Math.random() - 0.5) * 2; // Random horizontal speed
|
||||||
this.angle = Math.random() * Math.PI * 2;
|
this.speedY = (Math.random() - 0.5) * 2; // Random vertical speed
|
||||||
}
|
}
|
||||||
|
|
||||||
update() {
|
update() {
|
||||||
this.x += Math.cos(this.angle) * this.speed;
|
if (!isDragging || dragParticle !== this) {
|
||||||
this.y += Math.sin(this.angle) * this.speed;
|
this.x += this.speedX;
|
||||||
|
this.y += this.speedY;
|
||||||
|
|
||||||
if (this.x < 0 || this.x > canvas.width || this.y < 0 || this.y > canvas.height) {
|
// Bounce off the edges of the canvas
|
||||||
this.x = Math.random() * canvas.width;
|
if (this.x < 0 || this.x > canvas.width) {
|
||||||
this.y = Math.random() * canvas.height;
|
this.speedX *= -1;
|
||||||
|
}
|
||||||
|
if (this.y < 0 || this.y > canvas.height) {
|
||||||
|
this.speedY *= -1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -33,6 +50,11 @@ class Particle {
|
|||||||
ctx.fillStyle = this.color;
|
ctx.fillStyle = this.color;
|
||||||
ctx.fill();
|
ctx.fill();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
isMouseOver(mouseX, mouseY) {
|
||||||
|
// Increase the draggable area by checking if the mouse is within a larger radius
|
||||||
|
return Math.hypot(mouseX - this.x, mouseY - this.y) < dragAreaRadius;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
function connectParticles() {
|
function connectParticles() {
|
||||||
@ -69,5 +91,54 @@ function animate() {
|
|||||||
requestAnimationFrame(animate);
|
requestAnimationFrame(animate);
|
||||||
}
|
}
|
||||||
|
|
||||||
initParticles(100);
|
// Handle mouse click to create a new particle
|
||||||
|
canvas.addEventListener('click', (e) => {
|
||||||
|
const rect = canvas.getBoundingClientRect();
|
||||||
|
const mouseX = e.clientX - rect.left;
|
||||||
|
const mouseY = e.clientY - rect.top;
|
||||||
|
|
||||||
|
const newParticle = new Particle(mouseX, mouseY);
|
||||||
|
particles.push(newParticle);
|
||||||
|
|
||||||
|
// Limit the number of particles to the maximum
|
||||||
|
if (particles.length > maxParticles) {
|
||||||
|
particles.shift(); // Remove the oldest particle
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle mouse down for dragging
|
||||||
|
canvas.addEventListener('mousedown', (e) => {
|
||||||
|
const rect = canvas.getBoundingClientRect();
|
||||||
|
const mouseX = e.clientX - rect.left;
|
||||||
|
const mouseY = e.clientY - rect.top;
|
||||||
|
|
||||||
|
for (let particle of particles) {
|
||||||
|
if (particle.isMouseOver(mouseX, mouseY)) {
|
||||||
|
isDragging = true;
|
||||||
|
dragParticle = particle;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle mouse move for dragging
|
||||||
|
canvas.addEventListener('mousemove', (e) => {
|
||||||
|
if (isDragging && dragParticle) {
|
||||||
|
const rect = canvas.getBoundingClientRect();
|
||||||
|
const mouseX = e.clientX - rect.left;
|
||||||
|
const mouseY = e.clientY - rect.top;
|
||||||
|
|
||||||
|
dragParticle.x = mouseX;
|
||||||
|
dragParticle.y = mouseY;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
// Handle mouse up to stop dragging
|
||||||
|
canvas.addEventListener('mouseup', () => {
|
||||||
|
isDragging = false;
|
||||||
|
dragParticle = null;
|
||||||
|
});
|
||||||
|
|
||||||
|
// Initialize and start the animation
|
||||||
|
initParticles(maxParticles);
|
||||||
animate();
|
animate();
|
Loading…
Reference in New Issue
Block a user