From a6c8068d724434e214449a76f32c5af157b2b696 Mon Sep 17 00:00:00 2001 From: Unknown Date: Sat, 19 Jan 2019 16:58:27 +0100 Subject: [PATCH] Improved air generator tick rate logic --- .../TileEntityAirGeneratorTiered.java | 37 +++++++++---------- 1 file changed, 17 insertions(+), 20 deletions(-) diff --git a/src/main/java/cr0s/warpdrive/block/breathing/TileEntityAirGeneratorTiered.java b/src/main/java/cr0s/warpdrive/block/breathing/TileEntityAirGeneratorTiered.java index 22ffde26..361b043a 100644 --- a/src/main/java/cr0s/warpdrive/block/breathing/TileEntityAirGeneratorTiered.java +++ b/src/main/java/cr0s/warpdrive/block/breathing/TileEntityAirGeneratorTiered.java @@ -18,7 +18,7 @@ public class TileEntityAirGeneratorTiered extends TileEntityAbstractEnergyConsum // (none) // computed properties - private int cooldownTicks = 0; + private int tickUpdate; public TileEntityAirGeneratorTiered() { super(); @@ -38,6 +38,13 @@ public class TileEntityAirGeneratorTiered extends TileEntityAbstractEnergyConsum "HV", 2, "HV", 0); } + @Override + protected void onFirstUpdateTick() { + super.onFirstUpdateTick(); + + tickUpdate = world.rand.nextInt(WarpDriveConfig.BREATHING_AIR_GENERATION_TICKS); + } + @Override public void update() { super.update(); @@ -50,31 +57,21 @@ public class TileEntityAirGeneratorTiered extends TileEntityAbstractEnergyConsum return; } + tickUpdate--; + if (tickUpdate >= 0) { + return; + } + tickUpdate = WarpDriveConfig.BREATHING_AIR_GENERATION_TICKS; + // Air generator works only in space & hyperspace final IBlockState blockState = world.getBlockState(pos); if (CelestialObjectManager.hasAtmosphere(world, pos.getX(), pos.getZ())) { - if (blockState.getValue(BlockProperties.ACTIVE)) { - world.setBlockState(pos, blockState.withProperty(BlockProperties.ACTIVE, false)); // set disabled texture - } + updateBlockState(blockState, BlockProperties.ACTIVE, false); return; } - cooldownTicks++; - if (cooldownTicks > WarpDriveConfig.BREATHING_AIR_GENERATION_TICKS) { - final boolean isActive = releaseAir(blockState.getValue(BlockProperties.FACING)); - if (isActive) { - if (!blockState.getValue(BlockProperties.ACTIVE)) { - world.setBlockState(pos, blockState.withProperty(BlockProperties.ACTIVE, true)); // set enabled texture - } - } else { - if (blockState.getValue(BlockProperties.ACTIVE)) { - world.setBlockState(pos, blockState.withProperty(BlockProperties.ACTIVE, false)); // set disabled texture - } - } - releaseAir(blockState.getValue(BlockProperties.FACING)); - - cooldownTicks = 0; - } + final boolean isActive = releaseAir(blockState.getValue(BlockProperties.FACING)); + updateBlockState(blockState, BlockProperties.ACTIVE, isActive); } private boolean releaseAir(final EnumFacing direction) {