[1.5.2]Проблемы с печкой.

71
1
Какой-то косяк, когда ставлю печку свою она такая :
KAxeaJ6h4vRXMr.jpg

Но когда я положу внутрь допустим уголь и железо(из 64 остаётся по 1 а остальное вылетает с печки)
И получается вот такое чудо -_-
D2PjvdMsdBa80r.jpg

Ну а вот ошибка в Консоле:
Код:
2016-01-22 16:15:28 [INFO] [STDERR] net.minecraft.util.ReportedException: Ticking memory connection
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.network.NetworkListenThread.networkTick(NetworkListenThread.java:60)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.server.integrated.IntegratedServerListenThread.networkTick(IntegratedServerListenThread.java:109)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:677)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:573)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.server.integrated.IntegratedServer.tick(IntegratedServer.java:127)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:470)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.server.ThreadMinecraftServer.run(ThreadMinecraftServer.java:16)
2016-01-22 16:15:28 [INFO] [STDERR] Caused by: java.lang.ClassCastException: bcblocks.twoinputfurnace.tif.TileEntityInputFurnace cannot be cast to net.minecraft.tileentity.TileEntityFurnace
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.block.BlockFurnace.breakBlock(BlockFurnace.java:261)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.world.chunk.Chunk.setBlockIDWithMetadata(Chunk.java:715)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.world.World.setBlock(World.java:558)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.world.World.setBlockToAir(World.java:687)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.block.Block.removeBlockByPlayer(Block.java:1640)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.item.ItemInWorldManager.removeBlock(ItemInWorldManager.java:275)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.item.ItemInWorldManager.tryHarvestBlock(ItemInWorldManager.java:308)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.item.ItemInWorldManager.onBlockClicked(ItemInWorldManager.java:170)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.network.NetServerHandler.handleBlockDig(NetServerHandler.java:491)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.network.packet.Packet14BlockDig.processPacket(Packet14BlockDig.java:67)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.network.MemoryConnection.processReadPackets(MemoryConnection.java:89)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.network.NetServerHandler.networkTick(NetServerHandler.java:134)
2016-01-22 16:15:28 [INFO] [STDERR]     at net.minecraft.network.NetworkListenThread.networkTick(NetworkListenThread.java:53)
2016-01-22 16:15:28 [INFO] [STDERR]     ... 6 more
2016-01-22 16:15:28 [SEVERE] [Minecraft-Server] Encountered an unexpected exception ReportedException
net.minecraft.util.ReportedException: Ticking memory connection
    at net.minecraft.network.NetworkListenThread.networkTick(NetworkListenThread.java:60)
    at net.minecraft.server.integrated.IntegratedServerListenThread.networkTick(IntegratedServerListenThread.java:109)
    at net.minecraft.server.MinecraftServer.updateTimeLightAndEntities(MinecraftServer.java:677)
    at net.minecraft.server.MinecraftServer.tick(MinecraftServer.java:573)
    at net.minecraft.server.integrated.IntegratedServer.tick(IntegratedServer.java:127)
    at net.minecraft.server.MinecraftServer.run(MinecraftServer.java:470)
    at net.minecraft.server.ThreadMinecraftServer.run(ThreadMinecraftServer.java:16)
Caused by: java.lang.ClassCastException: bcblocks.twoinputfurnace.tif.TileEntityInputFurnace cannot be cast to net.minecraft.tileentity.TileEntityFurnace
    at net.minecraft.block.BlockFurnace.breakBlock(BlockFurnace.java:261)
    at net.minecraft.world.chunk.Chunk.setBlockIDWithMetadata(Chunk.java:715)
    at net.minecraft.world.World.setBlock(World.java:558)
    at net.minecraft.world.World.setBlockToAir(World.java:687)
    at net.minecraft.block.Block.removeBlockByPlayer(Block.java:1640)
    at net.minecraft.item.ItemInWorldManager.removeBlock(ItemInWorldManager.java:275)
    at net.minecraft.item.ItemInWorldManager.tryHarvestBlock(ItemInWorldManager.java:308)
    at net.minecraft.item.ItemInWorldManager.onBlockClicked(ItemInWorldManager.java:170)
    at net.minecraft.network.NetServerHandler.handleBlockDig(NetServerHandler.java:491)
    at net.minecraft.network.packet.Packet14BlockDig.processPacket(Packet14BlockDig.java:67)
    at net.minecraft.network.MemoryConnection.processReadPackets(MemoryConnection.java:89)
    at net.minecraft.network.NetServerHandler.networkTick(NetServerHandler.java:134)
    at net.minecraft.network.NetworkListenThread.networkTick(NetworkListenThread.java:53)
    ... 6 more
КОД БРАЛ С СТАНДАРТНОЙ ПЕЧКИ.
 

timaxa007

Модератор
5,831
409
672
Dablex написал(а):
Код:
Caused by: java.lang.ClassCastException: bcblocks.twoinputfurnace.tif.TileEntityInputFurnace cannot be cast to net.minecraft.tileentity.TileEntityFurnace
Наверное ещё и прихватил и условие, что при обновлении твой печки во время готовки, твой блок заменялся на ванильную печку.
 
71
1
timaxa007 написал(а):
Dablex написал(а):
Код:
Caused by: java.lang.ClassCastException: bcblocks.twoinputfurnace.tif.TileEntityInputFurnace cannot be cast to net.minecraft.tileentity.TileEntityFurnace
    at net.minecraft.block.BlockFurnace.breakBlock(BlockFurnace.java:261)
Наверное ещё и прихватил и условие, что при обновлении твой печки во время готовки, твой блок заменялся на ванильную печку.
Скорее всего, а как исправить? 
Вот TileEntityInputFurnace:
Код:
package bcblocks.twoinputfurnace.tif;

import net.minecraft.block.Block;
import net.minecraft.block.BlockFurnace;
import net.minecraft.block.material.Material;
import net.minecraft.entity.player.EntityPlayer;
import net.minecraft.inventory.ISidedInventory;
import net.minecraft.item.Item;
import net.minecraft.item.ItemBlock;
import net.minecraft.item.ItemHoe;
import net.minecraft.item.ItemStack;
import net.minecraft.item.ItemSword;
import net.minecraft.item.ItemTool;
import net.minecraft.nbt.NBTTagCompound;
import net.minecraft.nbt.NBTTagList;
import net.minecraft.tileentity.TileEntity;
import net.minecraftforge.common.ForgeDirection;
import net.minecraftforge.common.ForgeDummyContainer;
import bcblocks.twoinputfurnace.tifcare.InputFurnaceRecipes;
import cpw.mods.fml.common.registry.GameRegistry;
import cpw.mods.fml.relauncher.Side;
import cpw.mods.fml.relauncher.SideOnly;

public class TileEntityInputFurnace extends TileEntity implements ISidedInventory
{
    private static final int[] field_102010_d = new int[] {0};
    private static final int[] field_102011_e = new int[] {2, 1};
    private static final int[] field_102009_f = new int[] {1};

    /**
     * The ItemStacks that hold the items currently being used in the furnace
     */
    private ItemStack[] furnaceItemStacks = new ItemStack[3];

    /** The number of ticks that the furnace will keep burning */
    public int tickBurnTime = 0;

    /**
     * The number of ticks that a fresh copy of the currently-burning item would keep the furnace burning for
     */
    public int currentItemBurnTime = 0;

    /** The number of ticks that the current item has been cooking for */
    public int tickCookTime = 0;
    private String field_94130_e;

    /**
     * Returns the number of slots in the inventory.
     */
    public int getSizeInventory()
    {
        return this.furnaceItemStacks.length;
    }

    /**
     * Returns the stack in slot i
     */
    public ItemStack getStackInSlot(int par1)
    {
        return this.furnaceItemStacks[par1];
    }

    /**
     * Removes from an inventory slot (first arg) up to a specified number (second arg) of items and returns them in a
     * new stack.
     */
    public ItemStack decrStackSize(int par1, int par2)
    {
        if (this.furnaceItemStacks[par1] != null)
        {
            ItemStack itemstack;

            if (this.furnaceItemStacks[par1].stackSize <= par2)
            {
                itemstack = this.furnaceItemStacks[par1];
                this.furnaceItemStacks[par1] = null;
                return itemstack;
            }
            else
            {
                itemstack = this.furnaceItemStacks[par1].splitStack(par2);

                if (this.furnaceItemStacks[par1].stackSize == 0)
                {
                    this.furnaceItemStacks[par1] = null;
                }

                return itemstack;
            }
        }
        else
        {
            return null;
        }
    }

    /**
     * When some containers are closed they call this on each slot, then drop whatever it returns as an EntityItem -
     * like when you close a workbench GUI.
     */
    public ItemStack getStackInSlotOnClosing(int par1)
    {
        if (this.furnaceItemStacks[par1] != null)
        {
            ItemStack itemstack = this.furnaceItemStacks[par1];
            this.furnaceItemStacks[par1] = null;
            return itemstack;
        }
        else
        {
            return null;
        }
    }

    /**
     * Sets the given item stack to the specified slot in the inventory (can be crafting or armor sections).
     */
    public void setInventorySlotContents(int par1, ItemStack par2ItemStack)
    {
        this.furnaceItemStacks[par1] = par2ItemStack;

        if (par2ItemStack != null && par2ItemStack.stackSize > this.getInventoryStackLimit())
        {
            par2ItemStack.stackSize = this.getInventoryStackLimit();
        }
    }

    /**
     * Returns the name of the inventory.
     */
    public String getInvName()
    {
        return this.isInvNameLocalized() ? this.field_94130_e : "container.furnace";
    }

    /**
     * If this returns false, the inventory name will be used as an unlocalized name, and translated into the player's
     * language. Otherwise it will be used directly.
     */
    public boolean isInvNameLocalized()
    {
        return this.field_94130_e != null && this.field_94130_e.length() > 0;
    }

    public void func_94129_a(String par1Str)
    {
        this.field_94130_e = par1Str;
    }

    /**
     * Reads a tile entity from NBT.
     */
    public void readFromNBT(NBTTagCompound par1NBTTagCompound)
    {
        super.readFromNBT(par1NBTTagCompound);
        NBTTagList nbttaglist = par1NBTTagCompound.getTagList("Items");
        this.furnaceItemStacks = new ItemStack[this.getSizeInventory()];

        for (int i = 0; i < nbttaglist.tagCount(); ++i)
        {
            NBTTagCompound nbttagcompound1 = (NBTTagCompound)nbttaglist.tagAt(i);
            byte b0 = nbttagcompound1.getByte("Slot");

            if (b0 >= 0 && b0 < this.furnaceItemStacks.length)
            {
                this.furnaceItemStacks[b0] = ItemStack.loadItemStackFromNBT(nbttagcompound1);
            }
        }

        this.tickBurnTime = par1NBTTagCompound.getShort("BurnTime");
        this.tickCookTime = par1NBTTagCompound.getShort("CookTime");
        this.currentItemBurnTime = getItemBurnTime(this.furnaceItemStacks[1]);

        if (par1NBTTagCompound.hasKey("CustomName"))
        {
            this.field_94130_e = par1NBTTagCompound.getString("CustomName");
        }
    }

    /**
     * Writes a tile entity to NBT.
     */
    public void writeToNBT(NBTTagCompound par1NBTTagCompound)
    {
        super.writeToNBT(par1NBTTagCompound);
        par1NBTTagCompound.setShort("BurnTime", (short)this.tickBurnTime);
        par1NBTTagCompound.setShort("CookTime", (short)this.tickCookTime);
        NBTTagList nbttaglist = new NBTTagList();

        for (int i = 0; i < this.furnaceItemStacks.length; ++i)
        {
            if (this.furnaceItemStacks[i] != null)
            {
                NBTTagCompound nbttagcompound1 = new NBTTagCompound();
                nbttagcompound1.setByte("Slot", (byte)i);
                this.furnaceItemStacks[i].writeToNBT(nbttagcompound1);
                nbttaglist.appendTag(nbttagcompound1);
            }
        }

        par1NBTTagCompound.setTag("Items", nbttaglist);

        if (this.isInvNameLocalized())
        {
            par1NBTTagCompound.setString("CustomName", this.field_94130_e);
        }
    }

    /**
     * Returns the maximum stack size for a inventory slot. Seems to always be 64, possibly will be extended. *Isn't
     * this more of a set than a get?*
     */
    public int getInventoryStackLimit()
    {
        return 64;
    }

    @SideOnly(Side.CLIENT)

    /**
     * Returns an integer between 0 and the passed value representing how close the current item is to being completely
     * cooked
     */
    public int getCookProgressScaled(int par1)
    {
        return this.tickCookTime * par1 / 200;
    }

    @SideOnly(Side.CLIENT)

    /**
     * Returns an integer between 0 and the passed value representing how much burn time is left on the current fuel
     * item, where 0 means that the item is exhausted and the passed value means that the item is fresh
     */
    public int getBurnTimeRemainingScaled(int par1)
    {
        if (this.currentItemBurnTime == 0)
        {
            this.currentItemBurnTime = 200;
        }

        return this.tickBurnTime * par1 / this.currentItemBurnTime;
    }

    /**
     * Returns true if the furnace is currently burning
     */
    public boolean isBurning()
    {
        return this.tickBurnTime > 0;
    }

    /**
     * Allows the entity to update its state. Overridden in most subclasses, e.g. the mob spawner uses this to count
     * ticks and creates a new spawn inside its implementation.
     */
    public void updateEntity()
    {
        boolean flag = this.tickBurnTime > 0;
        boolean flag1 = false;

        if (this.tickBurnTime > 0)
        {
            --this.tickBurnTime;
        }

        if (!this.worldObj.isRemote)
        {
            if (this.tickBurnTime == 0 && this.canSmelt())
            {
                this.currentItemBurnTime = this.tickBurnTime = getItemBurnTime(this.furnaceItemStacks[1]);

                if (this.tickBurnTime > 0)
                {
                    flag1 = true;

                    if (this.furnaceItemStacks[1] != null)
                    {
                        --this.furnaceItemStacks[1].stackSize;

                        if (this.furnaceItemStacks[1].stackSize == 0)
                        {
                            this.furnaceItemStacks[1] = this.furnaceItemStacks[1].getItem().getContainerItemStack(furnaceItemStacks[1]);
                        }
                    }
                }
            }

            if (this.isBurning() && this.canSmelt())
            {
                ++this.tickCookTime;

                if (this.tickCookTime == 200)
                {
                    this.tickCookTime = 0;
                    this.smeltItem();
                    flag1 = true;
                }
            }
            else
            {
                this.tickCookTime = 0;
            }

            if (flag != this.tickBurnTime > 0)
            {
                flag1 = true;
                BlockFurnace.updateFurnaceBlockState(this.tickBurnTime > 0, this.worldObj, this.xCoord, this.yCoord, this.zCoord);
            }
        }

        if (flag1)
        {
            this.onInventoryChanged();
        }
    }

    /**
     * Returns true if the furnace can smelt an item, i.e. has a source item, destination stack isn't full, etc.
     */
    private boolean canSmelt()
    {
        if (this.furnaceItemStacks[0] == null)
        {
            return false;
        }
        else
        {
            ItemStack itemstack = InputFurnaceRecipes.smelting().getSmeltingResult(this.furnaceItemStacks[0]);
            if (itemstack == null) return false;
            if (this.furnaceItemStacks[2] == null) return true;
            if (!this.furnaceItemStacks[2].isItemEqual(itemstack)) return false;
            int result = furnaceItemStacks[2].stackSize + itemstack.stackSize;
            return (result <= getInventoryStackLimit() && result <= itemstack.getMaxStackSize());
        }
    }

    /**
     * Turn one item from the furnace source stack into the appropriate smelted item in the furnace result stack
     */
    public void smeltItem()
    {
        if (this.canSmelt())
        {
            ItemStack itemstack = InputFurnaceRecipes.smelting().getSmeltingResult(this.furnaceItemStacks[0]);

            if (this.furnaceItemStacks[2] == null)
            {
                this.furnaceItemStacks[2] = itemstack.copy();
            }
            else if (this.furnaceItemStacks[2].isItemEqual(itemstack))
            {
                furnaceItemStacks[2].stackSize += itemstack.stackSize;
            }

            --this.furnaceItemStacks[0].stackSize;

            if (this.furnaceItemStacks[0].stackSize <= 0)
            {
                this.furnaceItemStacks[0] = null;
            }
        }
    }

    /**
     * Returns the number of ticks that the supplied fuel item will keep the furnace burning, or 0 if the item isn't
     * fuel
     */
    public static int getItemBurnTime(ItemStack par0ItemStack)
    {
        if (par0ItemStack == null)
        {
            return 0;
        }
        else
        {
            int i = par0ItemStack.getItem().itemID;
            Item item = par0ItemStack.getItem();

            if (par0ItemStack.getItem() instanceof ItemBlock && Block.blocksList[i] != null)
            {
                Block block = Block.blocksList[i];

                if (block == Block.woodSingleSlab)
                {
                    return 150;
                }

                if (block.blockMaterial == Material.wood)
                {
                    return 300;
                }
            }

            if (item instanceof ItemTool && ((ItemTool) item).getToolMaterialName().equals("WOOD")) return 200;
            if (item instanceof ItemSword && ((ItemSword) item).getToolMaterialName().equals("WOOD")) return 200;
            if (item instanceof ItemHoe && ((ItemHoe) item).getMaterialName().equals("WOOD")) return 200;
            if (i == Item.stick.itemID) return 100;
            if (i == Item.coal.itemID) return 1600;
            if (i == Item.bucketLava.itemID) return 20000;
            if (i == Block.sapling.blockID) return 100;
            if (i == Item.blazeRod.itemID) return 2400;
            return GameRegistry.getFuelValue(par0ItemStack);
        }
    }

    /**
     * Return true if item is a fuel source (getItemBurnTime() > 0).
     */
    public static boolean isItemFuel(ItemStack par0ItemStack)
    {
        return getItemBurnTime(par0ItemStack) > 0;
    }

    /**
     * Do not make give this method the name canInteractWith because it clashes with Container
     */
    public boolean isUseableByPlayer(EntityPlayer par1EntityPlayer)
    {
        return this.worldObj.getBlockTileEntity(this.xCoord, this.yCoord, this.zCoord) != this ? false : par1EntityPlayer.getDistanceSq((double)this.xCoord + 0.5D, (double)this.yCoord + 0.5D, (double)this.zCoord + 0.5D) <= 64.0D;
    }

    public void openChest() {}

    public void closeChest() {}

    /**
     * Returns true if automation is allowed to insert the given stack (ignoring stack size) into the given slot.
     */
    public boolean isStackValidForSlot(int par1, ItemStack par2ItemStack)
    {
        return par1 == 2 ? false : (par1 == 1 ? isItemFuel(par2ItemStack) : true);
    }

    /**
     * Returns an array containing the indices of the slots that can be accessed by automation on the given side of this
     * block.
     */
    public int[] getAccessibleSlotsFromSide(int par1)
    {
        return par1 == 0 ? field_102011_e : (par1 == 1 ? field_102010_d : field_102009_f);
    }

    /**
     * Returns true if automation can insert the given item in the given slot from the given side. Args: Slot, item,
     * side
     */
    public boolean canInsertItem(int par1, ItemStack par2ItemStack, int par3)
    {
        return this.isStackValidForSlot(par1, par2ItemStack);
    }

    /**
     * Returns true if automation can extract the given item in the given slot from the given side. Args: Slot, item,
     * side
     */
    public boolean canExtractItem(int par1, ItemStack par2ItemStack, int par3)
    {
        return par3 != 0 || par1 != 1 || par2ItemStack.itemID == Item.bucketEmpty.itemID;
    }

    /***********************************************************************************
     * This function is here for compatibilities sake, Modders should Check for
     * Sided before ContainerWorldly, Vanilla Minecraft does not follow the sided standard
     * that Modding has for a while.
     *
     * In vanilla:
     *
     *   Top: Ores
     *   Sides: Fuel
     *   Bottom: Output
     *
     * Standard Modding:
     *   Top: Ores
     *   Sides: Output
     *   Bottom: Fuel
     *
     * The Modding one is designed after the GUI, the vanilla one is designed because its
     * intended use is for the hopper, which logically would take things in from the top.
     *
     * This will possibly be removed in future updates, and make vanilla the definitive
     * standard.
     */

    
    }
 

timaxa007

Модератор
5,831
409
672
Убрать или закомментировать:
Код:
BlockFurnace.updateFurnaceBlockState(this.tickBurnTime > 0, this.worldObj, this.xCoord, this.yCoord, this.zCoord);
 
71
1
timaxa007 написал(а):
Убрать или закомментировать:
Код:
BlockFurnace.updateFurnaceBlockState(this.tickBurnTime > 0, this.worldObj, this.xCoord, this.yCoord, this.zCoord);
Спасибо!
[merge_posts_bbcode]Добавлено: 22.01.2016 18:05:31[/merge_posts_bbcode]

Может кто ещё подскажет, как добавить проверку?
В слот можно было ложить только те итемы которые будут в рецептах.
То есть в 1-ый слот можно будет положить только какие-то руды, во 2-й только уголь.
 
Сверху