mirror of
https://github.com/Minestom/Minestom.git
synced 2025-01-07 00:48:28 +01:00
Improve anvil block loading performance
This commit is contained in:
parent
cb21b0baf5
commit
bad206d504
@ -88,8 +88,7 @@ public class AnvilLoader implements IChunkLoader {
|
|||||||
loadBlocks(chunk, fileChunk);
|
loadBlocks(chunk, fileChunk);
|
||||||
loadTileEntities(chunk, fileChunk);
|
loadTileEntities(chunk, fileChunk);
|
||||||
// Lights
|
// Lights
|
||||||
final var chunkSections = fileChunk.getSections();
|
for (var chunkSection : fileChunk.getSections()) {
|
||||||
for (var chunkSection : chunkSections) {
|
|
||||||
Section section = chunk.getSection(chunkSection.getY());
|
Section section = chunk.getSection(chunkSection.getY());
|
||||||
section.setSkyLight(chunkSection.getSkyLights());
|
section.setSkyLight(chunkSection.getSkyLights());
|
||||||
section.setBlockLight(chunkSection.getBlockLights());
|
section.setBlockLight(chunkSection.getBlockLights());
|
||||||
@ -116,11 +115,16 @@ public class AnvilLoader implements IChunkLoader {
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void loadBlocks(Chunk chunk, ChunkColumn fileChunk) {
|
private void loadBlocks(Chunk chunk, ChunkColumn fileChunk) {
|
||||||
for (int x = 0; x < Chunk.CHUNK_SIZE_X; x++) {
|
for (var section : fileChunk.getSections()) {
|
||||||
for (int z = 0; z < Chunk.CHUNK_SIZE_Z; z++) {
|
if (section.getEmpty()) {
|
||||||
for (int y = 0; y < 256; y++) { // TODO don't hardcode height
|
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 {
|
try {
|
||||||
final BlockState blockState = fileChunk.getBlockState(x, y, z);
|
final BlockState blockState = section.get(x, y, z);
|
||||||
Block block = Block.fromNamespaceId(blockState.getName());
|
Block block = Block.fromNamespaceId(blockState.getName());
|
||||||
if (block == null) {
|
if (block == null) {
|
||||||
// Invalid block
|
// Invalid block
|
||||||
@ -130,7 +134,7 @@ public class AnvilLoader implements IChunkLoader {
|
|||||||
if (!properties.isEmpty()) {
|
if (!properties.isEmpty()) {
|
||||||
block = block.withProperties(properties);
|
block = block.withProperties(properties);
|
||||||
}
|
}
|
||||||
chunk.setBlock(x, y, z, block);
|
chunk.setBlock(x, y + yOffset, z, block);
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
EXCEPTION_MANAGER.handleException(e);
|
EXCEPTION_MANAGER.handleException(e);
|
||||||
}
|
}
|
||||||
@ -138,6 +142,7 @@ public class AnvilLoader implements IChunkLoader {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void loadTileEntities(Chunk loadedChunk, ChunkColumn fileChunk) {
|
private void loadTileEntities(Chunk loadedChunk, ChunkColumn fileChunk) {
|
||||||
for (NBTCompound te : fileChunk.getTileEntities()) {
|
for (NBTCompound te : fileChunk.getTileEntities()) {
|
||||||
|
Loading…
Reference in New Issue
Block a user