Controller cursor

This commit is contained in:
PeytonPlayz595 2024-07-06 11:54:24 -07:00
parent b7e70b9368
commit 54806c33c7
2 changed files with 83 additions and 0 deletions

View File

@ -6,7 +6,12 @@ import java.util.List;
import org.teavm.jso.browser.Navigator; import org.teavm.jso.browser.Navigator;
import org.teavm.jso.browser.Window; import org.teavm.jso.browser.Window;
import org.teavm.jso.dom.events.EventListener; 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 org.teavm.jso.gamepad.GamepadEvent;
import net.lax1dude.eaglercraft.v1_8.Display;
import org.teavm.jso.gamepad.Gamepad; import org.teavm.jso.gamepad.Gamepad;
public class Controller { public class Controller {
@ -28,6 +33,8 @@ public class Controller {
private static int activeController = -1; private static int activeController = -1;
private static ButtonState[] states = new ButtonState[30]; private static ButtonState[] states = new ButtonState[30];
public static HTMLImageElement cursor;
public static final int getDX() { public static final int getDX() {
if(dx < 0.0) { if(dx < 0.0) {
if(dx < -cameraThreshold) { if(dx < -cameraThreshold) {
@ -134,6 +141,38 @@ public class Controller {
*/ */
dy = -axes[3] * multiplier; 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; forward = axes[1] < -threshold;
backwards = axes[1] > threshold; backwards = axes[1] > threshold;
left = axes[0] < -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) { private static Gamepad getGamepad(int index) {
return Navigator.getGamepads()[index]; return Navigator.getGamepads()[index];
} }
@ -205,4 +276,6 @@ public class Controller {
resetButtonStates(); resetButtonStates();
} }
private static String cursorSrc = "";
} }

View File

@ -1292,6 +1292,16 @@ public class Minecraft extends ModData implements IThreadListener {
Controller.tick(); 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) { if (this.rightClickDelayTimer > 0) {
--this.rightClickDelayTimer; --this.rightClickDelayTimer;
} }