From 70c1354a4a96698758a88c032866288f79de6f5a Mon Sep 17 00:00:00 2001 From: Benjamin Culkin Date: Sat, 24 Aug 2024 08:16:37 -0400 Subject: Initial commit --- .../fbs/container/ContainerFillingTable.java | 146 +++++++++++++++++++++ 1 file changed, 146 insertions(+) create mode 100644 src/main/java/jp/plusplus/fbs/container/ContainerFillingTable.java (limited to 'src/main/java/jp/plusplus/fbs/container/ContainerFillingTable.java') diff --git a/src/main/java/jp/plusplus/fbs/container/ContainerFillingTable.java b/src/main/java/jp/plusplus/fbs/container/ContainerFillingTable.java new file mode 100644 index 0000000..dfabcfd --- /dev/null +++ b/src/main/java/jp/plusplus/fbs/container/ContainerFillingTable.java @@ -0,0 +1,146 @@ +package jp.plusplus.fbs.container; + +import cpw.mods.fml.relauncher.Side; +import cpw.mods.fml.relauncher.SideOnly; +import jp.plusplus.fbs.block.BlockCore; +import jp.plusplus.fbs.container.slot.SlotTakeOnly; +import jp.plusplus.fbs.tileentity.TileEntityFillingTable; +import net.minecraft.entity.player.EntityPlayer; +import net.minecraft.inventory.Container; +import net.minecraft.inventory.ICrafting; +import net.minecraft.inventory.Slot; +import net.minecraft.item.ItemStack; +import net.minecraftforge.fluids.FluidStack; + +/** + * Createdby pluslus_Fon 2015/06/14. + */ +public class ContainerFillingTable extends Container { + public int lastProgress; + public int lastAmount; + + private TileEntityFillingTable entity; + + public ContainerFillingTable(EntityPlayer player, TileEntityFillingTable tileEntity) { + this.entity = tileEntity; + + //inventory's inventory + this.addSlotToContainer(new Slot(this.entity, 0, 116, 35)); + this.addSlotToContainer(new Slot(this.entity, 1, 44, 17)); + this.addSlotToContainer(new SlotTakeOnly(this.entity, 2, 44, 53)); + + //player inventory + for (int i = 0; i < 3; i++) { + for (int j = 0; j < 9; j++) { + this.addSlotToContainer(new Slot(player.inventory, j + i * 9 + 9, 8 + j * 18, 84 + i * 18)); + } + } + + //player slots + for (int i = 0; i < 9; i++) { + this.addSlotToContainer(new Slot(player.inventory, i, 8 + i * 18, 142)); + } + } + + @Override + public void addCraftingToCrafters(ICrafting par1ICrafting) { + super.addCraftingToCrafters(par1ICrafting); + par1ICrafting.sendProgressBarUpdate(this, 0, entity.tank.getFluidAmount()); + par1ICrafting.sendProgressBarUpdate(this, 1, entity.progress); + } + + @Override + public void detectAndSendChanges() { + super.detectAndSendChanges(); + for (int i = 0; i < this.crafters.size(); i++) { + ICrafting icrafting = (ICrafting) this.crafters.get(i); + if (lastAmount != entity.tank.getFluidAmount()) { + icrafting.sendProgressBarUpdate(this, 0, entity.tank.getFluidAmount()); + } + if (lastProgress != entity.progress) { + icrafting.sendProgressBarUpdate(this, 1, entity.progress); + } + } + lastAmount = entity.tank.getFluidAmount(); + lastProgress = entity.progress; + } + @Override + @SideOnly(Side.CLIENT) + public void updateProgressBar(int par1, int par2) { + if (par1 == 0) { + for (int i = 0; i < this.crafters.size(); i++) { + ICrafting icrafting = (ICrafting) this.crafters.get(i); + if (lastAmount != entity.tank.getFluidAmount()) { + icrafting.sendProgressBarUpdate(this, 0, entity.tank.getFluidAmount()); + } + } + if (par2 > 0) { + if (entity.tank.getFluid() == null) entity.tank.setFluid(new FluidStack(BlockCore.mana, par2)); + else entity.tank.setAmount(par2); + } else { + entity.tank.setFluid(null); + } + } else { + for (int i = 0; i < this.crafters.size(); i++) { + ICrafting icrafting = (ICrafting) this.crafters.get(i); + if (lastProgress != entity.progress) { + icrafting.sendProgressBarUpdate(this, 1, entity.progress); + } + } + entity.progress = (short) par2; + } + } + + @Override + public boolean canInteractWith(EntityPlayer entityPlayer) { + return entity.isUseableByPlayer(entityPlayer); + } + + + @Override + public ItemStack transferStackInSlot(EntityPlayer par1EntityPlayer, int par2) { + ItemStack itemStack = null; + Slot slot = (Slot) this.inventorySlots.get(par2); + + if (slot != null && slot.getHasStack()) { + ItemStack stack = slot.getStack(); + itemStack = stack.copy(); + + if (par2 >= 0 && par2 <= 2) { + if (!this.mergeItemStack(stack, 3, 39, true)) { + return null; + } + slot.onSlotChange(stack, itemStack); + } else { + if (entity.isItemValidForSlot(0, stack)) { + if (!this.mergeItemStack(stack, 0, 1, false)) { + return null; + } + } else if (entity.isItemValidForSlot(1, stack)) { + if (!this.mergeItemStack(stack, 1, 2, false)) { + return null; + } + } else if (par2 >= 3 && par2 < 30) { + if (!this.mergeItemStack(stack, 30, 39, false)) { + return null; + } + } else if (par2 >= 30 && par2 < 39 && !this.mergeItemStack(stack, 3, 30, false)) { + return null; + } + } + + if (stack.stackSize == 0) { + slot.putStack((ItemStack) null); + } else { + slot.onSlotChanged(); + } + + if (stack.stackSize == itemStack.stackSize) { + return null; + } + slot.onPickupFromSlot(par1EntityPlayer, stack); + } + + return itemStack; + } +} -- cgit v1.2.3