Files
PLG-MuDiCS/shared/splash_screen.html
T

487 lines
10 KiB
HTML

<div id="splash">
<svg id="splash-svg" class="fade-in" viewBox="0 0 950 550">
<!-- Paths -->
<!-- Disabled Paths -->
<path class="splash-stroke" d="M 385 350 V 270 H 100 V 112.5" />
<path class="splash-stroke" d="M 445 350 V 210 H 350 V 112.5" />
<path class="splash-stroke" d="M 505 350 V 210 H 600 V 112.5" />
<path class="splash-stroke" d="M 565 350 V 270 H 850 V 112.5" />
<!-- Masks -->
<defs>
<mask
id="m1"
maskUnits="userSpaceOnUse"
maskContentUnits="userSpaceOnUse"
>
<path
class="splash-mask"
pathLength="100"
d="M 385 350 V 270 H 100 V 112.5"
/>
</mask>
<mask
id="m2"
maskUnits="userSpaceOnUse"
maskContentUnits="userSpaceOnUse"
>
<path
class="splash-mask"
pathLength="100"
d="M 445 350 V 210 H 350 V 112.5"
/>
</mask>
<mask
id="m3"
maskUnits="userSpaceOnUse"
maskContentUnits="userSpaceOnUse"
>
<path
class="splash-mask"
pathLength="100"
d="M 505 350 V 210 H 600 V 112.5"
/>
</mask>
<mask
id="m4"
maskUnits="userSpaceOnUse"
maskContentUnits="userSpaceOnUse"
>
<path
class="splash-mask"
pathLength="100"
d="M 565 350 V 270 H 850 V 112.5"
/>
</mask>
</defs>
<!-- Active Paths -->
<path
class="splash-stroke-active"
mask="url(#m1)"
d="M 385 350 V 270 H 100 V 112.5"
/>
<path
class="splash-stroke-active"
mask="url(#m2)"
d="M 445 350 V 210 H 350 V 112.5"
/>
<path
class="splash-stroke-active"
mask="url(#m3)"
d="M 505 350 V 210 H 600 V 112.5"
/>
<path
class="splash-stroke-active"
mask="url(#m4)"
d="M 565 350 V 270 H 850 V 112.5"
/>
<!-- Displays -->
<rect
x="0"
y="0"
width="200"
height="112.5"
rx="8"
ry="8"
class="splash-monitor"
/>
<rect
x="250"
y="0"
width="200"
height="112.5"
rx="8"
ry="8"
class="splash-monitor"
/>
<rect
x="500"
y="0"
width="200"
height="112.5"
rx="8"
ry="8"
class="splash-monitor"
/>
<rect
x="750"
y="0"
width="200"
height="112.5"
rx="8"
ry="8"
class="splash-monitor"
/>
<!-- Text -->
<text class="splash-text" x="100" y="66.25" font-size="90">Mu</text>
<text class="splash-text" x="350" y="66.25" font-size="90">Di</text>
<text class="splash-text" x="600" y="66.25" font-size="90">C</text>
<text class="splash-text" x="850" y="66.25" font-size="90">S</text>
<!-- Controller -->
<rect
x="325"
y="350"
width="300"
height="168.75"
rx="8"
ry="8"
class="splash-control-monitor"
/>
<rect
x="335"
y="390"
width="135"
height="120"
rx="8"
ry="8"
class="splash-other-button"
/>
<rect
x="480"
y="390"
width="135"
height="55"
rx="8"
ry="8"
class="splash-other-button"
/>
<rect
x="480"
y="455"
width="135"
height="55"
rx="8"
ry="8"
class="splash-start-button"
/>
<!-- Window Controls -->
<path class="window-controls" d="M 600 360 l 15 15" />
<path class="window-controls" d="M 600 375 l 15 -15" />
<path
class="window-controls"
fill="none"
d="M 575 360 h 15 v 15 h -15 v -15"
/>
<path class="window-controls" d="M 550 375 h 15" />
</svg>
<div class="fade-in">
<div
class="cursor-x"
style="
position: absolute;
left: calc(50cqw + var(--mouse-start-x));
top: calc(50cqh + var(--mouse-start-y));
"
>
<svg class="cursor-y" width="50" height="50" viewBox="0 0 24 24">
<g
stroke="#ffffff"
fill="#000000"
stroke-width="2"
stroke-linecap="round"
stroke-linejoin="round"
>
<path stroke="#000000" d="M 6.5 10 H 18 V 19 H 6" />
<path d="M22 14a8 8 0 0 1-8 8" />
<path d="M18 11v-1a2 2 0 0 0-2-2a2 2 0 0 0-2 2" />
<path d="M14 10V9a2 2 0 0 0-2-2a2 2 0 0 0-2 2v1" />
<path d="M10 9.5V4a2 2 0 0 0-2-2a2 2 0 0 0-2 2v10" />
<path
d="M18 11a2 2 0 1 1 4 0v3a8 8 0 0 1-8 8h-2c-2.8 0-4.5-.86-5.99-2.34l-3.6-3.6a2 2 0 0 1 2.83-2.82L7 15"
/>
</g>
</svg>
</div>
</div>
<span id="version-label" aria-label="Version">%%APP-VERSION%%</span>
</div>
<style>
:root {
--splash-fade-out-delay: 3.5s;
--splash-fade-out-state: running;
--base-stroke: #444444;
--base-stroke-active: #109e00;
--splash-bg: oklch(21.6% 0.006 56.043);
--monitor-dark: #000000;
--monitor-active: #ffffff;
--window-controls: #cccccc;
--start-button-inactive: #cccccc;
--start-button-hover: #77a3b1;
--start-button-active: #2c819b;
--other-button: oklch(55.3% 0.013 58.071);
--splash-control-monitor: oklch(44.4% 0.011 73.639);
--version-color: oklch(55.3% 0.013 58.071);
--mouse-size: 50px;
--mouse-bounce-delay: 5s;
--mouse-start-x: calc((35 * 100vw) / 1920);
--mouse-start-y: calc((60 * 100vh) / 1080);
--dur-x: 16s;
--dur-y: 9s;
--stroke-strength: 8;
--dash: 16;
--gap: 20;
}
#version-label {
position: absolute;
right: 1rem;
top: 1rem;
display: block;
color: var(--version-color);
padding: 0.4rem 0.8rem;
font-size: 1.4rem;
text-align: right;
}
#splash {
position: fixed;
inset: 0;
background: var(--splash-bg);
color: white;
display: flex;
align-items: center;
justify-content: center;
z-index: 9999;
height: 100vh;
width: 100vw;
animation-name: splash-fade;
animation-duration: 1s;
animation-timing-function: ease;
animation-fill-mode: forwards;
animation-delay: var(--splash-fade-out-delay);
animation-play-state: var(--splash-fade-out-state);
}
#splash-svg {
max-height: 50vh;
max-width: 80vw;
transform: translateY(-12cqh);
}
.fade-in {
opacity: 0;
animation: fade-in 1s ease 500ms forwards;
}
.splash-monitor {
aspect-ratio: 16/9;
rx: 8;
ry: 8;
width: 200;
fill: var(--monitor-dark);
}
.splash-control-monitor {
fill: var(--splash-control-monitor);
}
.splash-other-button {
fill: var(--other-button);
}
.splash-stroke,
.splash-stroke-active {
fill: none;
stroke-linecap: round;
stroke-linejoin: round;
stroke-width: var(--stroke-strength);
stroke-dasharray: var(--dash) var(--gap);
}
.window-controls {
stroke: var(--window-controls);
stroke-width: 3;
}
.splash-stroke {
stroke: var(--base-stroke);
}
.splash-stroke-active {
stroke: var(--base-stroke-active);
}
.splash-mask {
fill: none;
stroke: #fff;
stroke-linecap: round;
stroke-width: var(--stroke-strength);
stroke-dasharray: 100;
stroke-dashoffset: 100;
animation: draw 1s ease-in-out 1.35s forwards;
}
.splash-text {
text-anchor: middle;
dominant-baseline: middle;
fill: var(--monitor-dark);
user-select: none;
font-family: sans-serif;
}
.splash-monitor {
fill: var(--monitor-dark);
animation: activate-monitor 0ms ease 2.35s forwards;
}
.splash-start-button {
fill: var(--start-button-inactive);
animation: start-button-hover-press 1s ease-in-out 450ms forwards;
}
.cursor-x {
animation-name: move-mouse, mouse-bounceX;
animation-duration: 1s, var(--dur-x);
animation-delay: 0s, var(--mouse-bounce-delay);
animation-iteration-count: 1, infinite;
animation-direction: normal, normal;
animation-timing-function: ease-in-out, linear;
animation-fill-mode: both, none;
will-change: transform;
}
.cursor-y {
animation-name: mouse-bounceY;
animation-duration: var(--dur-y);
animation-delay: var(--mouse-bounce-delay);
animation-iteration-count: infinite;
animation-direction: normal;
animation-timing-function: linear;
animation-fill-mode: none;
will-change: transform;
}
@keyframes fade-in {
to {
opacity: 1;
}
}
@keyframes move-mouse {
0% {
transform: translateX(-100px);
}
50% {
transform: translateX(-100px);
}
100% {
transform: translateX(0px);
}
}
@keyframes mouse-bounceX {
0% {
transform: translateX(0);
}
26% {
transform: translateX(calc(-50cqw - var(--mouse-start-x)));
}
76% {
transform: translateX(
calc(50cqw - var(--mouse-size) - var(--mouse-start-x))
);
}
}
@keyframes mouse-bounceY {
0% {
transform: translateY(0);
}
27% {
transform: translateY(calc(-50cqh - var(--mouse-start-y)));
}
77% {
transform: translateY(
calc(50cqh - var(--mouse-size) - var(--mouse-start-y))
);
}
}
@keyframes start-button-hover-press {
0% {
fill: var(--start-button-inactive);
}
30% {
fill: var(--start-button-inactive);
}
40% {
fill: var(--start-button-hover);
}
70% {
fill: var(--start-button-hover);
}
80% {
fill: var(--start-button-active);
}
90% {
fill: var(--start-button-active);
}
100% {
fill: var(--start-button-hover);
}
}
@keyframes draw {
to {
stroke-dashoffset: 0;
}
}
@keyframes activate-monitor {
to {
fill: var(--monitor-active);
}
}
@keyframes splash-fade {
to {
opacity: 0;
visibility: hidden;
}
}
rect {
vector-effect: non-scaling-stroke;
}
/* verhindert, dass die Linien beim Skalieren dicker werden */
.cursor * {
vector-effect: non-scaling-stroke;
}
</style>
<script>
const r =
Math.random() < 0.01
? 9 / 15.039473684
: 0.55 + (Math.random() - 0.5) * 0.18;
const tx = 13 + Math.random() * 5;
document.documentElement.style.setProperty("--dur-x", tx + "s");
document.documentElement.style.setProperty("--dur-y", tx * r + "s");
</script>