Changes for KL and cpw
Added set/add for KL Added perdition calculator for cpw
This commit is contained in:
parent
91a3ac95c6
commit
b92c81f638
1 changed files with 74 additions and 15 deletions
|
@ -14,18 +14,42 @@ import buildcraft.api.core.SafeTimeTracker;
|
||||||
|
|
||||||
public final class PowerProvider {
|
public final class PowerProvider {
|
||||||
|
|
||||||
|
public static class PerditionCalculator {
|
||||||
|
|
||||||
|
protected SafeTimeTracker energyLossTracker = new SafeTimeTracker();
|
||||||
|
private final float powerLoss;
|
||||||
|
|
||||||
|
public PerditionCalculator() {
|
||||||
|
powerLoss = 10;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PerditionCalculator(float powerLoss) {
|
||||||
|
if (powerLoss < 0) {
|
||||||
|
powerLoss = 10;
|
||||||
|
}
|
||||||
|
this.powerLoss = powerLoss;
|
||||||
|
}
|
||||||
|
|
||||||
|
public float applyPerdition(PowerProvider provider, float current) {
|
||||||
|
current -= powerLoss;
|
||||||
|
if (current < 0) {
|
||||||
|
current = 0;
|
||||||
|
}
|
||||||
|
return current;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
public static final PerditionCalculator DEFUALT_PERDITION = new PerditionCalculator(10);
|
||||||
private int minEnergyReceived;
|
private int minEnergyReceived;
|
||||||
private int maxEnergyReceived;
|
private int maxEnergyReceived;
|
||||||
private int maxEnergyStored;
|
private int maxEnergyStored;
|
||||||
private int minActivationEnergy;
|
private int minActivationEnergy;
|
||||||
private float energyStored = 0;
|
private float energyStored = 0;
|
||||||
private int powerLoss = 1;
|
|
||||||
private int powerLossRegularity = 1;
|
|
||||||
public final boolean canAcceptPowerFromPipes;
|
public final boolean canAcceptPowerFromPipes;
|
||||||
private SafeTimeTracker energyLossTracker = new SafeTimeTracker();
|
|
||||||
private SafeTimeTracker doWorkTracker = new SafeTimeTracker();
|
private SafeTimeTracker doWorkTracker = new SafeTimeTracker();
|
||||||
|
private SafeTimeTracker energyLossTracker = new SafeTimeTracker();
|
||||||
public final int[] powerSources = {0, 0, 0, 0, 0, 0};
|
public final int[] powerSources = {0, 0, 0, 0, 0, 0};
|
||||||
public final IPowerReceptor receptor;
|
public final IPowerReceptor receptor;
|
||||||
|
private PerditionCalculator perdition;
|
||||||
|
|
||||||
public PowerProvider(IPowerReceptor receptor) {
|
public PowerProvider(IPowerReceptor receptor) {
|
||||||
this(receptor, true);
|
this(receptor, true);
|
||||||
|
@ -63,11 +87,6 @@ public final class PowerProvider {
|
||||||
this.minActivationEnergy = minActivationEnergy;
|
this.minActivationEnergy = minActivationEnergy;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void configurePowerPerdition(int powerLoss, int powerLossRegularity) {
|
|
||||||
this.powerLoss = powerLoss;
|
|
||||||
this.powerLossRegularity = powerLossRegularity;
|
|
||||||
}
|
|
||||||
|
|
||||||
public void update() {
|
public void update() {
|
||||||
applyPerdition();
|
applyPerdition();
|
||||||
applyWork();
|
applyWork();
|
||||||
|
@ -79,13 +98,32 @@ public final class PowerProvider {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void configurePowerPerdition(int powerLoss, int powerLossRegularity) {
|
||||||
|
if (powerLossRegularity == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
perdition = new PerditionCalculator((float) powerLoss / (float) powerLossRegularity * 10.0F);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setPerdition(PerditionCalculator perdition) {
|
||||||
|
this.perdition = perdition;
|
||||||
|
}
|
||||||
|
|
||||||
|
public PerditionCalculator getPerdition() {
|
||||||
|
if (perdition == null)
|
||||||
|
return DEFUALT_PERDITION;
|
||||||
|
return perdition;
|
||||||
|
}
|
||||||
|
|
||||||
private void applyPerdition() {
|
private void applyPerdition() {
|
||||||
if (powerLoss > 0) {
|
if (energyStored > 0) {
|
||||||
TileEntity tile = (TileEntity) receptor;
|
TileEntity tile = (TileEntity) receptor;
|
||||||
if (energyLossTracker.markTimeIfDelay(tile.worldObj, powerLossRegularity)) {
|
if (energyLossTracker.markTimeIfDelay(tile.worldObj, 10)) {
|
||||||
energyStored -= powerLoss;
|
float newEnergy = getPerdition().applyPerdition(this, energyStored);
|
||||||
if (energyStored < 0) {
|
if (newEnergy == 0 || newEnergy < energyStored) {
|
||||||
energyStored = 0;
|
energyStored = newEnergy;
|
||||||
|
} else {
|
||||||
|
energyStored = DEFUALT_PERDITION.applyPerdition(this, energyStored);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -144,21 +182,42 @@ public final class PowerProvider {
|
||||||
}
|
}
|
||||||
|
|
||||||
public float receiveEnergy(float quantity, ForgeDirection from) {
|
public float receiveEnergy(float quantity, ForgeDirection from) {
|
||||||
|
if (from != null)
|
||||||
powerSources[from.ordinal()] = 2;
|
powerSources[from.ordinal()] = 2;
|
||||||
|
|
||||||
|
quantity = addEnergy(quantity);
|
||||||
|
applyWork();
|
||||||
|
|
||||||
|
return quantity;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Internal use only you should NEVER call this function on a PowerProvider
|
||||||
|
* you don't own.
|
||||||
|
*/
|
||||||
|
public float addEnergy(float quantity) {
|
||||||
energyStored += quantity;
|
energyStored += quantity;
|
||||||
|
|
||||||
if (energyStored > maxEnergyStored) {
|
if (energyStored > maxEnergyStored) {
|
||||||
quantity -= energyStored - maxEnergyStored;
|
quantity -= energyStored - maxEnergyStored;
|
||||||
energyStored = maxEnergyStored;
|
energyStored = maxEnergyStored;
|
||||||
|
} else if (energyStored < 0) {
|
||||||
|
energyStored = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
applyPerdition();
|
applyPerdition();
|
||||||
applyWork();
|
|
||||||
|
|
||||||
return quantity;
|
return quantity;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Internal use only you should NEVER call this function on a PowerProvider
|
||||||
|
* you don't own.
|
||||||
|
*/
|
||||||
|
public void setEnergy(float energy) {
|
||||||
|
this.energyStored = energy;
|
||||||
|
}
|
||||||
|
|
||||||
public boolean isPowerSource(ForgeDirection from) {
|
public boolean isPowerSource(ForgeDirection from) {
|
||||||
return powerSources[from.ordinal()] != 0;
|
return powerSources[from.ordinal()] != 0;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue