new chunks? does that even work?
This commit is contained in:
@@ -32,6 +32,7 @@ public class MeteorRejectsAddon extends MeteorAddon {
|
|||||||
modules.add(new InteractionMenu());
|
modules.add(new InteractionMenu());
|
||||||
modules.add(new Glide());
|
modules.add(new Glide());
|
||||||
modules.add(new Lavacast());
|
modules.add(new Lavacast());
|
||||||
|
modules.add(new NewChunks());
|
||||||
//modules.add(new ObsidianFarm());
|
//modules.add(new ObsidianFarm());
|
||||||
modules.add(new RenderInvisible());
|
modules.add(new RenderInvisible());
|
||||||
modules.add(new SkeletonESP());
|
modules.add(new SkeletonESP());
|
||||||
|
|||||||
154
src/main/java/cloudburst/rejects/modules/NewChunks.java
Normal file
154
src/main/java/cloudburst/rejects/modules/NewChunks.java
Normal file
@@ -0,0 +1,154 @@
|
|||||||
|
package cloudburst.rejects.modules;
|
||||||
|
|
||||||
|
import cloudburst.rejects.MeteorRejectsAddon;
|
||||||
|
import meteordevelopment.orbit.EventHandler;
|
||||||
|
import minegame159.meteorclient.events.packets.PacketEvent;
|
||||||
|
import minegame159.meteorclient.events.render.RenderEvent;
|
||||||
|
import minegame159.meteorclient.rendering.Renderer;
|
||||||
|
import minegame159.meteorclient.rendering.ShapeMode;
|
||||||
|
import minegame159.meteorclient.settings.*;
|
||||||
|
import minegame159.meteorclient.systems.modules.Module;
|
||||||
|
import minegame159.meteorclient.utils.render.RenderUtils;
|
||||||
|
import minegame159.meteorclient.utils.render.color.Color;
|
||||||
|
import minegame159.meteorclient.utils.render.color.SettingColor;
|
||||||
|
import net.minecraft.fluid.FluidState;
|
||||||
|
import net.minecraft.nbt.CompoundTag;
|
||||||
|
import net.minecraft.network.packet.s2c.play.*;
|
||||||
|
import net.minecraft.util.math.*;
|
||||||
|
import net.minecraft.world.chunk.WorldChunk;
|
||||||
|
|
||||||
|
import java.util.*;
|
||||||
|
|
||||||
|
public class NewChunks extends Module {
|
||||||
|
|
||||||
|
private Set<ChunkPos> newChunks = Collections.synchronizedSet(new HashSet<>());
|
||||||
|
private Set<ChunkPos> oldChunks = Collections.synchronizedSet(new HashSet<>());
|
||||||
|
private static final Direction[] searchDirs = new Direction[] { Direction.EAST, Direction.NORTH, Direction.WEST, Direction.SOUTH, Direction.UP };
|
||||||
|
|
||||||
|
public NewChunks() {
|
||||||
|
super(MeteorRejectsAddon.CATEGORY,"new-chunks", "Detects completely new chunks using certain traits of them");
|
||||||
|
}
|
||||||
|
|
||||||
|
private final SettingGroup sgGeneral = settings.getDefaultGroup();
|
||||||
|
|
||||||
|
private final Setting<Boolean> remove = sgGeneral.add(new BoolSetting.Builder()
|
||||||
|
.name("remove")
|
||||||
|
.description("Removes the cached chunks when disabling the module.")
|
||||||
|
.defaultValue(true)
|
||||||
|
.build()
|
||||||
|
);
|
||||||
|
|
||||||
|
private final Setting<SettingColor> newChunksColor = sgGeneral.add(new ColorSetting.Builder()
|
||||||
|
.name("new-chunks-color")
|
||||||
|
.description("Color of the chunks that are (most likely) completely new.")
|
||||||
|
.defaultValue(new SettingColor(204, 153, 217))
|
||||||
|
.build()
|
||||||
|
);
|
||||||
|
|
||||||
|
private final Setting<SettingColor> oldChunksColor = sgGeneral.add(new ColorSetting.Builder()
|
||||||
|
.name("old-chunks-color")
|
||||||
|
.description("Color of the chunks that have (most likely) been loaded before.")
|
||||||
|
.defaultValue(new SettingColor(230, 51, 51))
|
||||||
|
.build()
|
||||||
|
);
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDeactivate() {
|
||||||
|
if (remove.get()) {
|
||||||
|
newChunks.clear();
|
||||||
|
oldChunks.clear();
|
||||||
|
}
|
||||||
|
super.onDeactivate();
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
private void onRender(RenderEvent event) {
|
||||||
|
if (newChunksColor.get().a>3) {
|
||||||
|
int color = newChunksColor.get().getPacked();
|
||||||
|
synchronized (newChunks) {
|
||||||
|
for (ChunkPos c : newChunks) {
|
||||||
|
if (mc.getCameraEntity().getBlockPos().isWithinDistance(c.getStartPos(), 1024)) {
|
||||||
|
drawBoxOutline(new Box(c.getStartPos(), c.getStartPos().add(16, 0, 16)), newChunksColor.get());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (oldChunksColor.get().a>3){
|
||||||
|
int color = oldChunksColor.get().getPacked();
|
||||||
|
synchronized (oldChunks) {
|
||||||
|
for (ChunkPos c : oldChunks) {
|
||||||
|
if (mc.getCameraEntity().getBlockPos().isWithinDistance(c.getStartPos(), 1024)) {
|
||||||
|
drawBoxOutline(new Box(c.getStartPos(), c.getStartPos().add(16, 0, 16)), oldChunksColor.get());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
private void drawBoxOutline(Box box, Color color) {
|
||||||
|
Renderer.boxWithLines(Renderer.NORMAL, Renderer.LINES,
|
||||||
|
box.minX, box.minY, box.minZ, box.maxX, box.maxY, box.maxZ,
|
||||||
|
new Color(0,0,0,0), color, ShapeMode.Lines, 0
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@EventHandler
|
||||||
|
private void onReadPacket(PacketEvent.Receive event) {
|
||||||
|
if (event.packet instanceof ChunkDeltaUpdateS2CPacket) {
|
||||||
|
ChunkDeltaUpdateS2CPacket packet = (ChunkDeltaUpdateS2CPacket) event.packet;
|
||||||
|
|
||||||
|
packet.visitUpdates((pos, state) -> {
|
||||||
|
if (!state.getFluidState().isEmpty() && !state.getFluidState().isStill()) {
|
||||||
|
ChunkPos chunkPos = new ChunkPos(pos);
|
||||||
|
|
||||||
|
for (Direction dir: searchDirs) {
|
||||||
|
if (mc.world.getBlockState(pos.offset(dir)).getFluidState().isStill() && !oldChunks.contains(chunkPos)) {
|
||||||
|
newChunks.add(chunkPos);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (event.packet instanceof BlockUpdateS2CPacket) {
|
||||||
|
BlockUpdateS2CPacket packet = (BlockUpdateS2CPacket) event.packet;
|
||||||
|
|
||||||
|
if (!packet.getState().getFluidState().isEmpty() && !packet.getState().getFluidState().isStill()) {
|
||||||
|
ChunkPos chunkPos = new ChunkPos(packet.getPos());
|
||||||
|
|
||||||
|
for (Direction dir: searchDirs) {
|
||||||
|
if (mc.world.getBlockState(packet.getPos().offset(dir)).getFluidState().isStill() && !oldChunks.contains(chunkPos)) {
|
||||||
|
newChunks.add(chunkPos);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
else if (event.packet instanceof ChunkDataS2CPacket && mc.world != null) {
|
||||||
|
ChunkDataS2CPacket packet = (ChunkDataS2CPacket) event.packet;
|
||||||
|
|
||||||
|
ChunkPos pos = new ChunkPos(packet.getX(), packet.getZ());
|
||||||
|
|
||||||
|
if (!newChunks.contains(pos) && mc.world.getChunkManager().getChunk(packet.getX(), packet.getZ()) == null) {
|
||||||
|
WorldChunk chunk = new WorldChunk(mc.world, pos, null);
|
||||||
|
chunk.loadFromPacket(null, packet.getReadBuffer(), new CompoundTag(), packet.getVerticalStripBitmask());
|
||||||
|
|
||||||
|
for (int x = 0; x < 16; x++) {
|
||||||
|
for (int y = 0; y < mc.world.getHeight(); y++) {
|
||||||
|
for (int z = 0; z < 16; z++) {
|
||||||
|
FluidState fluid = chunk.getFluidState(x, y, z);
|
||||||
|
|
||||||
|
if (!fluid.isEmpty() && !fluid.isStill()) {
|
||||||
|
oldChunks.add(pos);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
Reference in New Issue
Block a user