Compare commits
3 Commits
2ebe7f3019
...
54806c33c7
Author | SHA1 | Date | |
---|---|---|---|
|
54806c33c7 | ||
|
b7e70b9368 | ||
|
60be872ee2 |
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -14,3 +14,4 @@ desktopRuntime/options.txt
|
|||
desktopRuntime/_eagstorage*
|
||||
desktopRuntime/filesystem/*
|
||||
desktopRuntime/downloads/*
|
||||
javascript/Shadow_Client_en_US.zip
|
||||
|
|
|
@ -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) {
|
||||
|
@ -71,11 +78,11 @@ public class Controller {
|
|||
}
|
||||
|
||||
public static boolean jump() {
|
||||
return isButtonPressed(1) || isButtonDown(1);
|
||||
return isButtonPressed(0) || isButtonDown(0);
|
||||
}
|
||||
|
||||
public static boolean crouch() {
|
||||
return isButtonPressed(0) || isButtonDown(0) || isButtonPressed(11) || isButtonDown(11);
|
||||
return isButtonPressed(1) || isButtonDown(1) || isButtonPressed(11) || isButtonDown(11);
|
||||
}
|
||||
|
||||
public static boolean sprint() {
|
||||
|
@ -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 = "";
|
||||
}
|
||||
|
|
|
@ -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;
|
||||
}
|
||||
|
|
|
@ -1,6 +1,7 @@
|
|||
package net.minecraft.util;
|
||||
|
||||
import net.PeytonPlayz585.shadow.input.Controller;
|
||||
import net.minecraft.client.Minecraft;
|
||||
import net.minecraft.client.settings.GameSettings;
|
||||
|
||||
/**+
|
||||
|
@ -49,8 +50,8 @@ public class MovementInputFromOptions extends MovementInput {
|
|||
--this.moveStrafe;
|
||||
}
|
||||
|
||||
this.jump = this.gameSettings.keyBindJump.isKeyDown() || Controller.jump();
|
||||
this.sneak = this.gameSettings.keyBindSneak.isKeyDown() || Controller.crouch();
|
||||
this.jump = this.gameSettings.keyBindJump.isKeyDown() || (Controller.jump() && Minecraft.getMinecraft().currentScreen == null);
|
||||
this.sneak = this.gameSettings.keyBindSneak.isKeyDown() || (Controller.crouch() && Minecraft.getMinecraft().currentScreen == null);
|
||||
if (this.sneak) {
|
||||
this.moveStrafe = (float) ((double) this.moveStrafe * 0.3D);
|
||||
this.moveForward = (float) ((double) this.moveForward * 0.3D);
|
||||
|
|
Loading…
Reference in New Issue
Block a user