portfolio/src/static/floater.js
2025-04-17 22:36:58 +02:00

16 lines
No EOL
523 B
JavaScript

function clamp(value, min, max) { return Math.max( min, Math.min(value, max) ); }
const body = document.querySelector('body');
const beams = document.querySelector(".beams");
window.addEventListener("scroll", function(){
const floaters = document.querySelectorAll(".floater");
const yPos = window.scrollY / window.innerHeight;
for (const floater of floaters) {
floater.style.top = yPos*50 + "%";
}
beams.style.opacity = 1-2*yPos;
beams.style.display = 1-2*yPos < 0 ? 'none' : 'block'
});