Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- package com.aiko.cenamicolmod.container;
- import com.aiko.cenamicolmod.te.TileEntityAnvil;
- import net.minecraft.entity.player.EntityPlayer;
- import net.minecraft.entity.player.InventoryPlayer;
- import net.minecraft.init.Blocks;
- import net.minecraft.init.Items;
- import net.minecraft.inventory.Container;
- import net.minecraft.inventory.IContainerListener;
- import net.minecraft.inventory.Slot;
- import net.minecraft.item.Item;
- import net.minecraft.item.ItemStack;
- import net.minecraftforge.fml.relauncher.Side;
- import net.minecraftforge.fml.relauncher.SideOnly;
- public class AnvilContainer extends Container {
- private TileEntityAnvil tile;
- private int timePassed = 0;
- private int burnTimeLeft = 0;
- public AnvilContainer(TileEntityAnvil tile, InventoryPlayer playerInventory) {
- this.tile = tile;
- int i;
- for(i = 0; i < 2; i++) {
- this.addSlotToContainer(new Slot(tile, i, 33 + i * 18, 7));
- }
- for(i = 0; i < 2; i++) {
- this.addSlotToContainer(new SlotSingleItem(tile, i + 2, 42, 40 + i * 18, i == 0 ? Item.getItemFromBlock(Blocks.PLANKS) : Items.WHEAT));
- }
- this.addSlotToContainer(new SlotOutput(tile, 4, 116, 17));
- for(i = 0; i < 3; ++i) {
- for(int j = 0; j < 9; ++j) {
- this.addSlotToContainer(new Slot(playerInventory, j + i * 9 + 9, 8 + j * 18, 84 + i * 18));
- }
- }
- for(i = 0; i < 9; ++i) {
- this.addSlotToContainer(new Slot(playerInventory, i, 8 + i * 18, 142));
- }
- }
- @Override
- public boolean canInteractWith(EntityPlayer player) {
- return tile.isUsableByPlayer(player);
- }
- @Override
- public void addListener(IContainerListener listener) {
- super.addListener(listener);
- listener.sendAllWindowProperties(this, this.tile);
- }
- @Override
- public void detectAndSendChanges() {
- super.detectAndSendChanges();
- for(int i = 0; i < this.listeners.size(); ++i) {
- IContainerListener icontainerlistener = (IContainerListener) this.listeners
- .get(i);
- if (this.burnTimeLeft != this.tile.getField(0)) {
- icontainerlistener.sendWindowProperty(this, 0,
- this.tile.getField(0));
- }
- if (this.timePassed != this.tile.getField(1)) {
- icontainerlistener.sendWindowProperty(this, 1,
- this.tile.getField(1));
- }
- }
- this.burnTimeLeft = this.tile.getField(0);
- this.timePassed = this.tile.getField(1);
- }
- @Override
- @SideOnly(Side.CLIENT)
- public void updateProgressBar(int id, int data) {
- this.tile.setField(id, data);
- }
- @Override
- public ItemStack transferStackInSlot(EntityPlayer playerIn, int index) {
- return ItemStack.EMPTY;
- }
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement