Fixed stackSize tooltip being "1" and added inventory clear method
This commit is contained in:
parent
05241e740e
commit
f581ade242
3 changed files with 119 additions and 29 deletions
|
@ -1,10 +1,14 @@
|
|||
package resonantinduction.archaic.engineering;
|
||||
|
||||
import java.util.Random;
|
||||
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.client.renderer.texture.IconRegister;
|
||||
import net.minecraft.entity.item.EntityItem;
|
||||
import net.minecraft.entity.player.EntityPlayer;
|
||||
import net.minecraft.inventory.IInventory;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.nbt.NBTTagCompound;
|
||||
import net.minecraft.tileentity.TileEntity;
|
||||
import net.minecraft.util.Icon;
|
||||
import net.minecraft.world.World;
|
||||
|
@ -36,6 +40,67 @@ public class BlockEngineeringTable extends BlockRI
|
|||
setTextureName("crafting_table");
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onBlockClicked(World world, int x, int y, int z, EntityPlayer player)
|
||||
{
|
||||
if (!world.isRemote)
|
||||
{
|
||||
dropEntireInventory(world, x, y, z, 0, 0);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void dropEntireInventory(World world, int x, int y, int z, int par5, int par6)
|
||||
{
|
||||
TileEntity tileEntity = world.getBlockTileEntity(x, y, z);
|
||||
|
||||
if (tileEntity != null)
|
||||
{
|
||||
if (tileEntity instanceof IInventory)
|
||||
{
|
||||
IInventory inventory = (IInventory) tileEntity;
|
||||
|
||||
// PREVENTS OUTPUT FROM DROPPING!
|
||||
for (int var6 = 0; var6 < inventory.getSizeInventory() - 1; ++var6)
|
||||
{
|
||||
ItemStack var7 = inventory.getStackInSlot(var6);
|
||||
|
||||
if (var7 != null)
|
||||
{
|
||||
Random random = new Random();
|
||||
float var8 = random.nextFloat() * 0.8F + 0.1F;
|
||||
float var9 = random.nextFloat() * 0.8F + 0.1F;
|
||||
float var10 = random.nextFloat() * 0.8F + 0.1F;
|
||||
|
||||
while (var7.stackSize > 0)
|
||||
{
|
||||
int var11 = random.nextInt(21) + 10;
|
||||
|
||||
if (var11 > var7.stackSize)
|
||||
{
|
||||
var11 = var7.stackSize;
|
||||
}
|
||||
|
||||
var7.stackSize -= var11;
|
||||
EntityItem var12 = new EntityItem(world, (x + var8), (y + var9), (z + var10), new ItemStack(var7.itemID, var11, var7.getItemDamage()));
|
||||
|
||||
if (var7.hasTagCompound())
|
||||
{
|
||||
var12.getEntityItem().setTagCompound((NBTTagCompound) var7.getTagCompound().copy());
|
||||
}
|
||||
|
||||
float var13 = 0.05F;
|
||||
var12.motionX = ((float) random.nextGaussian() * var13);
|
||||
var12.motionY = ((float) random.nextGaussian() * var13 + 0.2F);
|
||||
var12.motionZ = ((float) random.nextGaussian() * var13);
|
||||
world.spawnEntityInWorld(var12);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean onBlockActivated(World world, int x, int y, int z, EntityPlayer player, int hitSide, float hitX, float hitY, float hitZ)
|
||||
{
|
||||
|
@ -49,7 +114,6 @@ public class BlockEngineeringTable extends BlockRI
|
|||
{
|
||||
if (!world.isRemote)
|
||||
{
|
||||
|
||||
ItemStack current = player.inventory.getCurrentItem();
|
||||
|
||||
Vector2 hitVector = new Vector2(hitX, hitZ);
|
||||
|
@ -76,20 +140,38 @@ public class BlockEngineeringTable extends BlockRI
|
|||
if (checkStack == null || checkStack.isItemEqual(current))
|
||||
{
|
||||
if (ControlKeyModifer.isControlDown(player))
|
||||
{
|
||||
if (checkStack == null)
|
||||
{
|
||||
tile.craftingMatrix[slotID] = current;
|
||||
}
|
||||
else
|
||||
{
|
||||
tile.craftingMatrix[slotID].stackSize += current.stackSize;
|
||||
current.stackSize = 0;
|
||||
}
|
||||
|
||||
current = null;
|
||||
}
|
||||
else
|
||||
{
|
||||
if (checkStack == null)
|
||||
{
|
||||
tile.craftingMatrix[slotID] = current.splitStack(1);
|
||||
}
|
||||
else
|
||||
{
|
||||
tile.craftingMatrix[slotID].stackSize++;
|
||||
current.stackSize--;
|
||||
}
|
||||
}
|
||||
|
||||
if (current == null || current.stackSize <= 0)
|
||||
{
|
||||
player.inventory.setInventorySlotContents(player.inventory.currentItem, null);
|
||||
}
|
||||
|
||||
didInsert = true;
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -111,15 +193,20 @@ public class BlockEngineeringTable extends BlockRI
|
|||
return true;
|
||||
}
|
||||
else if (hitSide != 0)
|
||||
{
|
||||
if (!world.isRemote)
|
||||
{
|
||||
ItemStack output = tile.getStackInSlot(9);
|
||||
boolean firstLoop = true;
|
||||
|
||||
while (output != null && ControlKeyModifer.isControlDown(player))
|
||||
while (output != null && (firstLoop || ControlKeyModifer.isControlDown(player)))
|
||||
{
|
||||
InventoryUtility.dropItemStack(world, new Vector3(player), output, 0);
|
||||
tile.onPickUpFromSlot(player, 9, output);
|
||||
tile.setInventorySlotContents(9, null);
|
||||
output = tile.getStackInSlot(9);
|
||||
firstLoop = false;
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -65,7 +65,7 @@ public class RenderEngineeringTable extends TileEntitySpecialRenderer
|
|||
OpenGlHelper.setLightmapTextureCoords(OpenGlHelper.lightmapTexUnit, 240, 240);
|
||||
this.renderItem(tileEntity.worldObj, ForgeDirection.UP, tile.craftingMatrix[i], new Vector3(), 0, 0);
|
||||
GL11.glPopMatrix();
|
||||
System.out.println(tile.craftingMatrix[i].stackSize);
|
||||
|
||||
if (isLooking)
|
||||
RenderUtility.renderFloatingText("" + tile.craftingMatrix[i].stackSize, (float) translation.x, (float) translation.y - 2f, (float) translation.z);
|
||||
}
|
||||
|
@ -238,7 +238,7 @@ System.out.println(tile.craftingMatrix[i].stackSize);
|
|||
{
|
||||
if (itemStack != null)
|
||||
{
|
||||
EntityItem entityitem = new EntityItem(world, 0.0D, 0.0D, 0.0D, itemStack);
|
||||
EntityItem entityitem = new EntityItem(world, 0.0D, 0.0D, 0.0D, itemStack.copy());
|
||||
entityitem.getEntityItem().stackSize = 1;
|
||||
entityitem.hoverStart = 0.0F;
|
||||
GL11.glPushMatrix();
|
||||
|
|
|
@ -104,6 +104,7 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
if (slot < CRAFTING_MATRIX_END)
|
||||
{
|
||||
this.craftingMatrix[slot] = itemStack;
|
||||
System.out.println(worldObj.isRemote+"SET"+this.craftingMatrix[slot]);
|
||||
}
|
||||
else
|
||||
{
|
||||
|
@ -238,7 +239,7 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
@Override
|
||||
public void onInventoryChanged()
|
||||
{
|
||||
if (!this.worldObj.isRemote)
|
||||
if (!worldObj.isRemote)
|
||||
{
|
||||
this.output[craftingOutputSlot] = null;
|
||||
|
||||
|
@ -261,16 +262,17 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
didCraft = true;
|
||||
}
|
||||
|
||||
PacketDispatcher.sendPacketToAllPlayers(this.getDescriptionPacket());
|
||||
worldObj.markBlockForUpdate(xCoord, yCoord, zCoord);
|
||||
}
|
||||
}
|
||||
|
||||
@Override
|
||||
public void onPickUpFromSlot(EntityPlayer entityPlayer, int s, ItemStack itemStack)
|
||||
{
|
||||
if (!worldObj.isRemote)
|
||||
{
|
||||
if (itemStack != null)
|
||||
{
|
||||
|
||||
Pair<ItemStack, ItemStack[]> idealRecipeItem = this.getCraftingManager().getIdealRecipe(itemStack);
|
||||
|
||||
if (idealRecipeItem != null)
|
||||
|
@ -280,6 +282,7 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
/** Tries to let the Armbot craft an item. */
|
||||
@Override
|
||||
|
@ -314,18 +317,18 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
{
|
||||
super.readFromNBT(nbt);
|
||||
|
||||
NBTTagList var2 = nbt.getTagList("Items");
|
||||
NBTTagList nbtList = nbt.getTagList("Items");
|
||||
this.craftingMatrix = new ItemStack[9];
|
||||
this.output = new ItemStack[1];
|
||||
|
||||
for (int i = 0; i < var2.tagCount(); ++i)
|
||||
for (int i = 0; i < nbtList.tagCount(); ++i)
|
||||
{
|
||||
NBTTagCompound var4 = (NBTTagCompound) var2.tagAt(i);
|
||||
byte id = var4.getByte("Slot");
|
||||
NBTTagCompound stackTag = (NBTTagCompound) nbtList.tagAt(i);
|
||||
byte id = stackTag.getByte("Slot");
|
||||
|
||||
if (id >= 0 && id < this.getSizeInventory())
|
||||
{
|
||||
this.setInventorySlotContents(id, ItemStack.loadItemStackFromNBT(var4));
|
||||
this.setInventorySlotContents(id, ItemStack.loadItemStackFromNBT(stackTag));
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -338,7 +341,7 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
{
|
||||
super.writeToNBT(nbt);
|
||||
|
||||
NBTTagList var2 = new NBTTagList();
|
||||
NBTTagList nbtList = new NBTTagList();
|
||||
|
||||
for (int i = 0; i < this.getSizeInventory(); ++i)
|
||||
{
|
||||
|
@ -347,11 +350,11 @@ public class TileEngineeringTable extends TileAdvanced implements IPacketReceive
|
|||
NBTTagCompound var4 = new NBTTagCompound();
|
||||
var4.setByte("Slot", (byte) i);
|
||||
this.getStackInSlot(i).writeToNBT(var4);
|
||||
var2.appendTag(var4);
|
||||
nbtList.appendTag(var4);
|
||||
}
|
||||
}
|
||||
|
||||
nbt.setTag("Items", var2);
|
||||
nbt.setTag("Items", nbtList);
|
||||
nbt.setBoolean("searchInventories", this.searchInventories);
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue