diff --git a/Xplat/src/main/java/vazkii/botania/common/block/block_entity/CellularBlockEntity.java b/Xplat/src/main/java/vazkii/botania/common/block/block_entity/CellularBlockEntity.java index 104106e7c5..93e6ccb470 100644 --- a/Xplat/src/main/java/vazkii/botania/common/block/block_entity/CellularBlockEntity.java +++ b/Xplat/src/main/java/vazkii/botania/common/block/block_entity/CellularBlockEntity.java @@ -67,8 +67,8 @@ public void update(Level level) { generation = nextGeneration; } - public boolean hasActiveParent(Level level) { - return flowerCoords != null && level.getBlockEntity(flowerCoords) instanceof DandelifeonBlockEntity parent && level.hasNeighborSignal(flowerCoords) && ((level.getGameTime() % DandelifeonBlockEntity.SPEED == 0) || parent.overgrowth); + public boolean hasActiveParent(DandelifeonBlockEntity dandie) { + return flowerCoords != null && dandie.getLevel().getBlockEntity(flowerCoords) instanceof DandelifeonBlockEntity parent && dandie.getLevel().hasNeighborSignal(flowerCoords) && parent.overgrowthBoost == dandie.overgrowthBoost; } public int getGeneration() { diff --git a/Xplat/src/main/java/vazkii/botania/common/block/flower/generating/DandelifeonBlockEntity.java b/Xplat/src/main/java/vazkii/botania/common/block/flower/generating/DandelifeonBlockEntity.java index bda33eacf7..122a736ab4 100644 --- a/Xplat/src/main/java/vazkii/botania/common/block/flower/generating/DandelifeonBlockEntity.java +++ b/Xplat/src/main/java/vazkii/botania/common/block/flower/generating/DandelifeonBlockEntity.java @@ -26,6 +26,7 @@ public class DandelifeonBlockEntity extends GeneratingFlowerBlockEntity { public static final int RANGE = 12; public static final int SPEED = 10; + public static final int OVERGROWN_SPEED = SPEED / 2; // private static final int MAX_GENERATIONS = 100; public static final int MAX_MANA_GENERATIONS = 100; public static final int MANA_PER_GEN = 60; @@ -58,9 +59,9 @@ public void tickFlower() { super.tickFlower(); if (!getLevel().isClientSide) { - if ((getLevel().getGameTime() % SPEED == 0 || (getLevel().getGameTime() % (SPEED / 2) == 0 && overgrowth)) && getLevel().hasNeighborSignal(getBlockPos())) { + if (shouldTick(getLevel().getGameTime())) { runSimulation(); - } else if ((getLevel().getGameTime() + 1) % SPEED == 0 || ((getLevel().getGameTime() + 1) % (SPEED / 2) == 0 && overgrowth)) { + } else if (shouldTick(getLevel().getGameTime() + 1)) { int diameter = radius * 2; for (int i = 0; i <= diameter; i++) { @@ -76,6 +77,10 @@ public void tickFlower() { } } + private static boolean shouldTick(long gameTime) { + return (gameTime % SPEED == 0 || (gameTime % (OVERGROWN_SPEED) == 0 && overgrowthBoost)) && getLevel().hasNeighborSignal(getBlockPos()); + } + private void runSimulation() { var table = new CellTable(radius, this); List changes = new ArrayList<>(); @@ -186,7 +191,7 @@ public CellTable(int range, DandelifeonBlockEntity dandie) { private static int getCellGeneration(BlockPos pos, DandelifeonBlockEntity dandie, boolean onBoundary) { BlockEntity tile = dandie.getLevel().getBlockEntity(pos); if (tile instanceof CellularBlockEntity cell) { - return onBoundary ? (cell.hasActiveParent(dandie.getLevel()) ? Cell.boundaryPunish(cell.getGeneration()) : Cell.DEAD) : cell.getGeneration(); + return onBoundary ? (cell.hasActiveParent(dandie) ? Cell.boundaryPunish(cell.getGeneration()) : Cell.DEAD) : cell.getGeneration(); } return Cell.DEAD;