2013-05-07 22:12:07 +02:00
|
|
|
package ic2.api.reactor;
|
2013-04-13 16:35:13 +02:00
|
|
|
|
|
|
|
import net.minecraft.item.ItemStack;
|
2013-08-22 17:36:31 +02:00
|
|
|
import net.minecraft.util.ChunkCoordinates;
|
2013-04-13 16:35:13 +02:00
|
|
|
import net.minecraft.world.World;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Interface implemented by the tile entity of nuclear reactors.
|
|
|
|
*/
|
|
|
|
public interface IReactor {
|
|
|
|
/**
|
|
|
|
* Get the reactor's position in the world.
|
|
|
|
*
|
|
|
|
* @return Position of the reactor
|
|
|
|
*/
|
|
|
|
public ChunkCoordinates getPosition();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get the reactor's corresponding world.
|
|
|
|
*
|
|
|
|
* @return The reactor's world
|
|
|
|
*/
|
|
|
|
public World getWorld();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get the reactor's heat.
|
|
|
|
*
|
|
|
|
* @return The reactor's heat
|
|
|
|
*/
|
|
|
|
public int getHeat();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Set the reactor's heat.
|
|
|
|
*
|
|
|
|
* @param heat reactor heat
|
|
|
|
*/
|
|
|
|
public void setHeat(int heat);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Increase the reactor's heat.
|
|
|
|
*
|
|
|
|
* Use negative values to decrease.
|
|
|
|
*
|
|
|
|
* @param amount amount of heat to add
|
|
|
|
* @return The reactor's heat after adding the specified amount
|
|
|
|
*/
|
|
|
|
public int addHeat(int amount);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get the reactor's maximum heat before exploding.
|
|
|
|
*
|
|
|
|
* @return Maximum heat value
|
|
|
|
*/
|
|
|
|
public int getMaxHeat();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Set the reactor's stored maxHeat variable.
|
|
|
|
* Used by plating to increase the reactors MaxHeat capacity.
|
|
|
|
* Needs to be called during each cycle process.
|
|
|
|
*/
|
|
|
|
public void setMaxHeat(int newMaxHeat);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-11-21 22:50:40 +01:00
|
|
|
/**
|
|
|
|
* add Heat to a EmitHeat Buffer
|
|
|
|
* for use in Reactor operation.. need to be use
|
|
|
|
* for all Componetents with self-cooling
|
|
|
|
* no more magic heat disappear
|
|
|
|
*/
|
|
|
|
|
|
|
|
|
|
|
|
public void addEmitHeat(int heat);
|
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get's the reactor's HEM (Heat Effect Modifier)
|
|
|
|
* Basic value is 1.0F.
|
|
|
|
* Reducing the value causes a weakening/reduction of the heat-based sideeffects of reactors
|
|
|
|
* (F.e. water evaporation, melting, damaging entitys, etc)
|
|
|
|
*
|
|
|
|
* @return HEM
|
|
|
|
*/
|
|
|
|
public float getHeatEffectModifier();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Set's the reactor's HEM
|
|
|
|
* Needs to be called during each cycle process.
|
|
|
|
*/
|
|
|
|
public void setHeatEffectModifier(float newHEM);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get the reactor's energy output.
|
|
|
|
*
|
|
|
|
* @return Energy output, not multiplied by the base EU/t value
|
|
|
|
*/
|
2013-08-22 17:36:31 +02:00
|
|
|
public float getReactorEnergyOutput();
|
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Add's the given amount of energy to the Reactor's output.
|
|
|
|
*
|
|
|
|
* @return Energy output after adding the value, not multiplied by the base EU/t value
|
|
|
|
*/
|
2013-05-07 22:12:07 +02:00
|
|
|
public float addOutput(float energy);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get the item at the specified grid coordinates.
|
|
|
|
*
|
2013-12-26 21:00:08 +01:00
|
|
|
* @param x X position of the item, out of bounds returns null
|
|
|
|
* @param y Y position of the item, out of bounds returns null
|
2013-04-13 16:35:13 +02:00
|
|
|
* @return The item or null if there is no item
|
|
|
|
*/
|
|
|
|
public ItemStack getItemAt(int x, int y);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Set the item at the specified grid coordinates.
|
|
|
|
*
|
2013-12-26 21:00:08 +01:00
|
|
|
* @param x X position of the item, out of bounds is a no-op
|
|
|
|
* @param y Y position of the item, out of bounds is a no-op
|
2013-04-13 16:35:13 +02:00
|
|
|
* @param item The item to set.
|
|
|
|
*/
|
|
|
|
public void setItemAt(int x, int y, ItemStack item);
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Explode the reactor.
|
|
|
|
*/
|
|
|
|
public void explode();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get the reactor's tick rate (game ticks per reactor tick).
|
|
|
|
*
|
|
|
|
* @return Tick rate
|
|
|
|
*/
|
|
|
|
public int getTickRate();
|
2013-08-22 17:36:31 +02:00
|
|
|
|
2013-04-13 16:35:13 +02:00
|
|
|
/**
|
|
|
|
* Get whether the reactor is active and supposed to produce energy
|
|
|
|
* @return Whether the reactor is active
|
|
|
|
*/
|
|
|
|
public boolean produceEnergy();
|
|
|
|
}
|