Fix elevator mobile

This commit is contained in:
T
2026-06-02 02:36:05 +02:00
parent 974887eb1f
commit 62f9aa3421
2 changed files with 64 additions and 49 deletions
+22 -6
View File
@@ -65,6 +65,17 @@ var Elevator = function(options) {
return verticalOffset; return verticalOffset;
} }
function getScrollTop() {
return window.pageYOffset || document.documentElement.scrollTop || body.scrollTop || 0;
}
function playAudio(audio) {
var playPromise = audio.play();
if (playPromise && playPromise.catch) {
playPromise.catch(() => 0);
}
}
/** /**
* Main * Main
*/ */
@@ -101,13 +112,12 @@ var Elevator = function(options) {
// C__O__O__O__D // C__O__O__O__D
// [_____________] // [_____________]
this.elevate = function () { this.elevate = function () {
if (elevating) { if (elevating) {
return; return;
} }
elevating = true; elevating = true;
startPosition = (document.documentElement.scrollTop || body.scrollTop); startPosition = getScrollTop();
// No custom duration set, so we travel at pixels per millisecond. (0.75px per ms) // No custom duration set, so we travel at pixels per millisecond. (0.75px per ms)
if (!customDuration) { if (!customDuration) {
@@ -120,7 +130,7 @@ var Elevator = function(options) {
// Start music! // Start music!
if (mainAudio) { if (mainAudio) {
mainAudio.play(); playAudio(mainAudio);
} }
}; };
@@ -145,7 +155,7 @@ var Elevator = function(options) {
} }
if (endAudio) { if (endAudio) {
endAudio.play(); playAudio(endAudio);
} }
} }
@@ -153,7 +163,6 @@ var Elevator = function(options) {
// If animating, go straight to the top. And play no more music. // If animating, go straight to the top. And play no more music.
if (elevating) { if (elevating) {
cancelAnimationFrame(animation); cancelAnimationFrame(animation);
resetPositions(); resetPositions();
@@ -166,9 +175,16 @@ var Elevator = function(options) {
} }
} }
function handleElevate(event) {
if (event && event.type === 'touchend')
event.preventDefault();
that.elevate();
}
function bindElevateToElement(element) { function bindElevateToElement(element) {
if (element.addEventListener) { if (element.addEventListener) {
element.addEventListener('click', that.elevate, false); element.addEventListener('click', handleElevate, false);
element.addEventListener('touchend', handleElevate, false);
} else { } else {
// Older browsers // Older browsers
element.attachEvent('onclick', function () { element.attachEvent('onclick', function () {
-1
View File
@@ -1 +0,0 @@
var Elevator=function(){"use strict";function n(n,e){for(var t in e)t in n||(n[t]=e[t]);return n}function e(n,e,t,u){return n/=u/2,1>n?t/2*n*n+e:(n--,-t/2*(n*(n-2)-1)+e)}function t(n){p||(p=n);var u=n-p,o=e(u,v,-v,A);window.scrollTo(0,o),A>u?s=requestAnimationFrame(t):i()}function u(){w||(w=!0,v=document.documentElement.scrollTop||m.scrollTop,f||(A=1.5*v),requestAnimationFrame(t),c&&c.play())}function o(){p=null,v=null,w=!1}function i(){o(),c&&(c.pause(),c.currentTime=0),d&&d.play()}function r(){w&&(cancelAnimationFrame(s),o(),c&&(c.pause(),c.currentTime=0),window.scrollTo(0,0))}function l(n){n.addEventListener("click",u,!1)}function a(n){m=document.body,n.element&&l(n.element),n.duration&&(f=!0,A=n.duration),n.mainAudio&&(c=new Audio(n.mainAudio),c.setAttribute("preload","true"),c.setAttribute("loop","true")),n.endAudio&&(d=new Audio(n.endAudio),d.setAttribute("preload","true")),window.addEventListener("blur",r,!1)}var c,d,m=null,s=null,A=null,f=!1,p=null,v=null,w=!1;return n(a,{elevate:u})}();