From 0a58a802289a9c28184a4d4195d3dd5fd98744e8 Mon Sep 17 00:00:00 2001 From: Colbster937 Date: Mon, 27 May 2024 09:46:54 -0500 Subject: [PATCH 1/4] Update eaglermobile.user.js --- eaglermobile.user.js | 288 +++++++++++++++++++++++-------------------- 1 file changed, 156 insertions(+), 132 deletions(-) diff --git a/eaglermobile.user.js b/eaglermobile.user.js index a9c8820..348d686 100644 --- a/eaglermobile.user.js +++ b/eaglermobile.user.js @@ -13,6 +13,15 @@ // ==/UserScript== +function isMobile() { + try { + document.createEvent("TouchEvent"); + return true; + } catch (e) { + return false; + } +} +if(!isMobile()){alert("WARNING: This script doesn't play well with non-mobile browsers. Proceed at your own risk!")}; // Hides inventory button window.inInventory = false; // Used for changing touchmove events to mousemove events @@ -63,9 +72,9 @@ document.exitPointerLock = function() { window.fakelock = null document.dispatchEvent(new Event('pointerlockchange')); var hideButtonStyleDOM = document.getElementById('hideButtonStyle'); - var hideInventoryStyleDOM = document.getElementById('hideInventoryStyle'); - hideButtonStyleDOM.disabled = false; - hideInventoryStyleDOM.disabled = window.inInventory; + var hideInventoryStyleDOM = document.getElementById('hideInventoryStyle'); + hideButtonStyleDOM.disabled = false; + hideInventoryStyleDOM.disabled = window.inInventory; return true } @@ -101,7 +110,7 @@ document.createElement = function(type) { this.body.appendChild(element); newElement = document.querySelector('input'); newElement.addEventListener('change', function(e) { - this.hidden = true; + this.hidden = true; }) } newElement.value = null; @@ -131,8 +140,8 @@ customStyle.textContent = ` background: url() no-repeat right center, url() no-repeat left center; background-size: contain, cover; outline:none; - box-shadow: none; - border: none; + box-shadow: none; + border: none; } button:active { position: absolute; @@ -148,16 +157,16 @@ customStyle.textContent = ` text-shadow: 0.35vh 0.35vh #000000; box-sizing: content-box; image-rendering: pixelated; - background: url() no-repeat right center, url() no-repeat left center; - background-size: contain, cover; + background: url() no-repeat right center, url() no-repeat left center; + background-size: contain, cover; outline:none; - box-shadow: none; - border: none; + box-shadow: none; + border: none; } html, body { - height: -webkit-fill-available !important; - touch-action: pan-x pan-y; + height: -webkit-fill-available !important; + touch-action: pan-x pan-y; } `; document.documentElement.appendChild(customStyle); @@ -210,7 +219,10 @@ function insertCanvasElements() { } 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}); + var evt = new MouseEvent("mousemove", { + movementX: e.movementX, + movementY: e.movementY + }); canvas.dispatchEvent(evt); previousX = touch.pageX; previousY = touch.pageY; @@ -224,123 +236,135 @@ function insertCanvasElements() { // 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 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 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); + 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 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); } From 27cda8af9223b969b635177acb30c5c5172956fd Mon Sep 17 00:00:00 2001 From: Colbster937 Date: Tue, 28 May 2024 09:08:27 -0500 Subject: [PATCH 2/4] Update eaglermobile.user.js --- eaglermobile.user.js | 5 +---- 1 file changed, 1 insertion(+), 4 deletions(-) diff --git a/eaglermobile.user.js b/eaglermobile.user.js index 348d686..58ff52a 100644 --- a/eaglermobile.user.js +++ b/eaglermobile.user.js @@ -219,10 +219,7 @@ function insertCanvasElements() { } e.movementX = touch.pageX - previousX; e.movementY = touch.pageY - previousY; - var evt = new MouseEvent("mousemove", { - movementX: e.movementX, - movementY: e.movementY - }); + 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; From f6ad9cba449f465f35a22fb3c37b3ded72cb43ec Mon Sep 17 00:00:00 2001 From: FlamedDogo99 <96555444+FlamedDogo99@users.noreply.github.com> Date: Tue, 28 May 2024 08:14:16 -0600 Subject: [PATCH 3/4] Updated userscript version Forgot to update with the previous merge --- eaglermobile.user.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eaglermobile.user.js b/eaglermobile.user.js index 58ff52a..0b7e96e 100644 --- a/eaglermobile.user.js +++ b/eaglermobile.user.js @@ -7,7 +7,7 @@ // @license Apache License 2.0 - http://www.apache.org/licenses/ // @match https://eaglercraft.com/mc/* // @grant none -// @version 1.2 +// @version 1.3 // @updateURL https://raw.githubusercontent.com/FlamedDogo99/EaglerMobile/main/eaglermobile.user.js // @run-at document-start // ==/UserScript== From a5f33ef9338c1d7dd648c277dfca69754951ac22 Mon Sep 17 00:00:00 2001 From: FlamedDogo99 <96555444+FlamedDogo99@users.noreply.github.com> Date: Tue, 28 May 2024 10:48:42 -0600 Subject: [PATCH 4/4] Create README.md --- README.md | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) create mode 100644 README.md diff --git a/README.md b/README.md new file mode 100644 index 0000000..954085a --- /dev/null +++ b/README.md @@ -0,0 +1,22 @@ +# Eagler Mobile + +## A userscript that allows eaglercraft to run on iOS safari +To-do +- [ ] Strafe buttons when holding forward +- [ ] Crouch lock on hold +- [ ] Sprint button (sperate from double tapping forward) +- [ ] Gamepad support +- [ ] Cancel button for file upload +- [ ] Styling for file upload +- [ ] Pick block button +- [ ] Back button for Kiwi browser? + +Implemented + +- [x] Fake pointerlock API (tricks the client into loading) +- [x] Fake fullscreen API (so that selecting full screen doesn't crash the client) +- [x] Custom upload button for files (because safari is a pain with button clicks) +- [x] Fake mousemove events (Allows touch and drag to simulate mouse movement) +- [x] Fake cursor scroll events (Allows scrolling through hotbar and in menus) +- [x] On-screen controls (Movement, block placement/removal, inventory, item dropping, keyboard, and exiting keys) +- [x] Styling for html, body, and canvas (So that the canvas doesn't ignore the navigation bars for viewport sizing)