Improve anvil block loading performance

This commit is contained in:
TheMode 2021-07-20 23:40:23 +02:00
parent cb21b0baf5
commit bad206d504

View File

@ -88,8 +88,7 @@ public class AnvilLoader implements IChunkLoader {
loadBlocks(chunk, fileChunk);
loadTileEntities(chunk, fileChunk);
// Lights
final var chunkSections = fileChunk.getSections();
for (var chunkSection : chunkSections) {
for (var chunkSection : fileChunk.getSections()) {
Section section = chunk.getSection(chunkSection.getY());
section.setSkyLight(chunkSection.getSkyLights());
section.setBlockLight(chunkSection.getBlockLights());
@ -116,11 +115,16 @@ public class AnvilLoader implements IChunkLoader {
}
private void loadBlocks(Chunk chunk, ChunkColumn fileChunk) {
for (int x = 0; x < Chunk.CHUNK_SIZE_X; x++) {
for (int z = 0; z < Chunk.CHUNK_SIZE_Z; z++) {
for (int y = 0; y < 256; y++) { // TODO don't hardcode height
for (var section : fileChunk.getSections()) {
if (section.getEmpty()) {
continue;
}
final int yOffset = Chunk.CHUNK_SECTION_SIZE * section.getY();
for (int x = 0; x < Chunk.CHUNK_SECTION_SIZE; x++) {
for (int z = 0; z < Chunk.CHUNK_SECTION_SIZE; z++) {
for (int y = 0; y < Chunk.CHUNK_SECTION_SIZE; y++) {
try {
final BlockState blockState = fileChunk.getBlockState(x, y, z);
final BlockState blockState = section.get(x, y, z);
Block block = Block.fromNamespaceId(blockState.getName());
if (block == null) {
// Invalid block
@ -130,7 +134,7 @@ public class AnvilLoader implements IChunkLoader {
if (!properties.isEmpty()) {
block = block.withProperties(properties);
}
chunk.setBlock(x, y, z, block);
chunk.setBlock(x, y + yOffset, z, block);
} catch (Exception e) {
EXCEPTION_MANAGER.handleException(e);
}
@ -138,6 +142,7 @@ public class AnvilLoader implements IChunkLoader {
}
}
}
}
private void loadTileEntities(Chunk loadedChunk, ChunkColumn fileChunk) {
for (NBTCompound te : fileChunk.getTileEntities()) {