From fa947cb2d5bae25b14c1983af5a15c8320bcca38 Mon Sep 17 00:00:00 2001 From: Mouse Date: Fri, 8 Dec 2023 22:11:32 +0800 Subject: [PATCH] fix: prevent displaying the last glass block after destroying oit in the chunk --- .../graphics/voxel/chunk/DrawableChunk.java | 41 +++++++++++-------- 1 file changed, 23 insertions(+), 18 deletions(-) diff --git a/client/src/main/java/engine/graphics/voxel/chunk/DrawableChunk.java b/client/src/main/java/engine/graphics/voxel/chunk/DrawableChunk.java index 7622e24d..41786d99 100644 --- a/client/src/main/java/engine/graphics/voxel/chunk/DrawableChunk.java +++ b/client/src/main/java/engine/graphics/voxel/chunk/DrawableChunk.java @@ -12,7 +12,9 @@ import org.joml.Vector3ic; import java.util.HashMap; +import java.util.HashSet; import java.util.Map; +import java.util.Set; public final class DrawableChunk extends Geometry { @@ -28,7 +30,6 @@ public final class DrawableChunk extends Geometry { public DrawableChunk(ChunkRenderer renderer) { this.renderer = renderer; - setBounds(boundingBox); setTexture(VoxelGraphicsHelper.getVoxelTextureAtlas().getTexture()); setVisible(false); } @@ -77,18 +78,26 @@ public void finishBake(Map buffers) { if (pieces == null) { pieces = new HashMap<>(); } - buffers.forEach((type, vertexDataBuffer) -> { - pieces.computeIfAbsent(type, key -> { - var piece = new DrawableChunkPiece(key); - piece.setTexture(this.getTexture()); - piece.setBounds(boundingBox); - DrawableChunk.this.addChild(piece); - return piece; - }).uploadData(vertexDataBuffer); - }); + + buffers.forEach((renderType, buffer) -> pieces.computeIfAbsent(renderType, this::createPiece).uploadData(buffer)); + + Set invisibleRenderTypes = new HashSet<>(pieces.keySet()); + invisibleRenderTypes.removeAll(buffers.keySet()); + for (RenderType invisibleRenderType : invisibleRenderTypes) { + pieces.get(invisibleRenderType).setVisible(false); + } + baking = false; } + private DrawableChunkPiece createPiece(RenderType renderType) { + var piece = new DrawableChunkPiece(renderType); + piece.setTexture(getTexture()); + piece.setBounds(boundingBox); + addChild(piece); + return piece; + } + public void terminateBake() { baking = false; } @@ -98,21 +107,17 @@ public boolean isDisposed() { } private static class DrawableChunkPiece extends Geometry { - private final RenderType type; - private SingleBufMesh mesh; + private final SingleBufMesh mesh; private DrawableChunkPiece(RenderType type) { - this.type = type; + mesh = SingleBufMesh.builder().setDynamic().drawMode(DrawMode.TRIANGLES).build(); setRenderType(type); - setMesh(mesh = SingleBufMesh.builder().setDynamic().drawMode(DrawMode.TRIANGLES).build()); + setMesh(mesh); } public void uploadData(VertexDataBuffer buffer) { mesh.uploadData(buffer); - } - - public RenderType getType() { - return type; + setVisible(true); } } }