Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- package halestormxv.objects.blocks.devices.inscriber;
- import net.minecraft.entity.player.EntityPlayer;
- import net.minecraft.entity.player.InventoryPlayer;
- import net.minecraft.inventory.Container;
- import net.minecraft.inventory.IContainerListener;
- import net.minecraft.inventory.Slot;
- import net.minecraft.item.ItemStack;
- import net.minecraftforge.fml.relauncher.Side;
- import net.minecraftforge.fml.relauncher.SideOnly;
- public class ContainerRunicInscriber extends Container
- {
- private final TileEntityRunicInscriber tileEntity;
- private int cookTime, totalCookTime, burnTime, currentBurnTime;
- public ContainerRunicInscriber(InventoryPlayer player, TileEntityRunicInscriber tileEntity)
- {
- this.tileEntity = tileEntity;
- this.addSlotToContainer(new Slot(tileEntity, 0, 20, 18));
- this.addSlotToContainer(new Slot(tileEntity, 1, 140, 18));
- this.addSlotToContainer(new SlotInscriberFuel(tileEntity, 2, 80, 59));
- this.addSlotToContainer(new SlotInscriberOutput(player.player, tileEntity, 3, 80, 19));
- for (int y = 0; y < 3; ++y)
- {
- for (int x = 0; x < 9; ++x)
- {
- this.addSlotToContainer(new Slot(player, x + y * 9 + 9, 8 + x * 18, 84 + y * 18));
- }
- }
- for (int x = 0; x < 9; ++x)
- this.addSlotToContainer(new Slot(player, x, 8 + x * 18, 142));
- }
- @Override
- public void addListener(IContainerListener listener) {
- super.addListener(listener);
- listener.sendAllWindowProperties(this, this.tileEntity);
- }
- @Override
- public void detectAndSendChanges() {
- super.detectAndSendChanges();
- for (int i = 0; i < this.listeners.size(); ++i) {
- IContainerListener listener = (IContainerListener) this.listeners.get(i);
- if(this.cookTime != this.tileEntity.getField(2)) listener.sendWindowProperty(this, 2, this.tileEntity.getField(2));
- if(this.burnTime != this.tileEntity.getField(0)) listener.sendWindowProperty(this, 0, this.tileEntity.getField(0));
- if(this.currentBurnTime != this.tileEntity.getField(1)) listener.sendWindowProperty(this, 1, this.tileEntity.getField(1));
- if(this.totalCookTime != this.tileEntity.getField(3)) listener.sendWindowProperty(this, 3, this.tileEntity.getField(3));
- }
- this.cookTime = this.tileEntity.getField(2);
- this.burnTime = this.tileEntity.getField(0);
- this.currentBurnTime = this.tileEntity.getField(1);
- this.totalCookTime = this.tileEntity.getField(3);
- }
- @Override
- @SideOnly(Side.CLIENT)
- public void updateProgressBar(int id, int data) {
- this.tileEntity.setField(id, data);
- }
- @Override
- public boolean canInteractWith(EntityPlayer playerIn) {
- return this.tileEntity.isUsableByPlayer(playerIn);
- }
- @Override
- public ItemStack transferStackInSlot(EntityPlayer playerIn, int index)
- {
- ItemStack itemStack = ItemStack.EMPTY;
- Slot slot = (Slot) this.inventorySlots.get(index);
- if (slot != null && slot.getHasStack())
- {
- ItemStack stack1 = slot.getStack();
- itemStack = stack1.copy();
- if (index == 3)
- {
- if (!this.mergeItemStack(stack1, 4, 40, true))
- return ItemStack.EMPTY;
- slot.onSlotChange(stack1, itemStack);
- }
- else if (index != 2 && index != 1 && index != 0)
- {
- Slot slot1 = (Slot) this.inventorySlots.get(index + 1);
- if (!RunicInscriberRecipes.getInstance().getInscriberResult(stack1, slot1.getStack()).isEmpty())
- if (!this.mergeItemStack(stack1, 0, 2, false))
- return ItemStack.EMPTY;
- else if (TileEntityRunicInscriber.isItemFuel(stack1))
- if (!this.mergeItemStack(stack1, 2, 3, false))
- return ItemStack.EMPTY;
- else if (index >= 4 && index < 31)
- if (!this.mergeItemStack(stack1, 31, 40, false))
- return ItemStack.EMPTY;
- else if (index >= 31 && index < 40 && !this.mergeItemStack(stack1, 4, 31, false))
- return ItemStack.EMPTY;
- }
- else if (!this.mergeItemStack(stack1, 4, 40, false))
- return ItemStack.EMPTY;
- if (stack1.isEmpty())
- slot.putStack(ItemStack.EMPTY);
- else
- slot.onSlotChanged();
- if (stack1.getCount() == stack1.getCount())
- return ItemStack.EMPTY;
- slot.onTake(playerIn, stack1);
- }
- return itemStack;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement