From 54806c33c76f35090e0e78e30670b6acff2cdf7a Mon Sep 17 00:00:00 2001 From: PeytonPlayz595 <106421860+PeytonPlayz595@users.noreply.github.com> Date: Sat, 6 Jul 2024 11:54:24 -0700 Subject: [PATCH] Controller cursor --- .../shadow/input/Controller.java | 73 +++++++++++++++++++ .../java/net/minecraft/client/Minecraft.java | 10 +++ 2 files changed, 83 insertions(+) diff --git a/src/teavm/java/net/PeytonPlayz585/shadow/input/Controller.java b/src/teavm/java/net/PeytonPlayz585/shadow/input/Controller.java index 68b1f00..a973eac 100644 --- a/src/teavm/java/net/PeytonPlayz585/shadow/input/Controller.java +++ b/src/teavm/java/net/PeytonPlayz585/shadow/input/Controller.java @@ -6,7 +6,12 @@ import java.util.List; import org.teavm.jso.browser.Navigator; import org.teavm.jso.browser.Window; import org.teavm.jso.dom.events.EventListener; +import org.teavm.jso.dom.html.HTMLBodyElement; +import org.teavm.jso.dom.html.HTMLImageElement; import org.teavm.jso.gamepad.GamepadEvent; + +import net.lax1dude.eaglercraft.v1_8.Display; + import org.teavm.jso.gamepad.Gamepad; public class Controller { @@ -28,6 +33,8 @@ public class Controller { private static int activeController = -1; private static ButtonState[] states = new ButtonState[30]; + public static HTMLImageElement cursor; + public static final int getDX() { if(dx < 0.0) { if(dx < -cameraThreshold) { @@ -134,6 +141,38 @@ public class Controller { */ dy = -axes[3] * multiplier; + if(cursor != null) { + double dx1; + double dy1 = dy; + + if(dx1 < 0.0) { + if(dx1 < -cameraThreshold) { + dx1 = dx; + } + } else if(dx > 0.0) { + if(dx > cameraThreshold) { + dx1 = dx; + } + } else { + dx1 = 0; + } + + if(dy1 < 0.0) { + if(dy1 < -cameraThreshold) { + dy1 = dy; + } + } else if(dy1 > 0.0) { + if(dy1 > cameraThreshold) { + dy1 = dy; + } + } else { + dy1 = 0; + } + + + updateCursor((int)dx1, (int)dy1); + } + forward = axes[1] < -threshold; backwards = axes[1] > threshold; left = axes[0] < -threshold; @@ -169,6 +208,38 @@ public class Controller { } } + public static void addCursor(int x, int y) { + cursor = (HTMLImageElement) Window.current().getDocument().createElement("img"); + cursor.setAttribute("id", "cursor"); + cursor.setSrc(cursorSrc); + cursor.setAttribute("draggable", "false"); + cursor.getStyle().setProperty("left", "0px"); + cursor.getStyle().setProperty("top", "0px"); + cursor.getStyle().setProperty("width", "auto"); + cursor.getStyle().setProperty("height", "auto"); + + HTMLBodyElement body = (HTMLBodyElement) Window.current().getDocument().getBody(); + body.appendChild(cursor); + } + + public static void removeCursor() { + if (cursor != null) { + cursor.getParentNode().removeChild(cursor); + } + cursor = null; + } + + private static void updateCursor(int dx, int dy) { + int dx1 = cursor.getAbsoluteLeft() + dx; + int dy1 = cursor.getAbsoluteTop() + dy; + + int x = Math.min(Math.max(dx1, 0), Display.getWidth() - cursor.getWidth()); + int y = Math.min(Math.max(dy1, 0), Display.getHeight() - cursor.getHeight()); + + cursor.getStyle().setProperty("left", dx1 + "px"); + cursor.getStyle().setProperty("top", dy1 + "px"); + } + private static Gamepad getGamepad(int index) { return Navigator.getGamepads()[index]; } @@ -205,4 +276,6 @@ public class Controller { resetButtonStates(); } + + private static String cursorSrc = ""; } diff --git a/src/teavm/java/net/minecraft/client/Minecraft.java b/src/teavm/java/net/minecraft/client/Minecraft.java index 3a775bf..57410d0 100644 --- a/src/teavm/java/net/minecraft/client/Minecraft.java +++ b/src/teavm/java/net/minecraft/client/Minecraft.java @@ -1292,6 +1292,16 @@ public class Minecraft extends ModData implements IThreadListener { Controller.tick(); + if(this.currentScreen != null) { + if(Controller.cursor == null) { + Controller.addCursor(0, 0); + } + } else { + if(Controller.cursor != null) { + Controller.removeCursor(); + } + } + if (this.rightClickDelayTimer > 0) { --this.rightClickDelayTimer; }