2014-01-23 17:28:12 +01:00
|
|
|
package appeng.container.implementations;
|
|
|
|
|
|
|
|
import net.minecraft.entity.player.InventoryPlayer;
|
|
|
|
import net.minecraft.item.ItemStack;
|
2014-01-23 20:02:48 +01:00
|
|
|
import appeng.api.implementations.guiobjects.INetworkTool;
|
2014-01-23 17:28:12 +01:00
|
|
|
import appeng.container.AEBaseContainer;
|
|
|
|
import appeng.container.slot.SlotRestrictedInput;
|
|
|
|
import appeng.container.slot.SlotRestrictedInput.PlaceableItemType;
|
|
|
|
import appeng.util.Platform;
|
|
|
|
|
|
|
|
public class ContainerNetworkTool extends AEBaseContainer
|
|
|
|
{
|
|
|
|
|
|
|
|
INetworkTool toolInv;
|
|
|
|
|
|
|
|
public ContainerNetworkTool(InventoryPlayer ip, INetworkTool te) {
|
|
|
|
super( ip, null, null );
|
|
|
|
toolInv = te;
|
|
|
|
|
|
|
|
lockPlayerInventorySlot( ip.currentItem );
|
|
|
|
|
|
|
|
for (int y = 0; y < 3; y++)
|
|
|
|
for (int x = 0; x < 3; x++)
|
|
|
|
addSlotToContainer( (new SlotRestrictedInput( PlaceableItemType.UPGRADES, te, y * 3 + x, 80 - 18 + x * 18, 37 - 18 + y * 18 )) );
|
|
|
|
|
|
|
|
bindPlayerInventory( ip, 0, 166 - /* height of playerinventory */82 );
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void detectAndSendChanges()
|
|
|
|
{
|
|
|
|
ItemStack currentItem = getPlayerInv().getCurrentItem();
|
|
|
|
|
|
|
|
if ( currentItem != toolInv.getItemStack() )
|
|
|
|
{
|
|
|
|
if ( currentItem != null )
|
|
|
|
{
|
|
|
|
if ( Platform.isSameItem( toolInv.getItemStack(), currentItem ) )
|
|
|
|
getPlayerInv().setInventorySlotContents( getPlayerInv().currentItem, toolInv.getItemStack() );
|
|
|
|
else
|
2014-02-09 02:34:52 +01:00
|
|
|
isContainerValid = false;
|
2014-01-23 17:28:12 +01:00
|
|
|
}
|
|
|
|
else
|
2014-02-09 02:34:52 +01:00
|
|
|
isContainerValid = false;
|
2014-01-23 17:28:12 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
super.detectAndSendChanges();
|
|
|
|
}
|
|
|
|
}
|