This commit is contained in:
radmanplays 2024-03-20 18:26:48 +03:30
parent f5ebe88cbc
commit 428df25620
6 changed files with 210 additions and 4 deletions

View File

@ -549,7 +549,11 @@
> DELETE 2 @ 2 : 10 > DELETE 2 @ 2 : 10
> INSERT 9 : 28 @ 9 > INSERT 5 : 6 @ 5
+ Minecraft.getMinecraft().modapi.onFrame();
> INSERT 4 : 23 @ 4
+ RateLimitTracker.tick(); + RateLimitTracker.tick();
+ +

View File

@ -31,7 +31,7 @@
+ this.statWriter = statWriter; + this.statWriter = statWriter;
> INSERT 2 : 141 @ 2 > INSERT 2 : 157 @ 2
+ @Override + @Override
+ public ModData makeModData() { + public ModData makeModData() {
@ -54,7 +54,8 @@
+ data.set("clientBrand", clientBrand); + data.set("clientBrand", clientBrand);
+ data.set("sprintToggleTimer", sprintToggleTimer); + data.set("sprintToggleTimer", sprintToggleTimer);
+ data.set("sprintingTicksLeft", sprintingTicksLeft); + data.set("sprintingTicksLeft", sprintingTicksLeft);
+ + data.set("moveForward", moveForward);
+ data.set("moveStrafing", moveStrafing);
+ data.set("renderArmYaw", renderArmYaw); + data.set("renderArmYaw", renderArmYaw);
+ data.set("renderArmPitch", renderArmPitch); + data.set("renderArmPitch", renderArmPitch);
+ data.set("prevRenderArmYaw", prevRenderArmYaw); + data.set("prevRenderArmYaw", prevRenderArmYaw);
@ -145,6 +146,21 @@
+ data.setCallbackBoolean("isSpectator", () -> { + data.setCallbackBoolean("isSpectator", () -> {
+ return isSpectator(); + return isSpectator();
+ }); + });
+ data.setCallbackFloat("getSpeed", () -> {
+ return getSpeed();
+ });
+ data.setCallbackBoolean("isMoving", () -> {
+ return isMoving();
+ });
+ data.setCallbackBoolean("hasMotion", () -> {
+ return hasMotion();
+ });
+ data.setCallbackFloat("getSpeed", () -> {
+ return getSpeed();
+ });
+ data.setCallbackVoidWithDataArg("setSpeed", (BaseData params) -> {
+ setSpeed(params.getFloat("speed"));
+ });
+ return data; + return data;
+ } + }
+ +
@ -216,4 +232,60 @@
~ this.sendQueue.addToSendQueue(new C01PacketChatMessage(message)); ~ this.sendQueue.addToSendQueue(new C01PacketChatMessage(message));
~ } ~ }
> INSERT 426 : 479 @ 426
+
+ public float getSpeed() {
+ return (float) Math
+ .sqrt(mc.thePlayer.motionX * mc.thePlayer.motionX + mc.thePlayer.motionZ * mc.thePlayer.motionZ);
+ }
+
+ public void strafe() {
+ strafe(getSpeed());
+ }
+
+ public boolean isMoving() {
+ return mc.thePlayer != null
+ && (mc.thePlayer.movementInput.moveForward != 0F || mc.thePlayer.movementInput.moveStrafe != 0F);
+ }
+
+ public boolean hasMotion() {
+ return mc.thePlayer.motionX != 0D && mc.thePlayer.motionZ != 0D && mc.thePlayer.motionY != 0D;
+ }
+
+ public void strafe(final float speed) {
+ if (!isMoving())
+ return;
+
+ final double yaw = getDirection();
+ mc.thePlayer.motionX = -Math.sin(yaw) * speed;
+ mc.thePlayer.motionZ = Math.cos(yaw) * speed;
+ }
+
+ public double getDirection() {
+ float rotationYaw = mc.thePlayer.rotationYaw;
+
+ if (mc.thePlayer.moveForward < 0F)
+ rotationYaw += 180F;
+
+ float forward = 1F;
+ if (mc.thePlayer.moveForward < 0F)
+ forward = -0.5F;
+ else if (mc.thePlayer.moveForward > 0F)
+ forward = 0.5F;
+
+ if (mc.thePlayer.moveStrafing > 0F)
+ rotationYaw -= 90F * forward;
+
+ if (mc.thePlayer.moveStrafing < 0F)
+ rotationYaw += 90F * forward;
+
+ return Math.toRadians(rotationYaw);
+ }
+
+ public void setSpeed(float speed) {
+ this.motionX = -(Math.sin((double) this.getDirection()) * (double) speed);
+ this.motionZ = Math.cos((double) this.getDirection()) * (double) speed;
+ }
> EOF > EOF

View File

@ -1,16 +1,19 @@
package net.eaglerforge.api; package net.eaglerforge.api;
import com.sun.org.apache.bcel.internal.generic.RETURN;
import net.eaglerforge.gui.EmptyGui; import net.eaglerforge.gui.EmptyGui;
import net.eaglerforge.gui.ModGUI; import net.eaglerforge.gui.ModGUI;
import net.lax1dude.eaglercraft.v1_8.log4j.LogManager; import net.lax1dude.eaglercraft.v1_8.log4j.LogManager;
import net.lax1dude.eaglercraft.v1_8.log4j.Logger; import net.lax1dude.eaglercraft.v1_8.log4j.Logger;
import net.lax1dude.eaglercraft.v1_8.opengl.GlStateManager; import net.lax1dude.eaglercraft.v1_8.opengl.GlStateManager;
import net.lax1dude.eaglercraft.v1_8.profile.EaglerProfile;
import net.minecraft.client.ClientBrandRetriever; import net.minecraft.client.ClientBrandRetriever;
import net.minecraft.client.Minecraft; import net.minecraft.client.Minecraft;
import net.minecraft.client.gui.ScaledResolution; import net.minecraft.client.gui.ScaledResolution;
import net.minecraft.entity.Entity; import net.minecraft.entity.Entity;
import net.minecraft.util.ChatComponentText; import net.minecraft.util.ChatComponentText;
import me.otterdev.UwUAPI; import me.otterdev.UwUAPI;
import net.minecraft.util.EnumParticleTypes;
import org.teavm.jso.JSBody; import org.teavm.jso.JSBody;
import org.teavm.jso.JSObject; import org.teavm.jso.JSObject;
import net.minecraft.enchantment.Enchantment; import net.minecraft.enchantment.Enchantment;
@ -54,6 +57,10 @@ public class ModAPI {
@JSBody(params = { "data" }, script = "console.log(data);") @JSBody(params = { "data" }, script = "console.log(data);")
public static native void logJSObj(JSObject data); public static native void logJSObj(JSObject data);
@JSBody(params = { "minecraft" }, script = "window.Minecraft = minecraft;")
public static native void setMinecraftContext(BaseData minecraft);
public void onGlobalUpdated(String global) { public void onGlobalUpdated(String global) {
// logger.info("Global update request: "+global); // logger.info("Global update request: "+global);
BaseData data = getGlobal(global); BaseData data = getGlobal(global);
@ -88,6 +95,7 @@ public class ModAPI {
newEvent("premotionupdate"); newEvent("premotionupdate");
newEvent("sendchatmessage"); newEvent("sendchatmessage");
newEvent("update"); newEvent("update");
newEvent("frame");
/*newEvent("packetjoingame"); /*newEvent("packetjoingame");
newEvent("packetspawnobject"); newEvent("packetspawnobject");
@ -208,6 +216,93 @@ public class ModAPI {
getModAPI().setCallbackInt("getFPS", () -> { getModAPI().setCallbackInt("getFPS", () -> {
return getDebugFPS(); return getDebugFPS();
}); });
getModAPI().setCallbackVoidWithDataArg("displayParticleAtPlayer", (BaseData params) -> {
if (params.getString("type") == "EXPLOSION_NORMAL") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.EXPLOSION_NORMAL);
} else if (params.getString("type") == "EXPLOSION_LARGE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.EXPLOSION_LARGE);
} else if (params.getString("type") == "EXPLOSION_HUGE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.EXPLOSION_HUGE);
} else if (params.getString("type") == "FIREWORKS_SPARK") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.FIREWORKS_SPARK);
} else if (params.getString("type") == "WATER_BUBBLE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.WATER_BUBBLE);
} else if (params.getString("type") == "WATER_SPLASH") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.WATER_SPLASH);
} else if (params.getString("type") == "WATER_WAKE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.WATER_WAKE);
} else if (params.getString("type") == "SUSPENDED") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SUSPENDED);
} else if (params.getString("type") == "SUSPENDED_DEPTH") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SUSPENDED_DEPTH);
} else if (params.getString("type") == "CRIT") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.CRIT);
} else if (params.getString("type") == "CRIT_MAGIC") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.CRIT_MAGIC);
} else if (params.getString("type") == "SMOKE_NORMAL") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SMOKE_NORMAL);
} else if (params.getString("type") == "SMOKE_LARGE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SMOKE_LARGE);
} else if (params.getString("type") == "SPELL") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SPELL);
} else if (params.getString("type") == "SPELL_INSTANT") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SPELL_INSTANT);
} else if (params.getString("type") == "SPELL_MOB") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SPELL_MOB);
} else if (params.getString("type") == "SPELL_MOB_AMBIENT") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SPELL_MOB_AMBIENT);
} else if (params.getString("type") == "SPELL_WITCH") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SPELL_WITCH);
} else if (params.getString("type") == "DRIP_WATER") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.DRIP_WATER);
} else if (params.getString("type") == "DRIP_LAVA") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.DRIP_LAVA);
} else if (params.getString("type") == "VILLAGER_ANGRY") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.VILLAGER_ANGRY);
} else if (params.getString("type") == "VILLAGER_HAPPY") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.VILLAGER_HAPPY);
} else if (params.getString("type") == "TOWN_AURA") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.TOWN_AURA);
} else if (params.getString("type") == "NOTE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.NOTE);
} else if (params.getString("type") == "PORTAL") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.PORTAL);
} else if (params.getString("type") == "ENCHANTMENT_TABLE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.ENCHANTMENT_TABLE);
} else if (params.getString("type") == "FLAME") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.FLAME);
} else if (params.getString("type") == "LAVA") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.LAVA);
} else if (params.getString("type") == "FOOTSTEP") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.FOOTSTEP);
} else if (params.getString("type") == "CLOUD") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.CLOUD);
} else if (params.getString("type") == "REDSTONE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.REDSTONE);
} else if (params.getString("type") == "SNOWBALL") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SNOWBALL);
} else if (params.getString("type") == "SNOW_SHOVEL") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SNOW_SHOVEL);
} else if (params.getString("type") == "SLIME") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.SLIME);
} else if (params.getString("type") == "HEART") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.HEART);
} else if (params.getString("type") == "BARRIER") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.BARRIER);
} else if (params.getString("type") == "ITEM_CRACK") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.ITEM_CRACK);
} else if (params.getString("type") == "BLOCK_CRACK") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.BLOCK_CRACK);
} else if (params.getString("type") == "BLOCK_DUST") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.BLOCK_DUST);
} else if (params.getString("type") == "WATER_DROP") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.WATER_DROP);
} else if (params.getString("type") == "ITEM_TAKE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.ITEM_TAKE);
} else if (params.getString("type") == "MOB_APPEARANCE") {
mc.effectRenderer.emitParticleAtEntity(mc.thePlayer, EnumParticleTypes.MOB_APPEARANCE);
}
});
getModAPI().set("clientBrand", ClientBrandRetriever.getClientModName()); getModAPI().set("clientBrand", ClientBrandRetriever.getClientModName());
setGlobal("enchantments", Enchantment.makeModDataStatic()); setGlobal("enchantments", Enchantment.makeModDataStatic());
@ -215,6 +310,7 @@ public class ModAPI {
setGlobal("items", Items.makeModData()); setGlobal("items", Items.makeModData());
setGlobal("materials", Material.makeModDataStatic()); setGlobal("materials", Material.makeModDataStatic());
setGlobal("mcinstance", mc); setGlobal("mcinstance", mc);
setMinecraftContext(mc);
setGlobal("platform", PlatformAPI.makeModData()); setGlobal("platform", PlatformAPI.makeModData());
setGlobal("logger", LoggerAPI.makeModData()); setGlobal("logger", LoggerAPI.makeModData());
setGlobal("emptygui", EmptyGui.makeModData()); setGlobal("emptygui", EmptyGui.makeModData());
@ -247,6 +343,12 @@ public class ModAPI {
getModAPI().setCallbackVoidWithDataArg("drawRect", (BaseData params) -> { getModAPI().setCallbackVoidWithDataArg("drawRect", (BaseData params) -> {
gui.drawRect(params.getInt("left"), params.getInt("top"), params.getInt("right"), params.getInt("bottom"), params.getInt("color")); gui.drawRect(params.getInt("left"), params.getInt("top"), params.getInt("right"), params.getInt("bottom"), params.getInt("color"));
}); });
getModAPI().setCallbackVoid("reloadchunks", () -> {
mc.renderGlobal.loadRenderers();
});
getModAPI().setCallbackString("getProfileName", () -> {
return EaglerProfile.getName();
});
ModGUI.loadFont(); ModGUI.loadFont();
} }
static void globalsFunctor(ModAPI modAPI) { static void globalsFunctor(ModAPI modAPI) {
@ -275,9 +377,12 @@ public class ModAPI {
if (requiredList.contains("network") && mc.thePlayer != null && mc.thePlayer.sendQueue != null) { if (requiredList.contains("network") && mc.thePlayer != null && mc.thePlayer.sendQueue != null) {
ModAPI.setGlobal("network", mc.thePlayer.sendQueue.makeModData()); ModAPI.setGlobal("network", mc.thePlayer.sendQueue.makeModData());
} }
ModAPI.callEvent("update", new ModData());
}
public void onFrame(){
if (requiredList.contains("settings") && mc.gameSettings != null) { if (requiredList.contains("settings") && mc.gameSettings != null) {
ModAPI.setGlobal("settings", mc.gameSettings.makeModData()); ModAPI.setGlobal("settings", mc.gameSettings.makeModData());
} }
ModAPI.callEvent("update", new ModData()); ModAPI.callEvent("frame", new ModData());
} }
} }

View File

@ -0,0 +1,17 @@
from jsmin import jsmin
import sys
if len(sys.argv) < 3:
print("Usage: python jsminify.py <sourcePath> <minifiedPath>")
sys.exit(1)
source_path = sys.argv[1]
minified_path = sys.argv[2]
with open(source_path, 'r') as js_file:
minified = jsmin(js_file.read())
with open(minified_path, 'w') as minified_file:
minified_file.write(minified)
print(f"Minification done. Output at {minified_path}")

View File

@ -0,0 +1,3 @@
pip install jsmin
python desktopRuntime/minifier.py javascript/classes.js javascript/classes.js
pause

View File

@ -0,0 +1,5 @@
#!/bin/bash
pip install jsmin
python desktopRuntime/minifier.py javascript/classes.js javascript/classes.js
read -p "Press [Enter] key to continue..."