Updated transporter room so it doesn't load remote world while IDLE

This commit is contained in:
Unknown 2018-05-01 00:49:20 +02:00
parent 8b4f373e37
commit 4c51624cb2

View file

@ -65,6 +65,7 @@ import net.minecraft.world.World;
import net.minecraft.world.WorldServer; import net.minecraft.world.WorldServer;
import cpw.mods.fml.common.Optional; import cpw.mods.fml.common.Optional;
import net.minecraftforge.common.DimensionManager;
import net.minecraftforge.common.util.Constants; import net.minecraftforge.common.util.Constants;
import net.minecraftforge.common.util.ForgeDirection; import net.minecraftforge.common.util.ForgeDirection;
@ -679,7 +680,7 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
} }
} }
// compute remote universal coordinates // compute remote global position
GlobalPosition globalPositionRemoteNew = null; GlobalPosition globalPositionRemoteNew = null;
if (globalPositionBeacon != null) { if (globalPositionBeacon != null) {
globalPositionRemoteNew = globalPositionBeacon; globalPositionRemoteNew = globalPositionBeacon;
@ -731,7 +732,7 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
if ( globalPositionRemoteNew == null if ( globalPositionRemoteNew == null
|| !globalPositionRemoteNew.equals(globalPositionRemote) ) { || !globalPositionRemoteNew.equals(globalPositionRemote) ) {
globalPositionRemote = globalPositionRemoteNew; globalPositionRemote = globalPositionRemoteNew;
lockStrengthActual = 0; lockStrengthActual = 0.0D;
if (transporterState == EnumTransporterState.ENERGIZING) { if (transporterState == EnumTransporterState.ENERGIZING) {
transporterState = EnumTransporterState.ACQUIRING; transporterState = EnumTransporterState.ACQUIRING;
} }
@ -767,8 +768,11 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
} }
} }
// get remote world // get remote world, only load while acquiring or energizing
final WorldServer worldRemote = Commons.getOrCreateWorldServer(celestialObjectRemote.dimensionId); final WorldServer worldRemote;
if ( transporterState == EnumTransporterState.ACQUIRING
|| transporterState == EnumTransporterState.ENERGIZING ) {
worldRemote = Commons.getOrCreateWorldServer(celestialObjectRemote.dimensionId);
if (worldRemote == null) { if (worldRemote == null) {
WarpDrive.logger.error(String.format("Unable to initialize dimension %d for %s", WarpDrive.logger.error(String.format("Unable to initialize dimension %d for %s",
celestialObjectRemote.dimensionId, celestialObjectRemote.dimensionId,
@ -777,6 +781,9 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
reasonJammed = String.format("Unable to initialize dimension %d", celestialObjectRemote.dimensionId); reasonJammed = String.format("Unable to initialize dimension %d", celestialObjectRemote.dimensionId);
return; return;
} }
} else {
worldRemote = DimensionManager.getWorld(celestialObjectRemote.dimensionId);
}
// compute range // compute range
final double rangeActualSquared = v3Local_universal.clone().subtract(v3Remote_universal).getMagnitudeSquared(); final double rangeActualSquared = v3Local_universal.clone().subtract(v3Remote_universal).getMagnitudeSquared();
@ -901,7 +908,7 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
energyFactor = Math.max(4.0D, energyFactor); // ensure minimum energy factor for beacon activation energyFactor = Math.max(4.0D, energyFactor); // ensure minimum energy factor for beacon activation
isJammed = true; isJammed = true;
reasonJammed = "Beacon request received"; reasonJammed = "Beacon request received";
lockStrengthActual = 0; lockStrengthActual = 0.0D;
if (transporterState == EnumTransporterState.ENERGIZING) { if (transporterState == EnumTransporterState.ENERGIZING) {
transporterState = EnumTransporterState.ACQUIRING; transporterState = EnumTransporterState.ACQUIRING;
} }
@ -912,6 +919,15 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
} }
private static FocusValues getFocusValueAtCoordinates(final World world, final VectorI vLocation, final int radius) { private static FocusValues getFocusValueAtCoordinates(final World world, final VectorI vLocation, final int radius) {
// return default values if world isn't loaded
if (world == null) {
final FocusValues result = new FocusValues();
result.countRangeUpgrades = 0;
result.speed = WarpDriveConfig.TRANSPORTER_LOCKING_SPEED_IN_WILDERNESS;
result.strength = WarpDriveConfig.TRANSPORTER_LOCKING_STRENGTH_IN_WILDERNESS;
return result;
}
// scan the area // scan the area
int countBeacons = 0; int countBeacons = 0;
int countTransporters = 0; int countTransporters = 0;
@ -986,6 +1002,11 @@ public class TileEntityTransporterCore extends TileEntityAbstractEnergy implemen
} }
private static boolean isJammedTrajectory(final World world, final VectorI vSource, final VectorI vDestination, final int beamFrequency) { private static boolean isJammedTrajectory(final World world, final VectorI vSource, final VectorI vDestination, final int beamFrequency) {
// return default value if world isn't loaded
if (world == null) {
return false;
}
final VectorI vPath = vDestination.clone().translateBack(vSource); final VectorI vPath = vDestination.clone().translateBack(vSource);
final int length = (int) Math.ceil(3 * Math.sqrt(vPath.getMagnitudeSquared())); final int length = (int) Math.ceil(3 * Math.sqrt(vPath.getMagnitudeSquared()));
final Vector3 v3Delta = new Vector3(vPath.x / (double) length, vPath.y / (double) length, vPath.z / (double) length); final Vector3 v3Delta = new Vector3(vPath.x / (double) length, vPath.y / (double) length, vPath.z / (double) length);