Add in code to support the bukkit fun

This commit is contained in:
Christian Weeks 2012-04-15 18:30:49 -04:00
parent f12f8b1c31
commit 554d6c7005
2 changed files with 77 additions and 65 deletions

View File

@ -3,84 +3,93 @@ package cpw.mods.ironchest;
import net.minecraft.src.Container; import net.minecraft.src.Container;
import net.minecraft.src.EntityPlayer; import net.minecraft.src.EntityPlayer;
import net.minecraft.src.IInventory; import net.minecraft.src.IInventory;
import net.minecraft.src.InventoryPlayer;
import net.minecraft.src.ItemStack; import net.minecraft.src.ItemStack;
import net.minecraft.src.Slot; import net.minecraft.src.Slot;
public class ContainerIronChestBase extends Container { public class ContainerIronChestBase extends Container {
private IronChestType type; private IronChestType type;
public ContainerIronChestBase(IInventory playerInventory, IInventory chestInventory, IronChestType type, int xSize, int ySize) { private EntityPlayer player;
chest = chestInventory; private IInventory chest;
this.type=type;
chestInventory.openChest();
layoutContainer(playerInventory, chestInventory, type, xSize, ySize);
}
public boolean canInteractWith(EntityPlayer player) public ContainerIronChestBase(IInventory playerInventory, IInventory chestInventory, IronChestType type, int xSize, int ySize) {
{ chest = chestInventory;
return chest.isUseableByPlayer(player); player = ((InventoryPlayer) playerInventory).player;
} this.type = type;
chestInventory.openChest();
layoutContainer(playerInventory, chestInventory, type, xSize, ySize);
}
public ItemStack transferStackInSlot(int i) public boolean canInteractWith(EntityPlayer player)
{
return chest.isUseableByPlayer(player);
}
public ItemStack transferStackInSlot(int i)
{
ItemStack itemstack = null;
Slot slot = (Slot) inventorySlots.get(i);
if (slot != null && slot.getHasStack())
{ {
ItemStack itemstack = null; ItemStack itemstack1 = slot.getStack();
Slot slot = (Slot)inventorySlots.get(i); itemstack = itemstack1.copy();
if(slot != null && slot.getHasStack()) if (i < type.size)
{
if (!mergeItemStack(itemstack1, type.size, inventorySlots.size(), true))
{ {
ItemStack itemstack1 = slot.getStack(); return null;
itemstack = itemstack1.copy();
if(i < type.size)
{
if(!mergeItemStack(itemstack1, type.size, inventorySlots.size(), true))
{
return null;
}
} else
if(!mergeItemStack(itemstack1, 0, type.size, false))
{
return null;
}
if(itemstack1.stackSize == 0)
{
slot.putStack(null);
} else
{
slot.onSlotChanged();
}
} }
return itemstack; } else if (!mergeItemStack(itemstack1, 0, type.size, false))
{
return null;
}
if (itemstack1.stackSize == 0)
{
slot.putStack(null);
} else
{
slot.onSlotChanged();
}
} }
return itemstack;
}
public void onCraftGuiClosed(EntityPlayer entityplayer) public void onCraftGuiClosed(EntityPlayer entityplayer)
{
super.onCraftGuiClosed(entityplayer);
chest.closeChest();
}
protected void layoutContainer(IInventory playerInventory, IInventory chestInventory, IronChestType type, int xSize, int ySize) {
for (int chestRow = 0; chestRow < type.getRowCount(); chestRow++)
{ {
super.onCraftGuiClosed(entityplayer); for (int chestCol = 0; chestCol < type.getRowLength(); chestCol++)
chest.closeChest(); {
addSlot(new Slot(chestInventory, chestCol + chestRow * type.getRowLength(), 12 + chestCol * 18, 8 + chestRow * 18));
}
} }
protected void layoutContainer(IInventory playerInventory, IInventory chestInventory, IronChestType type, int xSize, int ySize) { int leftCol = (xSize - 162) / 2 + 1;
for(int chestRow = 0; chestRow < type.getRowCount(); chestRow++) for (int playerInvRow = 0; playerInvRow < 3; playerInvRow++)
{ {
for(int chestCol = 0; chestCol < type.getRowLength(); chestCol++) for (int playerInvCol = 0; playerInvCol < 9; playerInvCol++)
{ {
addSlot(new Slot(chestInventory, chestCol + chestRow * type.getRowLength(), 12 + chestCol * 18, 8 + chestRow * 18)); addSlot(new Slot(playerInventory, playerInvCol + playerInvRow * 9 + 9, leftCol + playerInvCol * 18, ySize - (4 - playerInvRow) * 18 - 10));
} }
} }
int leftCol=(xSize-162)/2 + 1; for (int hotbarSlot = 0; hotbarSlot < 9; hotbarSlot++)
for(int playerInvRow = 0; playerInvRow < 3; playerInvRow++) {
{ addSlot(new Slot(playerInventory, hotbarSlot, leftCol + hotbarSlot * 18, ySize - 24));
for(int playerInvCol = 0; playerInvCol < 9; playerInvCol++) }
{ }
addSlot(new Slot(playerInventory, playerInvCol + playerInvRow * 9 + 9, leftCol + playerInvCol * 18, ySize - (4-playerInvRow) * 18 - 10)); public EntityPlayer getPlayer() {
} return player;
}
} public IInventory getInventory() {
return chest;
for(int hotbarSlot = 0; hotbarSlot < 9; hotbarSlot++) }
{
addSlot(new Slot(playerInventory, hotbarSlot, leftCol + hotbarSlot * 18, ySize-24));
}
}
private IInventory chest;
} }

View File

@ -382,4 +382,7 @@ public class TileEntityIronChest extends TileEntity implements IInventory {
return null; return null;
} }
} }
public void setMaxStackSize(int size) {
}
} }