aboutsummaryrefslogtreecommitdiffstats
path: root/js/arrows.js
diff options
context:
space:
mode:
Diffstat (limited to 'js/arrows.js')
-rw-r--r--js/arrows.js37
1 files changed, 37 insertions, 0 deletions
diff --git a/js/arrows.js b/js/arrows.js
new file mode 100644
index 0000000..a23af87
--- /dev/null
+++ b/js/arrows.js
@@ -0,0 +1,37 @@
+
+arrows = [];
+
+const minSpeed = 3;
+const maxSpeed = 8;
+const delay = 1500;
+const lifetime = 25000;
+
+function make_arrow() {
+ const svg = document.getElementById("protoarrow").cloneNode();
+ svg.style.left = Math.random() * 100 + '%';
+ svg.style.display = 'block';
+ document.getElementById('arrows').append(svg);
+ const ob = {
+ y: -800,
+ svg: svg,
+ speed: Math.random() * (maxSpeed - minSpeed) + minSpeed
+ };
+ arrows.push(ob);
+ setTimeout(make_arrow, delay);
+ setTimeout(() => {
+ svg.remove();
+ arrows.remove(ob);
+ }, lifetime);
+}
+
+function update() {
+ for (const arrow of arrows) {
+ arrow.y += arrow.speed;
+ arrow.svg.style.bottom = arrow.y + 'px';
+ }
+
+ window.requestAnimationFrame(update);
+}
+
+make_arrow();
+update();