Mirror von
https://github.com/ViaVersion/ViaBackwards.git
synchronisiert 2024-11-20 06:50:10 +01:00
Fix multi block change
Dieser Commit ist enthalten in:
Ursprung
c75f497c79
Commit
6738b2a16b
@ -4,7 +4,6 @@ import nl.matsv.viabackwards.api.entities.storage.EntityTracker;
|
|||||||
import nl.matsv.viabackwards.api.rewriters.TranslatableRewriter;
|
import nl.matsv.viabackwards.api.rewriters.TranslatableRewriter;
|
||||||
import nl.matsv.viabackwards.protocol.protocol1_16_4to1_17.Protocol1_16_4To1_17;
|
import nl.matsv.viabackwards.protocol.protocol1_16_4to1_17.Protocol1_16_4To1_17;
|
||||||
import us.myles.ViaVersion.api.PacketWrapper;
|
import us.myles.ViaVersion.api.PacketWrapper;
|
||||||
import us.myles.ViaVersion.api.data.UserConnection;
|
|
||||||
import us.myles.ViaVersion.api.minecraft.BlockChangeRecord;
|
import us.myles.ViaVersion.api.minecraft.BlockChangeRecord;
|
||||||
import us.myles.ViaVersion.api.minecraft.chunks.Chunk;
|
import us.myles.ViaVersion.api.minecraft.chunks.Chunk;
|
||||||
import us.myles.ViaVersion.api.minecraft.chunks.ChunkSection;
|
import us.myles.ViaVersion.api.minecraft.chunks.ChunkSection;
|
||||||
@ -162,18 +161,14 @@ public class BlockItemPackets1_17 extends nl.matsv.viabackwards.api.rewriters.It
|
|||||||
map(Type.LONG); // Chunk pos
|
map(Type.LONG); // Chunk pos
|
||||||
map(Type.BOOLEAN); // Suppress light updates
|
map(Type.BOOLEAN); // Suppress light updates
|
||||||
handler((wrapper) -> {
|
handler((wrapper) -> {
|
||||||
// Cancel if above the 256 block limit
|
// Remove sections below y 0 and above 255
|
||||||
long chunkPos = wrapper.get(Type.LONG, 0);
|
long chunkPos = wrapper.get(Type.LONG, 0);
|
||||||
int chunkY = (int) (chunkPos << 44 >> 44);
|
int chunkY = (int) (chunkPos << 44 >> 44);
|
||||||
int flattenedChunkY = getFlattenedYSection(wrapper.user(), chunkY);
|
if (chunkY < 0 || chunkY > 15) {
|
||||||
if (flattenedChunkY < 0 || flattenedChunkY > 15) {
|
|
||||||
wrapper.cancel();
|
wrapper.cancel();
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Encode changed y pos
|
|
||||||
wrapper.set(Type.LONG, 0, encodeChunkPos(decodeChunkX(chunkPos), flattenedChunkY, decodeChunkZ(chunkPos)));
|
|
||||||
|
|
||||||
BlockChangeRecord[] records = wrapper.passthrough(Type.VAR_LONG_BLOCK_CHANGE_RECORD_ARRAY);
|
BlockChangeRecord[] records = wrapper.passthrough(Type.VAR_LONG_BLOCK_CHANGE_RECORD_ARRAY);
|
||||||
for (BlockChangeRecord record : records) {
|
for (BlockChangeRecord record : records) {
|
||||||
record.setBlockId(protocol.getMappingData().getNewBlockStateId(record.getBlockId()));
|
record.setBlockId(protocol.getMappingData().getNewBlockStateId(record.getBlockId()));
|
||||||
@ -272,29 +267,4 @@ public class BlockItemPackets1_17 extends nl.matsv.viabackwards.api.rewriters.It
|
|||||||
}
|
}
|
||||||
return cutMask;
|
return cutMask;
|
||||||
}
|
}
|
||||||
|
|
||||||
private int getFlattenedYSection(UserConnection connection, int chunkSectionY) {
|
|
||||||
EntityTracker tracker = connection.get(EntityTracker.class);
|
|
||||||
return chunkSectionY + (tracker.getCurrentMinY() << 4);
|
|
||||||
}
|
|
||||||
|
|
||||||
private long encodeChunkPos(int chunkX, int chunkY, int chunkZ) {
|
|
||||||
long l = 0L;
|
|
||||||
l |= (chunkX & 0x3FFFFFL) << 42;
|
|
||||||
l |= (chunkY & 0xFFFFFL);
|
|
||||||
l |= (chunkZ & 0x3FFFFFL) << 20;
|
|
||||||
return l;
|
|
||||||
}
|
|
||||||
|
|
||||||
private int decodeChunkX(long chunkPos) {
|
|
||||||
return (int) (chunkPos >> 42);
|
|
||||||
}
|
|
||||||
|
|
||||||
private int decodeChunkY(long chunkPos) {
|
|
||||||
return (int) (chunkPos << 44 >> 44);
|
|
||||||
}
|
|
||||||
|
|
||||||
private int decodeChunkZ(long chunkPos) {
|
|
||||||
return (int) (chunkPos << 22 >> 42);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
Laden…
In neuem Issue referenzieren
Einen Benutzer sperren