diff --git a/eaglermobile-ef.js b/eaglermobile-ef.js index 286f3bf..dc553c4 100644 --- a/eaglermobile-ef.js +++ b/eaglermobile-ef.js @@ -1,6 +1,5 @@ // eaglermobile for eaglerforge - function isMobile() { try { document.createEvent("TouchEvent"); @@ -145,4 +144,219 @@ customStyle.textContent = ` text-shadow: 0.35vh 0.35vh #000000; box-sizing: content-box; image-rendering: pixelated; - background: url() no-repeat right center, url( \ No newline at end of file + background: url() no-repeat right center, url() no-repeat left center; + background-size: contain, cover; + outline:none; + box-shadow: none; + border: none; + + } + html, body { + height: -webkit-fill-available !important; + touch-action: pan-x pan-y; + } + `; +document.documentElement.appendChild(customStyle); + +// Lazy way to hide touch controls through CSS. +let hideButtonStyle = document.createElement("style"); +hideButtonStyle.id = "hideButtonStyle"; +hideButtonStyle.textContent = ` + #hideButton { + display: none; + }`; +document.documentElement.appendChild(hideButtonStyle); +let hideInventoryStyle = document.createElement("style"); +hideInventoryStyle.id = "hideInventoryStyle"; +hideInventoryStyle.textContent = ` + #hideInventory { + display: none; + }`; +document.documentElement.appendChild(hideInventoryStyle); + +// The canvas is created by the client after it finishes unzipping and loading. When the canvas is created, this applies any necessary event listeners +function waitForElm(selector) { + return new Promise(resolve => { + if (document.querySelector(selector)) { + return resolve(document.querySelector(selector)); + } + const observer = new MutationObserver(mutations => { + if (document.querySelector(selector)) { + observer.disconnect(); + resolve(document.querySelector(selector)); + } + }); + observer.observe(document.documentElement, { + childList: true, + subtree: true + }); + }); +} + +waitForElm('canvas').then(() => {insertCanvasElements()}); +function insertCanvasElements() { + // Translates touchmove events to mousemove events + var canvas = document.querySelector('canvas'); + canvas.addEventListener("touchmove", (e) => { + const touch = e.targetTouches[0]; // We can get away with this because every other touch event will be on different elements + + if (!previousX) { + previousX = touch.pageX; + previousY = touch.pageY; + } + e.movementX = touch.pageX - previousX; + e.movementY = touch.pageY - previousY; + var evt = window.fakelock ? new MouseEvent("mousemove", {movementX: e.movementX, movementY: e.movementY}) : new WheelEvent("wheel", {"wheelDeltaY": e.movementY}); + canvas.dispatchEvent(evt); + previousX = touch.pageX; + previousY = touch.pageY; + event.preventDefault(); + }, false); + + canvas.addEventListener("touchend", (e) => { + previousX = null; + previousY = null; + }, false) + // Adds all of the touch screen controls + // Theres probably a better way to do this but this works for now + var forwardButton = document.createElement('button'); + forwardButton.id = "hideButton" + forwardButton.textContent = "▲"; + forwardButton.style.cssText = "left:10vh;bottom:20vh;" + forwardButton.addEventListener("touchstart", function(e){keyEvent("w", "keydown")}, false); + forwardButton.addEventListener("touchend", function(e){keyEvent("w", "keyup")}, false); + forwardButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(forwardButton); + var rightButton = document.createElement('button'); + rightButton.id = "hideButton" + rightButton.textContent = "▶"; + rightButton.style.cssText = "left:20vh;bottom:10vh;" + rightButton.addEventListener("touchstart", function(e){keyEvent("d", "keydown")}, false); + rightButton.addEventListener("touchend", function(e){keyEvent("d", "keyup")}, false); + rightButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(rightButton); + var leftButton = document.createElement('button'); + leftButton.id = "hideButton" + leftButton.textContent = "◀"; + leftButton.style.cssText = "left: 0vh; bottom:10vh;" + leftButton.addEventListener("touchstart", function(e){keyEvent("a", "keydown")}, false); + leftButton.addEventListener("touchend", function(e){keyEvent("a", "keyup")}, false); + leftButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(leftButton); + var backButton = document.createElement('button'); + backButton.id = "hideButton" + backButton.textContent = "▼"; + backButton.style.cssText = "left:10vh;bottom:0vh;" + backButton.addEventListener("touchstart", function(e){keyEvent("s", "keydown")}, false); + backButton.addEventListener("touchend", function(e){keyEvent("s", "keyup")}, false); + backButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(backButton); + var jumpButton = document.createElement('button'); + jumpButton.id = "hideButton" + jumpButton.textContent = "⇧"; + jumpButton.style.cssText = "right:10vh;bottom:10vh;" + jumpButton.addEventListener("touchstart", function(e){keyEvent(" ", "keydown")}, false); + jumpButton.addEventListener("touchend", function(e){keyEvent(" ", "keyup")}, false); + jumpButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(jumpButton); + var crouchButton = document.createElement('button'); + crouchButton.id = "hideButton" + crouchButton.textContent = "⇩"; + crouchButton.style.cssText = "left:10vh;bottom:10vh;" + crouchButton.addEventListener("touchstart", function(e){shiftKey("keydown")}, false); + crouchButton.addEventListener("touchend", function(e){shiftKey("keyup")}, false); + crouchButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(crouchButton); + var inventoryButton = document.createElement('button'); + inventoryButton.id = "hideInventory" + inventoryButton.textContent = "🎒"; + inventoryButton.style.cssText = "right:0vh;bottom:0vh;" + inventoryButton.addEventListener("touchstart", function(e){ + window.inInventory = (window.fakelock != null) + keyEvent("e", "keydown"); + }, false); + inventoryButton.addEventListener("touchend", function(e){keyEvent("e", "keyup")}, false); + inventoryButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(inventoryButton); + var chatButton = document.createElement('button'); + chatButton.id = "hideButton" + chatButton.textContent = "💬"; + chatButton.style.cssText = "right:0vh;top:0vh;" + chatButton.addEventListener("touchstart", function(e){keyEvent("¿", "keydown")}, false); + chatButton.addEventListener("touchend", function(e){keyEvent("¿", "keydown")}, false); + chatButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(chatButton); + var exitButton = document.createElement('button'); + exitButton.id = "exitButton" + exitButton.textContent = "⮐"; + exitButton.style.cssText = "left:0vh;top:0vh;" + exitButton.addEventListener("touchstart", function(e){keyEvent("À", "keydown")}, false); + exitButton.addEventListener("touchend", function(e){keyEvent("À", "keyup")}, false); + exitButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(exitButton); + var hiddenInput = document.createElement('input'); + hiddenInput.id = "hiddenInput" + hiddenInput.style.cssText = "opacity:0;z-index:-99999"; + document.body.appendChild(hiddenInput); + var keyboardButton = document.createElement('button'); + keyboardButton.id = "keyboardButton" + keyboardButton.textContent = "⌨️"; + keyboardButton.style.cssText = "left:10vh;top:0vh;" + keyboardButton.addEventListener("touchstart", function(e){e.preventDefault();hiddenInput.blur()}, false); + keyboardButton.addEventListener("touchend", function(e){hiddenInput.select()}, false); + keyboardButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(keyboardButton); + var placeButton = document.createElement('button'); + placeButton.id = "hideButton" + placeButton.textContent = "⊹"; + placeButton.style.cssText = "right:0vh;bottom:20vh;" + placeButton.addEventListener("touchstart", function(e){mouseEvent(2, "mousedown", canvas)}, false); + placeButton.addEventListener("touchend", function(e){mouseEvent(2, "mouseup", canvas)}, false); + placeButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(placeButton); + var breakButton = document.createElement('button'); + breakButton.id = "hideButton" + breakButton.textContent = "🗡"; + breakButton.style.cssText = "right:10vh;bottom:20vh;" + breakButton.addEventListener("touchstart", function(e){mouseEvent(0, "mousedown", canvas)}, false); + breakButton.addEventListener("touchend", function(e){mouseEvent(0, "mouseup", canvas)}, false); + breakButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(breakButton); + var selectButton = document.createElement('button'); + selectButton.id = "hideButton" + selectButton.textContent = "⬚"; + selectButton.style.cssText = "right:20vh;bottom:20vh;" + selectButton.addEventListener("touchstart", function(e){mouseEvent(1, "mousedown", canvas)}, false); + selectButton.addEventListener("touchend", function(e){mouseEvent(1, "mouseup", canvas)}, false); + selectButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(selectButton); + var scrollUpButton = document.createElement('button'); + scrollUpButton.id = "hideButton" + scrollUpButton.textContent = "⇨"; + scrollUpButton.style.cssText = "right:0vh;bottom:30vh;" + scrollUpButton.addEventListener("touchstart", function(e){ + canvas.dispatchEvent(new WheelEvent("wheel", {"wheelDeltaY": -10})) + }, false); + scrollUpButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(scrollUpButton); + var scrollDownButton = document.createElement('button'); + scrollDownButton.id = "hideButton" + scrollDownButton.textContent = "⇦"; + scrollDownButton.style.cssText = "right:10vh;bottom:30vh;" + scrollDownButton.addEventListener("touchstart", function(e){ + canvas.dispatchEvent(new WheelEvent("wheel", {"wheelDeltaY": 10})) + }, false); + scrollDownButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(scrollDownButton); + var throwButton = document.createElement('button'); + throwButton.id = "hideButton" + throwButton.textContent = "Q"; + throwButton.style.cssText = "right:0vh;bottom:10vh;" + throwButton.addEventListener("touchstart", function(e){ + window.inInventory = (window.fakelock != null) + keyEvent("q", "keydown"); + }, false); + throwButton.addEventListener("touchend", function(e){keyEvent("q", "keyup")}, false); + throwButton.addEventListener("touchmove", function(e){e.preventDefault()}, false); + document.body.appendChild(throwButton); +}