Resolved #113 - Crate now can swap and merge oredict items

This commit is contained in:
Calclavia 2014-03-02 18:24:20 +08:00
parent d81f2fa6fa
commit c4122f52f9
2 changed files with 50 additions and 21 deletions

View file

@ -1,5 +1,6 @@
package resonantinduction.archaic.crate; package resonantinduction.archaic.crate;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import net.minecraft.client.renderer.texture.IconRegister; import net.minecraft.client.renderer.texture.IconRegister;
@ -11,9 +12,11 @@ import net.minecraft.item.ItemStack;
import net.minecraft.tileentity.TileEntity; import net.minecraft.tileentity.TileEntity;
import net.minecraft.util.Icon; import net.minecraft.util.Icon;
import net.minecraft.world.World; import net.minecraft.world.World;
import net.minecraftforge.oredict.OreDictionary;
import resonantinduction.core.Reference; import resonantinduction.core.Reference;
import universalelectricity.api.UniversalElectricity; import universalelectricity.api.UniversalElectricity;
import calclavia.lib.prefab.block.BlockTile; import calclavia.lib.prefab.block.BlockTile;
import calclavia.lib.utility.WrenchUtility;
import codechicken.multipart.ControlKeyModifer; import codechicken.multipart.ControlKeyModifer;
import cpw.mods.fml.relauncher.Side; import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly; import cpw.mods.fml.relauncher.SideOnly;
@ -87,39 +90,62 @@ public class BlockCrate extends BlockTile
{ {
if (world.getBlockTileEntity(x, y, z) instanceof TileCrate) if (world.getBlockTileEntity(x, y, z) instanceof TileCrate)
{ {
TileCrate tileEntity = (TileCrate) world.getBlockTileEntity(x, y, z); TileCrate tile = (TileCrate) world.getBlockTileEntity(x, y, z);
if (player.getCurrentEquippedItem() != null && WrenchUtility.isWrench(player.getCurrentEquippedItem()))
{
/**
* Swap oredict nodes if the player is wrenching the crate.
*/
ItemStack sampleStack = tile.getSampleStack();
int oreID = OreDictionary.getOreID(sampleStack);
if (oreID != -1)
{
ArrayList<ItemStack> ores = OreDictionary.getOres(oreID);
for (int i = 0; i < ores.size(); i++)
{
if (ores.get(i).isItemEqual(sampleStack))
{
int nextIndex = (i + 1) % ores.size();
ItemStack desiredStack = ores.get(nextIndex).copy();
desiredStack.stackSize = sampleStack.stackSize;
for (int index = 0; index < tile.getSizeInventory(); index++)
tile.setInventorySlotContents(index, null);
tile.addStackToStorage(desiredStack);
break;
}
}
}
}
/** Make double clicking input all stacks. */ /** Make double clicking input all stacks. */
boolean allMode = (world.getWorldTime() - tileEntity.prevClickTime < 10); boolean allMode = (world.getWorldTime() - tile.prevClickTime < 10);
tileEntity.prevClickTime = world.getWorldTime(); tile.prevClickTime = world.getWorldTime();
if (ControlKeyModifer.isControlDown(player)) if (ControlKeyModifer.isControlDown(player))
{ {
this.tryEject(tileEntity, player, allMode); tryEject(tile, player, allMode);
} }
else else
{ {
ItemStack current = player.inventory.getCurrentItem(); ItemStack current = player.inventory.getCurrentItem();
if (side == 1 && player.capabilities.isCreativeMode) if (side == 1 && player.capabilities.isCreativeMode)
{ {
if (current != null && tileEntity.getSampleStack() == null) if (current != null && tile.getSampleStack() == null)
{ {
ItemStack cStack = current.copy(); ItemStack cStack = current.copy();
cStack.stackSize = TileCrate.getSlotCount(world.getBlockMetadata(x, y, z)) * 64; cStack.stackSize = TileCrate.getSlotCount(world.getBlockMetadata(x, y, z)) * 64;
BlockCrate.addStackToCrate(tileEntity, cStack); addStackToCrate(tile, cStack);
} }
} }
// Add items
if (side == 1 || (side > 1 && hitY > 0.5) || !player.capabilities.isCreativeMode) tryInsert(tile, player, allMode);
{
this.tryInsert(tileEntity, player, allMode);
}
// Remove items
else if (side == 0 || (side > 1 && hitY <= 0.5))
{
this.tryEject(tileEntity, player, allMode);
}
} }
} }
} }
@ -160,7 +186,7 @@ public class BlockCrate extends BlockTile
public void tryInsert(TileCrate tileEntity, EntityPlayer player, boolean allMode) public void tryInsert(TileCrate tileEntity, EntityPlayer player, boolean allMode)
{ {
this.tryInsert(tileEntity, player, allMode, true); tryInsert(tileEntity, player, allMode, true);
} }
public void tryEject(TileCrate tileEntity, EntityPlayer player, boolean allMode) public void tryEject(TileCrate tileEntity, EntityPlayer player, boolean allMode)
@ -209,7 +235,7 @@ public class BlockCrate extends BlockTile
{ {
if (tileEntity.getSampleStack() != null) if (tileEntity.getSampleStack() != null)
{ {
if (!tileEntity.getSampleStack().isItemEqual(currentStack)) if (!(tileEntity.getSampleStack().isItemEqual(currentStack) || OreDictionary.getOreID(tileEntity.getSampleStack()) == OreDictionary.getOreID(currentStack)))
{ {
return false; return false;
} }
@ -339,7 +365,7 @@ public class BlockCrate extends BlockTile
ItemStack containingStack = tileEntity.getSampleStack(); ItemStack containingStack = tileEntity.getSampleStack();
if (containingStack == null || containingStack != null && containingStack.isItemEqual(itemStack)) if (containingStack == null || (containingStack.isItemEqual(itemStack) || OreDictionary.getOreID(containingStack) == OreDictionary.getOreID(itemStack)))
{ {
int room = Math.max((tileEntity.getInventory().getSizeInventory() * 64) - (containingStack != null ? containingStack.stackSize : 0), 0); int room = Math.max((tileEntity.getInventory().getSizeInventory() * 64) - (containingStack != null ? containingStack.stackSize : 0), 0);
if (itemStack.stackSize <= room) if (itemStack.stackSize <= room)

View file

@ -5,6 +5,7 @@ import net.minecraft.item.ItemStack;
import net.minecraft.nbt.NBTTagCompound; import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.network.packet.Packet; import net.minecraft.network.packet.Packet;
import net.minecraftforge.common.ForgeDirection; import net.minecraftforge.common.ForgeDirection;
import net.minecraftforge.oredict.OreDictionary;
import resonantinduction.core.ResonantInduction; import resonantinduction.core.ResonantInduction;
import calclavia.lib.network.IPacketReceiver; import calclavia.lib.network.IPacketReceiver;
import calclavia.lib.network.PacketHandler; import calclavia.lib.network.PacketHandler;
@ -130,16 +131,18 @@ public class TileCrate extends TileExternalInventory implements IPacketReceiver,
{ {
this.buildSampleStack(); this.buildSampleStack();
boolean flag = false; boolean flag = false;
if (this.sampleStack == null) if (this.sampleStack == null)
{ {
this.sampleStack = stack; this.sampleStack = stack;
flag = true; flag = true;
} }
else if (this.sampleStack.isItemEqual(stack)) else if (this.sampleStack.isItemEqual(stack) || OreDictionary.getOreID(sampleStack) == OreDictionary.getOreID(stack))
{ {
this.sampleStack.stackSize += stack.stackSize; this.sampleStack.stackSize += stack.stackSize;
flag = true; flag = true;
} }
if (flag) if (flag)
{ {
this.getInventory().buildInventory(this.sampleStack); this.getInventory().buildInventory(this.sampleStack);
@ -165,7 +168,7 @@ public class TileCrate extends TileExternalInventory implements IPacketReceiver,
@Override @Override
public boolean canStore(ItemStack stack, int slot, ForgeDirection side) public boolean canStore(ItemStack stack, int slot, ForgeDirection side)
{ {
return this.sampleStack == null || stack != null && stack.isItemEqual(sampleStack); return sampleStack == null || stack != null && (stack.isItemEqual(sampleStack) || OreDictionary.getOreID(sampleStack) == OreDictionary.getOreID(stack));
} }
/** Gets the current slot count for the crate */ /** Gets the current slot count for the crate */