Added heart spray on click as a gimmick

master
Toerd@480 5 years ago
parent 5925e572e3
commit 7ee0ebe302

@ -303,6 +303,26 @@ nav {
margin-left: calc(var(--h-info) * 0.25 * -0.70); margin-left: calc(var(--h-info) * 0.25 * -0.70);
} }
#avatar:hover {
cursor: pointer;
}
.wobble {
animation: wob 1s infinite;
}
@keyframes wob {
0% {
transform: scale(1.0) rotate(0deg);
}
50% {
transform: scale(0.8);
}
100% {
transform: scale(1.0) rotate(360deg);
}
}
.flying-text { .flying-text {
display: inline-block; display: inline-block;
position: absolute; position: absolute;

@ -30,6 +30,11 @@ function initialize() {
runTextAnimation = true; runTextAnimation = true;
flyingText(welcome); flyingText(welcome);
hideElement(overlay); hideElement(overlay);
} else if (curr.id === "avatar") {
curr.classList.add("wobble");
for (let i = 0; i < 10; ++i)
shootText(welcome, 3, "♥");
setTimeout(() => {curr.classList.remove("wobble");}, 2000);
} }
}); });

@ -1,15 +1,24 @@
/* /*
* text.js * text.js
* function for the purpose of my portfolio to animate welcome text * function for the purpose of my portfolio to animate welcome text
* Author: phga/teord * Author: phga/teord
* Date: 2019-10-23 * Date: 2019-10-23
* Version: 1.0 * Version: 1.0
*/ */
// set a global var "run" to true before running this function // set a global var "run" to true before running this function
"use strict"; "use strict";
async function flyingText(canvas) { async function flyingText(canvas) {
canvas.classList.remove("hidden");
while (runTextAnimation) {
// wait till ele is rdy in dom + time between spawns
await shootText(canvas, 4);
}
}
async function shootText(canvas, sec, sta) {
// TODO: move to argument, load from backend // TODO: move to argument, load from backend
let statements = ["Keyboard-Nerd", "🖤", "Emacs", let statements = sta || ["Keyboard-Nerd", "🖤", "Emacs",
"Lives in VI", "GNU/Linux", "Arch Linux", "Lives in VI", "GNU/Linux", "Arch Linux",
"Computer Science", "Design", "Computer Science", "Design",
"Javascript", "C/C++", "Go", "Bash", "Javascript", "C/C++", "Go", "Bash",
@ -28,43 +37,36 @@ async function flyingText(canvas) {
"Winter is coming!", "😺 Person"]; "Winter is coming!", "😺 Person"];
let stCount = statements.length; let stCount = statements.length;
let animationTime = 4; let animationTime = sec;
let maxX , maxY, x, y; let maxX , maxY, x, y;
// Browser resize
maxX = canvas.offsetWidth / 2;
maxY = canvas.offsetHeight / 2;
canvas.classList.remove("hidden"); let curr = document.createElement("p");
curr.innerHTML = statements[getRand(stCount)];
while (runTextAnimation) { curr.className = "flying-text";
// Browser resize curr.style.transition = `${animationTime}s ease-in`;
maxX = canvas.offsetWidth / 2;
maxY = canvas.offsetHeight / 2;
let curr = document.createElement("p"); // Get random position + correction to not touch middle to much
curr.innerHTML = statements[getRand(stCount)]; x = getRand(maxX * 0.2, maxX);
curr.className = "flying-text"; y = getRand(maxY * 0.45, maxY);
curr.style.transition = `${animationTime}s ease-in`;
// Get random position + correction to not touch middle to much // Random direction and correction to not touch right border
x = getRand(maxX * 0.2, maxX); x = (getRand(2) == 1) ? -1*x : 0.3 * x;
y = getRand(maxY * 0.45, maxY); y = (getRand(2) == 1) ? -1*y : 0.8 * y;
// Random direction and correction to not touch right border canvas.appendChild(curr);
x = (getRand(2) == 1) ? -1*x : 0.3 * x; await sleep(1000);
y = (getRand(2) == 1) ? -1*y : 0.8 * y;
canvas.appendChild(curr); // add the stuff that should be animated (transition in class)
curr.style.transform = `translate(${x}px, ${y}px)`;
curr.style.fontSize = `${Math.random() + Math.random() + 1.0}vw`;
// wait till ele is rdy in dom + time between spawns // wait to remove it (async)
await sleep(1000); setTimeout(() => {
curr.remove();
// add the stuff that should be animated (transition in class) }, animationTime * 1000 + 2000);
curr.style.transform = `translate(${x}px, ${y}px)`;
curr.style.fontSize = `${Math.random() + Math.random() + 1.0}vw`;
// wait to remove it (async)
setTimeout(() => {
curr.remove();
}, animationTime * 1000 + 2000);
}
} }
function getRand(max, min) { function getRand(max, min) {

Loading…
Cancel
Save