WIP chunk packet support

This commit is contained in:
TheMode 2021-05-31 20:39:54 +02:00
parent 698469aa60
commit 8712ca364b

View File

@ -81,8 +81,9 @@ public class ChunkDataPacket implements ServerPacket, CacheablePacket {
int mask = 0; int mask = 0;
ByteBuf blocks = Unpooled.buffer(MAX_BUFFER_SIZE); ByteBuf blocks = Unpooled.buffer(MAX_BUFFER_SIZE);
final boolean fullChunk = sections.length == 0;
for (byte i = 0; i < CHUNK_SECTION_COUNT; i++) { for (byte i = 0; i < CHUNK_SECTION_COUNT; i++) {
if (false || (sections.length == CHUNK_SECTION_COUNT && sections[i] != 0)) { if (fullChunk || (sections.length == CHUNK_SECTION_COUNT && sections[i] != 0)) {
final Section section = paletteStorage.getSections()[i]; final Section section = paletteStorage.getSections()[i];
if (section == null) { if (section == null) {
// Section not loaded // Section not loaded
@ -95,7 +96,9 @@ public class ChunkDataPacket implements ServerPacket, CacheablePacket {
} }
} }
writer.writeVarInt(mask); // TODO variable size
writer.writeVarInt(1);
writer.writeLong(mask);
// TODO: don't hardcode heightmaps // TODO: don't hardcode heightmaps
// Heightmap // Heightmap
@ -163,7 +166,11 @@ public class ChunkDataPacket implements ServerPacket, CacheablePacket {
chunkX = reader.readInt(); chunkX = reader.readInt();
chunkZ = reader.readInt(); chunkZ = reader.readInt();
int mask = reader.readVarInt(); int maskCount = reader.readVarInt();
long[] masks = new long[maskCount];
for(int i=0;i<maskCount;i++){
masks[i] = reader.readLong();
}
try { try {
// TODO: Use heightmaps // TODO: Use heightmaps
// unused at the moment // unused at the moment
@ -179,6 +186,7 @@ public class ChunkDataPacket implements ServerPacket, CacheablePacket {
// Data // Data
this.paletteStorage = new PaletteStorage(8, 1); this.paletteStorage = new PaletteStorage(8, 1);
int blockArrayLength = reader.readVarInt(); int blockArrayLength = reader.readVarInt();
final long mask = masks[0]; // TODO support for variable size
for (int section = 0; section < CHUNK_SECTION_COUNT; section++) { for (int section = 0; section < CHUNK_SECTION_COUNT; section++) {
boolean hasSection = (mask & 1 << section) != 0; boolean hasSection = (mask & 1 << section) != 0;
if (!hasSection) if (!hasSection)