mirror of
https://github.com/HbmMods/Hbm-s-Nuclear-Tech-GIT.git
synced 2026-01-25 10:32:49 +00:00
123 lines
3.2 KiB
Java
123 lines
3.2 KiB
Java
package com.hbm.inventory.container;
|
|
|
|
import com.hbm.inventory.SlotCraftingOutput;
|
|
import com.hbm.tileentity.machine.TileEntityNukeFurnace;
|
|
import com.hbm.util.InventoryUtil;
|
|
|
|
import net.minecraft.entity.player.EntityPlayer;
|
|
import net.minecraft.entity.player.InventoryPlayer;
|
|
import net.minecraft.inventory.Container;
|
|
import net.minecraft.inventory.ICrafting;
|
|
import net.minecraft.inventory.Slot;
|
|
import net.minecraft.item.ItemStack;
|
|
|
|
public class ContainerNukeFurnace extends Container {
|
|
|
|
private TileEntityNukeFurnace diFurnace;
|
|
private int dualCookTime;
|
|
private int dualPower;
|
|
|
|
public ContainerNukeFurnace(InventoryPlayer invPlayer, TileEntityNukeFurnace tedf) {
|
|
dualCookTime = 0;
|
|
dualPower = 0;
|
|
|
|
diFurnace = tedf;
|
|
|
|
this.addSlotToContainer(new Slot(tedf, 0, 56, 53) {
|
|
@Override
|
|
public int getSlotStackLimit() {
|
|
return 1;
|
|
}
|
|
});
|
|
|
|
this.addSlotToContainer(new Slot(tedf, 1, 56, 17));
|
|
this.addSlotToContainer(new SlotCraftingOutput(invPlayer.player, tedf, 2, 116, 35));
|
|
|
|
for(int i = 0; i < 3; i++) {
|
|
for(int j = 0; j < 9; j++) {
|
|
this.addSlotToContainer(new Slot(invPlayer, j + i * 9 + 9, 8 + j * 18, 84 + i * 18));
|
|
}
|
|
}
|
|
|
|
for(int i = 0; i < 9; i++) {
|
|
this.addSlotToContainer(new Slot(invPlayer, i, 8 + i * 18, 142));
|
|
}
|
|
}
|
|
|
|
@Override
|
|
public void addCraftingToCrafters(ICrafting crafting) {
|
|
super.addCraftingToCrafters(crafting);
|
|
crafting.sendProgressBarUpdate(this, 0, this.diFurnace.dualCookTime);
|
|
crafting.sendProgressBarUpdate(this, 1, this.diFurnace.dualPower);
|
|
}
|
|
|
|
@Override
|
|
public ItemStack transferStackInSlot(EntityPlayer p_82846_1_, int par2) {
|
|
ItemStack var3 = null;
|
|
Slot var4 = (Slot) this.inventorySlots.get(par2);
|
|
|
|
if(var4 != null && var4.getHasStack()) {
|
|
ItemStack var5 = var4.getStack();
|
|
var3 = var5.copy();
|
|
|
|
if(par2 <= 2) {
|
|
if(!this.mergeItemStack(var5, 3, this.inventorySlots.size(), true)) {
|
|
return null;
|
|
}
|
|
} else {
|
|
|
|
if(TileEntityNukeFurnace.getFuelValue(var5) > 0) {
|
|
if(!InventoryUtil.mergeItemStack(this.inventorySlots, var5, 0, 1, false))
|
|
return null;
|
|
} else {
|
|
if(!this.mergeItemStack(var5, 1, 2, false))
|
|
return null;
|
|
}
|
|
}
|
|
|
|
if(var5.stackSize == 0) {
|
|
var4.putStack((ItemStack) null);
|
|
} else {
|
|
var4.onSlotChanged();
|
|
}
|
|
}
|
|
|
|
return var3;
|
|
}
|
|
|
|
@Override
|
|
public boolean canInteractWith(EntityPlayer player) {
|
|
return diFurnace.isUseableByPlayer(player);
|
|
}
|
|
|
|
@Override
|
|
public void detectAndSendChanges() {
|
|
super.detectAndSendChanges();
|
|
|
|
for(int i = 0; i < this.crafters.size(); i++) {
|
|
ICrafting par1 = (ICrafting) this.crafters.get(i);
|
|
|
|
if(this.dualCookTime != this.diFurnace.dualCookTime) {
|
|
par1.sendProgressBarUpdate(this, 0, this.diFurnace.dualCookTime);
|
|
}
|
|
|
|
if(this.dualPower != this.diFurnace.dualPower) {
|
|
par1.sendProgressBarUpdate(this, 1, this.diFurnace.dualPower);
|
|
}
|
|
}
|
|
|
|
this.dualCookTime = this.diFurnace.dualCookTime;
|
|
this.dualPower = this.diFurnace.dualPower;
|
|
}
|
|
|
|
@Override
|
|
public void updateProgressBar(int i, int j) {
|
|
if(i == 0) {
|
|
diFurnace.dualCookTime = j;
|
|
}
|
|
if(i == 1) {
|
|
diFurnace.dualPower = j;
|
|
}
|
|
}
|
|
}
|