mirror of
https://github.com/HbmMods/Hbm-s-Nuclear-Tech-GIT.git
synced 2026-01-25 10:32:49 +00:00
Added vent Carbon Dioxide function in Zirnox for OpenComputers
This commit is contained in:
parent
40379c75b0
commit
b7d416cd8a
@ -60,7 +60,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
public FluidTank carbonDioxide;
|
public FluidTank carbonDioxide;
|
||||||
public FluidTank water;
|
public FluidTank water;
|
||||||
protected int output;
|
protected int output;
|
||||||
|
|
||||||
private static final int[] slots_io = new int[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23 };
|
private static final int[] slots_io = new int[] { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23 };
|
||||||
|
|
||||||
public static final HashMap<ComparableStack, ItemStack> fuelMap = new HashMap<ComparableStack, ItemStack>();
|
public static final HashMap<ComparableStack, ItemStack> fuelMap = new HashMap<ComparableStack, ItemStack>();
|
||||||
@ -89,7 +89,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
public String getName() {
|
public String getName() {
|
||||||
return "container.zirnox";
|
return "container.zirnox";
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int[] getAccessibleSlotsFromSide(int side) {
|
public int[] getAccessibleSlotsFromSide(int side) {
|
||||||
return slots_io;
|
return slots_io;
|
||||||
@ -156,7 +156,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
case 11: return new int[] { 4, 10, 12, 18 };
|
case 11: return new int[] { 4, 10, 12, 18 };
|
||||||
case 12: return new int[] { 5, 11, 13, 19 };
|
case 12: return new int[] { 5, 11, 13, 19 };
|
||||||
case 13: return new int[] { 6, 12, 20 };
|
case 13: return new int[] { 6, 12, 20 };
|
||||||
case 14: return new int[] { 7, 15, 21 };
|
case 14: return new int[] { 7, 15, 21 };
|
||||||
case 15: return new int[] { 8, 14, 16, 22 };
|
case 15: return new int[] { 8, 14, 16, 22 };
|
||||||
case 16: return new int[] { 9, 15, 23 };
|
case 16: return new int[] { 9, 15, 23 };
|
||||||
case 17: return new int[] { 10, 18 };
|
case 17: return new int[] { 10, 18 };
|
||||||
@ -177,14 +177,14 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
if(!worldObj.isRemote) {
|
if(!worldObj.isRemote) {
|
||||||
|
|
||||||
this.output = 0;
|
this.output = 0;
|
||||||
|
|
||||||
if(worldObj.getTotalWorldTime() % 20 == 0) {
|
if(worldObj.getTotalWorldTime() % 20 == 0) {
|
||||||
this.updateConnections();
|
this.updateConnections();
|
||||||
}
|
}
|
||||||
|
|
||||||
carbonDioxide.loadTank(24, 26, slots);
|
carbonDioxide.loadTank(24, 26, slots);
|
||||||
water.loadTank(25, 27, slots);
|
water.loadTank(25, 27, slots);
|
||||||
|
|
||||||
if(isOn) {
|
if(isOn) {
|
||||||
for(int i = 0; i < 24; i++) {
|
for(int i = 0; i < 24; i++) {
|
||||||
|
|
||||||
@ -196,7 +196,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
//2(fill) + (x * fill%)
|
//2(fill) + (x * fill%)
|
||||||
this.pressure = (this.carbonDioxide.getFill() * 2) + (int)((float)this.heat * ((float)this.carbonDioxide.getFill() / (float)this.carbonDioxide.getMaxFill()));
|
this.pressure = (this.carbonDioxide.getFill() * 2) + (int)((float)this.heat * ((float)this.carbonDioxide.getFill() / (float)this.carbonDioxide.getMaxFill()));
|
||||||
|
|
||||||
@ -208,9 +208,9 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
} else {
|
} else {
|
||||||
this.heat -= 10;
|
this.heat -= 10;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
for(DirPos pos : getConPos()) {
|
for(DirPos pos : getConPos()) {
|
||||||
this.sendFluid(steam, worldObj, pos.getX(), pos.getY(), pos.getZ(), pos.getDir());
|
this.sendFluid(steam, worldObj, pos.getX(), pos.getY(), pos.getZ(), pos.getDir());
|
||||||
}
|
}
|
||||||
@ -244,16 +244,16 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void generateSteam() {
|
private void generateSteam() {
|
||||||
|
|
||||||
// function of SHS produced per tick
|
// function of SHS produced per tick
|
||||||
// (heat - 10256)/100000 * steamFill (max efficiency at 14b) * 25 * 5 (should get rid of any rounding errors)
|
// (heat - 10256)/100000 * steamFill (max efficiency at 14b) * 25 * 5 (should get rid of any rounding errors)
|
||||||
if(this.heat > 10256) {
|
if(this.heat > 10256) {
|
||||||
int cycle = (int)((((float)heat - 10256F) / (float)maxHeat) * Math.min(((float)carbonDioxide.getFill() / 14000F), 1F) * 25F * 5F);
|
int cycle = (int)((((float)heat - 10256F) / (float)maxHeat) * Math.min(((float)carbonDioxide.getFill() / 14000F), 1F) * 25F * 5F);
|
||||||
this.output = cycle;
|
this.output = cycle;
|
||||||
|
|
||||||
water.setFill(water.getFill() - cycle);
|
water.setFill(water.getFill() - cycle);
|
||||||
steam.setFill(steam.getFill() + cycle);
|
steam.setFill(steam.getFill() + cycle);
|
||||||
|
|
||||||
if(water.getFill() < 0)
|
if(water.getFill() < 0)
|
||||||
water.setFill(0);
|
water.setFill(0);
|
||||||
|
|
||||||
@ -301,7 +301,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
for(int i = 0; i < decay; i++) {
|
for(int i = 0; i < decay; i++) {
|
||||||
this.heat += num.heat;
|
this.heat += num.heat;
|
||||||
ItemZirnoxRod.incrementLifeTime(slots[id]);
|
ItemZirnoxRod.incrementLifeTime(slots[id]);
|
||||||
|
|
||||||
if(ItemZirnoxRod.getLifeTime(slots[id]) > num.maxLife) {
|
if(ItemZirnoxRod.getLifeTime(slots[id]) > num.maxLife) {
|
||||||
slots[id] = fuelMap.get(new ComparableStack(getStackInSlot(id))).copy();
|
slots[id] = fuelMap.get(new ComparableStack(getStackInSlot(id))).copy();
|
||||||
break;
|
break;
|
||||||
@ -338,16 +338,16 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
}
|
}
|
||||||
|
|
||||||
private void zirnoxDebris() {
|
private void zirnoxDebris() {
|
||||||
|
|
||||||
for(int i = 0; i < 2; i++) {
|
for(int i = 0; i < 2; i++) {
|
||||||
spawnDebris(DebrisType.EXCHANGER);
|
spawnDebris(DebrisType.EXCHANGER);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(int i = 0; i < 20; i++) {
|
for(int i = 0; i < 20; i++) {
|
||||||
spawnDebris(DebrisType.CONCRETE);
|
spawnDebris(DebrisType.CONCRETE);
|
||||||
spawnDebris(DebrisType.BLANK);
|
spawnDebris(DebrisType.BLANK);
|
||||||
}
|
}
|
||||||
|
|
||||||
for(int i = 0; i < 10; i++) {
|
for(int i = 0; i < 10; i++) {
|
||||||
spawnDebris(DebrisType.ELEMENT);
|
spawnDebris(DebrisType.ELEMENT);
|
||||||
spawnDebris(DebrisType.GRAPHITE);
|
spawnDebris(DebrisType.GRAPHITE);
|
||||||
@ -369,14 +369,14 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
worldObj.createExplosion(null, this.xCoord, this.yCoord + 3, this.zCoord, 12.0F, true);
|
worldObj.createExplosion(null, this.xCoord, this.yCoord + 3, this.zCoord, 12.0F, true);
|
||||||
zirnoxDebris();
|
zirnoxDebris();
|
||||||
ExplosionNukeGeneric.waste(worldObj, this.xCoord, this.yCoord, this.zCoord, 35);
|
ExplosionNukeGeneric.waste(worldObj, this.xCoord, this.yCoord, this.zCoord, 35);
|
||||||
|
|
||||||
List<EntityPlayer> players = worldObj.getEntitiesWithinAABB(EntityPlayer.class,
|
List<EntityPlayer> players = worldObj.getEntitiesWithinAABB(EntityPlayer.class,
|
||||||
AxisAlignedBB.getBoundingBox(xCoord + 0.5, yCoord + 0.5, zCoord + 0.5, xCoord + 0.5, yCoord + 0.5, zCoord + 0.5).expand(100, 100, 100));
|
AxisAlignedBB.getBoundingBox(xCoord + 0.5, yCoord + 0.5, zCoord + 0.5, xCoord + 0.5, yCoord + 0.5, zCoord + 0.5).expand(100, 100, 100));
|
||||||
|
|
||||||
for(EntityPlayer player : players) {
|
for(EntityPlayer player : players) {
|
||||||
player.triggerAchievement(MainRegistry.achZIRNOXBoom);
|
player.triggerAchievement(MainRegistry.achZIRNOXBoom);
|
||||||
}
|
}
|
||||||
|
|
||||||
if(MobConfig.enableElementals) {
|
if(MobConfig.enableElementals) {
|
||||||
for(EntityPlayer player : players) {
|
for(EntityPlayer player : players) {
|
||||||
player.getEntityData().getCompoundTag(EntityPlayer.PERSISTED_NBT_TAG).setBoolean("radMark", true);
|
player.getEntityData().getCompoundTag(EntityPlayer.PERSISTED_NBT_TAG).setBoolean("radMark", true);
|
||||||
@ -390,11 +390,11 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
this.trySubscribe(carbonDioxide.getTankType(), worldObj, pos.getX(), pos.getY(), pos.getZ(), pos.getDir());
|
this.trySubscribe(carbonDioxide.getTankType(), worldObj, pos.getX(), pos.getY(), pos.getZ(), pos.getDir());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
private DirPos[] getConPos() {
|
private DirPos[] getConPos() {
|
||||||
ForgeDirection dir = ForgeDirection.getOrientation(this.getBlockMetadata() - BlockDummyable.offset);
|
ForgeDirection dir = ForgeDirection.getOrientation(this.getBlockMetadata() - BlockDummyable.offset);
|
||||||
ForgeDirection rot = dir.getRotation(ForgeDirection.UP);
|
ForgeDirection rot = dir.getRotation(ForgeDirection.UP);
|
||||||
|
|
||||||
return new DirPos[] {
|
return new DirPos[] {
|
||||||
new DirPos(this.xCoord + rot.offsetX * 3, this.yCoord + 1, this.zCoord + rot.offsetZ * 3, rot),
|
new DirPos(this.xCoord + rot.offsetX * 3, this.yCoord + 1, this.zCoord + rot.offsetZ * 3, rot),
|
||||||
new DirPos(this.xCoord + rot.offsetX * 3, this.yCoord + 3, this.zCoord + rot.offsetZ * 3, rot),
|
new DirPos(this.xCoord + rot.offsetX * 3, this.yCoord + 3, this.zCoord + rot.offsetZ * 3, rot),
|
||||||
@ -420,25 +420,25 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
public double getMaxRenderDistanceSquared() {
|
public double getMaxRenderDistanceSquared() {
|
||||||
return 65536.0D;
|
return 65536.0D;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean hasPermission(EntityPlayer player) {
|
public boolean hasPermission(EntityPlayer player) {
|
||||||
return Vec3.createVectorHelper(xCoord - player.posX, yCoord - player.posY, zCoord - player.posZ).lengthVector() < 20;
|
return Vec3.createVectorHelper(xCoord - player.posX, yCoord - player.posY, zCoord - player.posZ).lengthVector() < 20;
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void receiveControl(NBTTagCompound data) {
|
public void receiveControl(NBTTagCompound data) {
|
||||||
if(data.hasKey("control")) {
|
if(data.hasKey("control")) {
|
||||||
this.isOn = !this.isOn;
|
this.isOn = !this.isOn;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(data.hasKey("vent")) {
|
if(data.hasKey("vent")) {
|
||||||
int fill = this.carbonDioxide.getFill();
|
int fill = this.carbonDioxide.getFill();
|
||||||
this.carbonDioxide.setFill(fill - 1000);
|
this.carbonDioxide.setFill(fill - 1000);
|
||||||
if(this.carbonDioxide.getFill() < 0)
|
if(this.carbonDioxide.getFill() < 0)
|
||||||
this.carbonDioxide.setFill(0);
|
this.carbonDioxide.setFill(0);
|
||||||
}
|
}
|
||||||
|
|
||||||
this.markDirty();
|
this.markDirty();
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -456,7 +456,7 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
public FluidTank[] getAllTanks() {
|
public FluidTank[] getAllTanks() {
|
||||||
return new FluidTank[] { water, steam, carbonDioxide };
|
return new FluidTank[] { water, steam, carbonDioxide };
|
||||||
}
|
}
|
||||||
|
|
||||||
// do some opencomputer stuff
|
// do some opencomputer stuff
|
||||||
@Override
|
@Override
|
||||||
@Optional.Method(modid = "OpenComputers")
|
@Optional.Method(modid = "OpenComputers")
|
||||||
@ -481,12 +481,12 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
public Object[] getWater(Context context, Arguments args) {
|
public Object[] getWater(Context context, Arguments args) {
|
||||||
return new Object[] {water.getFill()};
|
return new Object[] {water.getFill()};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Callback(direct = true)
|
@Callback(direct = true)
|
||||||
@Optional.Method(modid = "OpenComputers")
|
@Optional.Method(modid = "OpenComputers")
|
||||||
public Object[] getSteam(Context context, Arguments args) {
|
public Object[] getSteam(Context context, Arguments args) {
|
||||||
return new Object[] {steam.getFill()};
|
return new Object[] {steam.getFill()};
|
||||||
}
|
}
|
||||||
|
|
||||||
@Callback(direct = true)
|
@Callback(direct = true)
|
||||||
@Optional.Method(modid = "OpenComputers")
|
@Optional.Method(modid = "OpenComputers")
|
||||||
@ -513,6 +513,17 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
return new Object[] {};
|
return new Object[] {};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Callback(direct = true)
|
||||||
|
@Optional.Method(modid = "OpenComputers")
|
||||||
|
public Object[] ventCarbonDioxide(Context context, Arguments args) {
|
||||||
|
int ventAmount = args.optInteger(0, 1000); // Get how much CO2 to vent in mB (1000mB default)
|
||||||
|
int fill = this.carbonDioxide.getFill();
|
||||||
|
this.carbonDioxide.setFill(fill - ventAmount);
|
||||||
|
if(this.carbonDioxide.getFill() < 0)
|
||||||
|
this.carbonDioxide.setFill(0);
|
||||||
|
return new Object[] {};
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@Optional.Method(modid = "OpenComputers")
|
@Optional.Method(modid = "OpenComputers")
|
||||||
public String[] methods() {
|
public String[] methods() {
|
||||||
@ -524,7 +535,8 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
"getCarbonDioxide",
|
"getCarbonDioxide",
|
||||||
"isActive",
|
"isActive",
|
||||||
"getInfo",
|
"getInfo",
|
||||||
"setActive"
|
"setActive",
|
||||||
|
"ventCarbonDioxide"
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -548,6 +560,8 @@ public class TileEntityReactorZirnox extends TileEntityMachineBase implements IC
|
|||||||
return getInfo(context, args);
|
return getInfo(context, args);
|
||||||
case ("setActive"):
|
case ("setActive"):
|
||||||
return setActive(context, args);
|
return setActive(context, args);
|
||||||
|
case ("ventCarbonDioxide"):
|
||||||
|
return ventCarbonDioxide(context, args);
|
||||||
}
|
}
|
||||||
throw new NoSuchMethodException();
|
throw new NoSuchMethodException();
|
||||||
}
|
}
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user