mirror of
https://github.com/seppukudevelopment/seppuku
synced 2025-01-16 03:51:58 +00:00
Fixed a nullptr in PingComponent, Fixed a bug with LogoutSpots where the model would appear red because their hurttime was > 0, Added end portals to portal finder
This commit is contained in:
parent
cc453c8739
commit
d004aeaf46
@ -2,6 +2,7 @@ package me.rigamortis.seppuku.impl.gui.hud.component;
|
|||||||
|
|
||||||
import me.rigamortis.seppuku.api.gui.hud.component.DraggableHudComponent;
|
import me.rigamortis.seppuku.api.gui.hud.component.DraggableHudComponent;
|
||||||
import net.minecraft.client.Minecraft;
|
import net.minecraft.client.Minecraft;
|
||||||
|
import net.minecraft.client.network.NetworkPlayerInfo;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Author Seth
|
* Author Seth
|
||||||
@ -19,10 +20,15 @@ public final class PingComponent extends DraggableHudComponent {
|
|||||||
|
|
||||||
final Minecraft mc = Minecraft.getMinecraft();
|
final Minecraft mc = Minecraft.getMinecraft();
|
||||||
|
|
||||||
if (mc.getConnection() == null || mc.player == null)
|
if (mc.world == null || mc.player == null || mc.player.getUniqueID() == null)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
final String ping = "MS: " + mc.getConnection().getPlayerInfo(mc.player.getUniqueID()).getResponseTime();
|
final NetworkPlayerInfo playerInfo = mc.getConnection().getPlayerInfo(mc.player.getUniqueID());
|
||||||
|
|
||||||
|
if (playerInfo == null)
|
||||||
|
return;
|
||||||
|
|
||||||
|
final String ping = "MS: " + playerInfo.getResponseTime();
|
||||||
|
|
||||||
this.setW(Minecraft.getMinecraft().fontRenderer.getStringWidth(ping));
|
this.setW(Minecraft.getMinecraft().fontRenderer.getStringWidth(ping));
|
||||||
this.setH(Minecraft.getMinecraft().fontRenderer.FONT_HEIGHT);
|
this.setH(Minecraft.getMinecraft().fontRenderer.FONT_HEIGHT);
|
||||||
|
@ -69,6 +69,7 @@ public final class LogoutSpotsModule extends Module {
|
|||||||
data.ghost.prevLimbSwingAmount = 0;
|
data.ghost.prevLimbSwingAmount = 0;
|
||||||
data.ghost.limbSwing = 0;
|
data.ghost.limbSwing = 0;
|
||||||
data.ghost.limbSwingAmount = 0;
|
data.ghost.limbSwingAmount = 0;
|
||||||
|
data.ghost.hurtTime = 0;
|
||||||
|
|
||||||
GlStateManager.pushMatrix();
|
GlStateManager.pushMatrix();
|
||||||
GlStateManager.enableLighting();
|
GlStateManager.enableLighting();
|
||||||
@ -159,6 +160,14 @@ public final class LogoutSpotsModule extends Module {
|
|||||||
return Minecraft.getMinecraft().player.getDistance(position.x, position.y, position.z) > this.removeDistance.getValue();
|
return Minecraft.getMinecraft().player.getDistance(position.x, position.y, position.z) > this.removeDistance.getValue();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public Map<String, EntityPlayer> getPlayerCache() {
|
||||||
|
return playerCache;
|
||||||
|
}
|
||||||
|
|
||||||
|
public Map<String, PlayerData> getLogoutCache() {
|
||||||
|
return logoutCache;
|
||||||
|
}
|
||||||
|
|
||||||
private class PlayerData {
|
private class PlayerData {
|
||||||
Vec3d position;
|
Vec3d position;
|
||||||
GameProfile profile;
|
GameProfile profile;
|
||||||
|
@ -156,7 +156,7 @@ public final class PortalFinderModule extends Module {
|
|||||||
final int worldY = y + extendedBlockStorage.getYLocation();
|
final int worldY = y + extendedBlockStorage.getYLocation();
|
||||||
if (blockState.getBlock().equals(Blocks.PORTAL)) {
|
if (blockState.getBlock().equals(Blocks.PORTAL)) {
|
||||||
BlockPos position = new BlockPos(event.getChunk().getPos().getXStart() + x, worldY, event.getChunk().getPos().getZStart() + z);
|
BlockPos position = new BlockPos(event.getChunk().getPos().getXStart() + x, worldY, event.getChunk().getPos().getZStart() + z);
|
||||||
if (!isPortalCached(position.getX(), position.getY(), position.getZ())) {
|
if (!isPortalCached(position.getX(), position.getY(), position.getZ(), 0)) {
|
||||||
final Vec3d portal = new Vec3d(position.getX(), position.getY(), position.getZ());
|
final Vec3d portal = new Vec3d(position.getX(), position.getY(), position.getZ());
|
||||||
this.portals.add(portal);
|
this.portals.add(portal);
|
||||||
if (this.chat.getValue()) {
|
if (this.chat.getValue()) {
|
||||||
@ -165,6 +165,17 @@ public final class PortalFinderModule extends Module {
|
|||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
if (blockState.getBlock().equals(Blocks.END_PORTAL)) {
|
||||||
|
BlockPos position = new BlockPos(event.getChunk().getPos().getXStart() + x, worldY, event.getChunk().getPos().getZStart() + z);
|
||||||
|
if (!isPortalCached(position.getX(), position.getY(), position.getZ(), 3)) {
|
||||||
|
final Vec3d portal = new Vec3d(position.getX(), position.getY(), position.getZ());
|
||||||
|
this.portals.add(portal);
|
||||||
|
if (this.chat.getValue()) {
|
||||||
|
this.printEndPortalToChat(portal);
|
||||||
|
}
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -182,15 +193,32 @@ public final class PortalFinderModule extends Module {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private boolean isPortalCached(int x, int y, int z) {
|
private boolean isPortalCached(int x, int y, int z, float dist) {
|
||||||
for (int i = this.portals.size() - 1; i >= 0; i--) {
|
for (int i = this.portals.size() - 1; i >= 0; i--) {
|
||||||
Vec3d searchPortal = this.portals.get(i);
|
Vec3d searchPortal = this.portals.get(i);
|
||||||
|
|
||||||
|
if (searchPortal.distanceTo(new Vec3d(x, y, z)) <= dist)
|
||||||
|
return true;
|
||||||
|
|
||||||
if (searchPortal.x == x && searchPortal.y == y && searchPortal.z == z)
|
if (searchPortal.x == x && searchPortal.y == y && searchPortal.z == z)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private void printEndPortalToChat(Vec3d portal) {
|
||||||
|
final TextComponentString portalTextComponent = new TextComponentString("End Portal found!");
|
||||||
|
|
||||||
|
String coords = String.format("X: %s, Y: %s, Z: %s", (int) portal.x, (int) portal.y, (int) portal.z);
|
||||||
|
int playerDistance = (int) Minecraft.getMinecraft().player.getDistance(portal.x, portal.y, portal.z);
|
||||||
|
String distance = ChatFormatting.GRAY + "" + playerDistance + "m away";
|
||||||
|
|
||||||
|
String hoverText = coords + "\n" + distance;
|
||||||
|
portalTextComponent.setStyle(new Style().setHoverEvent(new HoverEvent(HoverEvent.Action.SHOW_TEXT, new TextComponentString(hoverText))));
|
||||||
|
|
||||||
|
Seppuku.INSTANCE.logcChat(portalTextComponent);
|
||||||
|
}
|
||||||
|
|
||||||
private void printPortalToChat(Vec3d portal) {
|
private void printPortalToChat(Vec3d portal) {
|
||||||
final TextComponentString portalTextComponent = new TextComponentString("Portal found!");
|
final TextComponentString portalTextComponent = new TextComponentString("Portal found!");
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user