generated from tilera/1710mod
feat: implement arcane furnace
This commit is contained in:
parent
9e5e3b8488
commit
40284fb2ec
|
@ -5,6 +5,7 @@ import cpw.mods.fml.client.registry.RenderingRegistry;
|
||||||
import cpw.mods.fml.common.FMLCommonHandler;
|
import cpw.mods.fml.common.FMLCommonHandler;
|
||||||
import cpw.mods.fml.common.registry.GameRegistry;
|
import cpw.mods.fml.common.registry.GameRegistry;
|
||||||
import net.anvilcraft.thaummach.entities.EntitySingularity;
|
import net.anvilcraft.thaummach.entities.EntitySingularity;
|
||||||
|
import net.anvilcraft.thaummach.gui.GuiArcaneFurnace;
|
||||||
import net.anvilcraft.thaummach.gui.GuiBore;
|
import net.anvilcraft.thaummach.gui.GuiBore;
|
||||||
import net.anvilcraft.thaummach.gui.GuiCrystallizer;
|
import net.anvilcraft.thaummach.gui.GuiCrystallizer;
|
||||||
import net.anvilcraft.thaummach.gui.GuiVoidChest;
|
import net.anvilcraft.thaummach.gui.GuiVoidChest;
|
||||||
|
@ -17,6 +18,7 @@ import net.anvilcraft.thaummach.render.tile.TileConduitPumpRenderer;
|
||||||
import net.anvilcraft.thaummach.render.tile.TileCrystallizerRenderer;
|
import net.anvilcraft.thaummach.render.tile.TileCrystallizerRenderer;
|
||||||
import net.anvilcraft.thaummach.render.tile.TileVoidChestRenderer;
|
import net.anvilcraft.thaummach.render.tile.TileVoidChestRenderer;
|
||||||
import net.anvilcraft.thaummach.render.tile.TileVoidInterfaceRenderer;
|
import net.anvilcraft.thaummach.render.tile.TileVoidInterfaceRenderer;
|
||||||
|
import net.anvilcraft.thaummach.tiles.TileArcaneFurnace;
|
||||||
import net.anvilcraft.thaummach.tiles.TileBore;
|
import net.anvilcraft.thaummach.tiles.TileBore;
|
||||||
import net.anvilcraft.thaummach.tiles.TileConduit;
|
import net.anvilcraft.thaummach.tiles.TileConduit;
|
||||||
import net.anvilcraft.thaummach.tiles.TileConduitPump;
|
import net.anvilcraft.thaummach.tiles.TileConduitPump;
|
||||||
|
@ -55,6 +57,7 @@ public class ClientProxy extends CommonProxy {
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void registerTileEntities() {
|
public void registerTileEntities() {
|
||||||
|
GameRegistry.registerTileEntity(TileArcaneFurnace.class, "arcane_furnace");
|
||||||
GameRegistry.registerTileEntity(TileConduit.class, "conduit");
|
GameRegistry.registerTileEntity(TileConduit.class, "conduit");
|
||||||
GameRegistry.registerTileEntity(TileConduitTank.class, "conduit_tank");
|
GameRegistry.registerTileEntity(TileConduitTank.class, "conduit_tank");
|
||||||
GameRegistry.registerTileEntity(TileConduitValve.class, "conduit_valve");
|
GameRegistry.registerTileEntity(TileConduitValve.class, "conduit_valve");
|
||||||
|
@ -87,18 +90,21 @@ public class ClientProxy extends CommonProxy {
|
||||||
getClientGuiElement(int id, EntityPlayer player, World world, int x, int y, int z) {
|
getClientGuiElement(int id, EntityPlayer player, World world, int x, int y, int z) {
|
||||||
TileEntity te = world.getTileEntity(x, y, z);
|
TileEntity te = world.getTileEntity(x, y, z);
|
||||||
switch (GuiID.get(id)) {
|
switch (GuiID.get(id)) {
|
||||||
|
case ARCANE_FURNACE:
|
||||||
|
return new GuiArcaneFurnace(player.inventory, (TileArcaneFurnace) te);
|
||||||
|
|
||||||
case BORE:
|
case BORE:
|
||||||
return new GuiBore(player.inventory, (TileBore) te);
|
return new GuiBore(player.inventory, (TileBore) te);
|
||||||
|
|
||||||
|
case CRYSTALLIZER:
|
||||||
|
return new GuiCrystallizer(player.inventory, (TileCrystallizer) te);
|
||||||
|
|
||||||
case VOID_CHEST:
|
case VOID_CHEST:
|
||||||
return new GuiVoidChest(player.inventory, (TileVoidChest) te);
|
return new GuiVoidChest(player.inventory, (TileVoidChest) te);
|
||||||
|
|
||||||
case VOID_INTERFACE:
|
case VOID_INTERFACE:
|
||||||
return new GuiVoidInterface(player.inventory, (TileVoidInterface) te);
|
return new GuiVoidInterface(player.inventory, (TileVoidInterface) te);
|
||||||
|
|
||||||
case CRYSTALLIZER:
|
|
||||||
return new GuiCrystallizer(player.inventory, (TileCrystallizer) te);
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("ALEC");
|
throw new IllegalArgumentException("ALEC");
|
||||||
}
|
}
|
||||||
|
|
|
@ -2,10 +2,12 @@ package net.anvilcraft.thaummach;
|
||||||
|
|
||||||
import cpw.mods.fml.common.network.IGuiHandler;
|
import cpw.mods.fml.common.network.IGuiHandler;
|
||||||
import cpw.mods.fml.common.registry.GameRegistry;
|
import cpw.mods.fml.common.registry.GameRegistry;
|
||||||
|
import net.anvilcraft.thaummach.container.ContainerArcaneFurnace;
|
||||||
import net.anvilcraft.thaummach.container.ContainerBore;
|
import net.anvilcraft.thaummach.container.ContainerBore;
|
||||||
import net.anvilcraft.thaummach.container.ContainerCrystallizer;
|
import net.anvilcraft.thaummach.container.ContainerCrystallizer;
|
||||||
import net.anvilcraft.thaummach.container.ContainerVoidChest;
|
import net.anvilcraft.thaummach.container.ContainerVoidChest;
|
||||||
import net.anvilcraft.thaummach.container.ContainerVoidInterface;
|
import net.anvilcraft.thaummach.container.ContainerVoidInterface;
|
||||||
|
import net.anvilcraft.thaummach.tiles.TileArcaneFurnace;
|
||||||
import net.anvilcraft.thaummach.tiles.TileBore;
|
import net.anvilcraft.thaummach.tiles.TileBore;
|
||||||
import net.anvilcraft.thaummach.tiles.TileConduit;
|
import net.anvilcraft.thaummach.tiles.TileConduit;
|
||||||
import net.anvilcraft.thaummach.tiles.TileConduitPump;
|
import net.anvilcraft.thaummach.tiles.TileConduitPump;
|
||||||
|
@ -30,6 +32,7 @@ public class CommonProxy implements IGuiHandler {
|
||||||
public void init() {}
|
public void init() {}
|
||||||
|
|
||||||
public void registerTileEntities() {
|
public void registerTileEntities() {
|
||||||
|
GameRegistry.registerTileEntity(TileArcaneFurnace.class, "arcane_furnace");
|
||||||
GameRegistry.registerTileEntity(TileBore.class, "bore");
|
GameRegistry.registerTileEntity(TileBore.class, "bore");
|
||||||
GameRegistry.registerTileEntity(TileConduit.class, "conduit");
|
GameRegistry.registerTileEntity(TileConduit.class, "conduit");
|
||||||
GameRegistry.registerTileEntity(TileConduitPump.class, "conduit_pump");
|
GameRegistry.registerTileEntity(TileConduitPump.class, "conduit_pump");
|
||||||
|
@ -53,9 +56,17 @@ public class CommonProxy implements IGuiHandler {
|
||||||
getServerGuiElement(int id, EntityPlayer player, World world, int x, int y, int z) {
|
getServerGuiElement(int id, EntityPlayer player, World world, int x, int y, int z) {
|
||||||
TileEntity te = world.getTileEntity(x, y, z);
|
TileEntity te = world.getTileEntity(x, y, z);
|
||||||
switch (GuiID.get(id)) {
|
switch (GuiID.get(id)) {
|
||||||
|
case ARCANE_FURNACE:
|
||||||
|
return new ContainerArcaneFurnace(
|
||||||
|
player.inventory, (TileArcaneFurnace) te
|
||||||
|
);
|
||||||
|
|
||||||
case BORE:
|
case BORE:
|
||||||
return new ContainerBore(player.inventory, (TileBore) te);
|
return new ContainerBore(player.inventory, (TileBore) te);
|
||||||
|
|
||||||
|
case CRYSTALLIZER:
|
||||||
|
return new ContainerCrystallizer(player.inventory, (TileCrystallizer) te);
|
||||||
|
|
||||||
case VOID_CHEST:
|
case VOID_CHEST:
|
||||||
return new ContainerVoidChest(player.inventory, (TileVoidChest) te);
|
return new ContainerVoidChest(player.inventory, (TileVoidChest) te);
|
||||||
|
|
||||||
|
@ -64,9 +75,6 @@ public class CommonProxy implements IGuiHandler {
|
||||||
player.inventory, (TileVoidInterface) te
|
player.inventory, (TileVoidInterface) te
|
||||||
);
|
);
|
||||||
|
|
||||||
case CRYSTALLIZER:
|
|
||||||
return new ContainerCrystallizer(player.inventory, (TileCrystallizer) te);
|
|
||||||
|
|
||||||
default:
|
default:
|
||||||
throw new IllegalArgumentException("ALEC");
|
throw new IllegalArgumentException("ALEC");
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,10 +1,11 @@
|
||||||
package net.anvilcraft.thaummach;
|
package net.anvilcraft.thaummach;
|
||||||
|
|
||||||
public enum GuiID {
|
public enum GuiID {
|
||||||
|
ARCANE_FURNACE,
|
||||||
BORE,
|
BORE,
|
||||||
|
CRYSTALLIZER,
|
||||||
VOID_CHEST,
|
VOID_CHEST,
|
||||||
VOID_INTERFACE,
|
VOID_INTERFACE;
|
||||||
CRYSTALLIZER;
|
|
||||||
|
|
||||||
public static GuiID get(int id) {
|
public static GuiID get(int id) {
|
||||||
if (id >= 0 && id < GuiID.values().length) {
|
if (id >= 0 && id < GuiID.values().length) {
|
||||||
|
|
|
@ -0,0 +1,108 @@
|
||||||
|
package net.anvilcraft.thaummach.container;
|
||||||
|
|
||||||
|
import net.anvilcraft.thaummach.OutputSlot;
|
||||||
|
import net.anvilcraft.thaummach.tiles.TileArcaneFurnace;
|
||||||
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
|
import net.minecraft.entity.player.InventoryPlayer;
|
||||||
|
import net.minecraft.inventory.Container;
|
||||||
|
import net.minecraft.inventory.Slot;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
|
public class ContainerArcaneFurnace extends Container {
|
||||||
|
private TileArcaneFurnace arcaneFurnace;
|
||||||
|
|
||||||
|
public ContainerArcaneFurnace(
|
||||||
|
InventoryPlayer inventoryplayer, TileArcaneFurnace tileArcaneFurnace
|
||||||
|
) {
|
||||||
|
this.arcaneFurnace = tileArcaneFurnace;
|
||||||
|
|
||||||
|
int j;
|
||||||
|
int k;
|
||||||
|
for (j = 0; j < 3; ++j) {
|
||||||
|
for (k = 0; k < 3; ++k) {
|
||||||
|
this.addSlotToContainer(
|
||||||
|
new Slot(tileArcaneFurnace, 9 + k + j * 3, 17 + k * 18, 17 + j * 18)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
this.addSlotToContainer(new Slot(tileArcaneFurnace, 18, 80, 53));
|
||||||
|
|
||||||
|
for (j = 0; j < 3; ++j) {
|
||||||
|
for (k = 0; k < 3; ++k) {
|
||||||
|
this.addSlotToContainer(new OutputSlot(
|
||||||
|
tileArcaneFurnace, k + j * 3, 107 + k * 18, 17 + j * 18
|
||||||
|
));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (j = 0; j < 3; ++j) {
|
||||||
|
for (k = 0; k < 9; ++k) {
|
||||||
|
this.addSlotToContainer(
|
||||||
|
new Slot(inventoryplayer, k + j * 9 + 9, 8 + k * 18, 84 + j * 18)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for (j = 0; j < 9; ++j) {
|
||||||
|
this.addSlotToContainer(new Slot(inventoryplayer, j, 8 + j * 18, 142));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
//@Override
|
||||||
|
//public void updateCraftingResults() {
|
||||||
|
// super.updateCraftingResults();
|
||||||
|
|
||||||
|
// for (int i = 0; i < super.inventorySlots.size(); ++i) {
|
||||||
|
// ICrafting icrafting = (ICrafting) super.inventorySlots.get(i);
|
||||||
|
// if (this.lastCookTime != this.arcaneFurnace.furnaceCookTime) {
|
||||||
|
// icrafting.updateCraftingInventoryInfo(
|
||||||
|
// this, 0, Math.round((float) this.arcaneFurnace.furnaceCookTime)
|
||||||
|
// );
|
||||||
|
// }
|
||||||
|
// }
|
||||||
|
|
||||||
|
// this.lastCookTime = Math.round((float) this.arcaneFurnace.furnaceCookTime);
|
||||||
|
//}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void updateProgressBar(int i, int j) {
|
||||||
|
if (i == 0) {
|
||||||
|
this.arcaneFurnace.furnaceCookTime = j;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean canInteractWith(EntityPlayer entityplayer) {
|
||||||
|
return this.arcaneFurnace.isUseableByPlayer(entityplayer);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ItemStack transferStackInSlot(EntityPlayer player, int i) {
|
||||||
|
ItemStack itemstack = null;
|
||||||
|
Slot slot = (Slot) super.inventorySlots.get(i);
|
||||||
|
if (slot != null && slot.getHasStack()) {
|
||||||
|
ItemStack itemstack1 = slot.getStack();
|
||||||
|
itemstack = itemstack1.copy();
|
||||||
|
if (i < 19) {
|
||||||
|
if (!this.mergeItemStack(itemstack1, 19, 46, true)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
} else if (i >= 19 && i < 46 && !this.mergeItemStack(itemstack1, 0, 9, false)) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (itemstack1.stackSize == 0) {
|
||||||
|
slot.putStack((ItemStack) null);
|
||||||
|
} else {
|
||||||
|
slot.onSlotChanged();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (itemstack1.stackSize == itemstack.stackSize) {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return itemstack;
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,47 @@
|
||||||
|
package net.anvilcraft.thaummach.gui;
|
||||||
|
|
||||||
|
import net.anvilcraft.thaummach.container.ContainerArcaneFurnace;
|
||||||
|
import net.anvilcraft.thaummach.tiles.TileArcaneFurnace;
|
||||||
|
import net.minecraft.client.gui.inventory.GuiContainer;
|
||||||
|
import net.minecraft.entity.player.InventoryPlayer;
|
||||||
|
import net.minecraft.util.ResourceLocation;
|
||||||
|
import org.lwjgl.opengl.GL11;
|
||||||
|
|
||||||
|
public class GuiArcaneFurnace extends GuiContainer {
|
||||||
|
private TileArcaneFurnace arcaneFurnaceInventory;
|
||||||
|
|
||||||
|
public GuiArcaneFurnace(
|
||||||
|
InventoryPlayer inventoryplayer, TileArcaneFurnace tileArcaneFurnace
|
||||||
|
) {
|
||||||
|
super(new ContainerArcaneFurnace(inventoryplayer, tileArcaneFurnace));
|
||||||
|
this.arcaneFurnaceInventory = tileArcaneFurnace;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void drawGuiContainerForegroundLayer(int alec1, int alec2) {
|
||||||
|
super.fontRendererObj.drawString("Thaumic Furnace", 48, 5, 4210752);
|
||||||
|
super.fontRendererObj.drawString("Inventory", 8, super.ySize - 96 + 2, 4210752);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void drawGuiContainerBackgroundLayer(float f, int qq, int ww) {
|
||||||
|
GL11.glColor4f(1.0F, 1.0F, 1.0F, 1.0F);
|
||||||
|
super.mc.renderEngine.bindTexture(
|
||||||
|
new ResourceLocation("thaummach", "textures/guis/arcane_furnace.png")
|
||||||
|
);
|
||||||
|
int l = (super.width - super.xSize) / 2;
|
||||||
|
int i1 = (super.height - super.ySize) / 2;
|
||||||
|
this.drawTexturedModalRect(l, i1, 0, 0, super.xSize, super.ySize);
|
||||||
|
int j1;
|
||||||
|
if (this.arcaneFurnaceInventory.isWorking()) {
|
||||||
|
j1 = this.arcaneFurnaceInventory.getBurnTimeRemainingScaled(16);
|
||||||
|
this.drawTexturedModalRect(l + 80, i1 + 32 + 16 - j1, 176, 16 - j1, 16, j1);
|
||||||
|
} else if (this.arcaneFurnaceInventory.furnaceBurnTime > 0) {
|
||||||
|
j1 = this.arcaneFurnaceInventory.getBurnTimeRemainingScaled(16);
|
||||||
|
this.drawTexturedModalRect(l + 80, i1 + 32 + 16 - j1, 221, 16 - j1, 16, j1);
|
||||||
|
}
|
||||||
|
|
||||||
|
j1 = this.arcaneFurnaceInventory.getCookProgressScaled(26);
|
||||||
|
this.drawTexturedModalRect(l + 75, i1 + 22, 176, 28, j1, 4);
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,12 +4,17 @@ import java.util.stream.IntStream;
|
||||||
|
|
||||||
import dev.tilera.auracore.api.machine.TileVisUser;
|
import dev.tilera.auracore.api.machine.TileVisUser;
|
||||||
import dev.tilera.auracore.aura.AuraManager;
|
import dev.tilera.auracore.aura.AuraManager;
|
||||||
|
import net.anvilcraft.thaummach.GuiID;
|
||||||
|
import net.anvilcraft.thaummach.ITileGui;
|
||||||
import net.minecraft.entity.player.EntityPlayer;
|
import net.minecraft.entity.player.EntityPlayer;
|
||||||
import net.minecraft.inventory.ISidedInventory;
|
import net.minecraft.inventory.ISidedInventory;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.crafting.FurnaceRecipes;
|
import net.minecraft.item.crafting.FurnaceRecipes;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.nbt.NBTTagList;
|
import net.minecraft.nbt.NBTTagList;
|
||||||
|
import net.minecraft.network.NetworkManager;
|
||||||
|
import net.minecraft.network.Packet;
|
||||||
|
import net.minecraft.network.play.server.S35PacketUpdateTileEntity;
|
||||||
import net.minecraft.tileentity.TileEntity;
|
import net.minecraft.tileentity.TileEntity;
|
||||||
import net.minecraft.tileentity.TileEntityFurnace;
|
import net.minecraft.tileentity.TileEntityFurnace;
|
||||||
import net.minecraft.world.EnumSkyBlock;
|
import net.minecraft.world.EnumSkyBlock;
|
||||||
|
@ -17,7 +22,7 @@ import net.minecraftforge.common.util.ForgeDirection;
|
||||||
import thaumcraft.api.aspects.Aspect;
|
import thaumcraft.api.aspects.Aspect;
|
||||||
import thaumcraft.api.aspects.AspectList;
|
import thaumcraft.api.aspects.AspectList;
|
||||||
|
|
||||||
public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
public class TileArcaneFurnace extends TileVisUser implements ISidedInventory, ITileGui {
|
||||||
private ItemStack[] furnaceItemStacks = new ItemStack[19];
|
private ItemStack[] furnaceItemStacks = new ItemStack[19];
|
||||||
public int furnaceBurnTime = 0;
|
public int furnaceBurnTime = 0;
|
||||||
public int currentItemBurnTime = 0;
|
public int currentItemBurnTime = 0;
|
||||||
|
@ -27,10 +32,10 @@ public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
||||||
public float vis;
|
public float vis;
|
||||||
public boolean boost;
|
public boolean boost;
|
||||||
|
|
||||||
// TODO: GUIs
|
@Override
|
||||||
//public GuiScreen getGui(EntityPlayer player) {
|
public GuiID getGuiID() {
|
||||||
// return new GuiArcaneFurnace(player.inventory, this);
|
return GuiID.ARCANE_FURNACE;
|
||||||
//}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public int getSizeInventory() {
|
public int getSizeInventory() {
|
||||||
|
@ -198,10 +203,12 @@ public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
||||||
if (this.furnaceBurnTime > 0
|
if (this.furnaceBurnTime > 0
|
||||||
&& (this.furnaceCookTime > 0 || this.belowHeatableTile())) {
|
&& (this.furnaceCookTime > 0 || this.belowHeatableTile())) {
|
||||||
--this.furnaceBurnTime;
|
--this.furnaceBurnTime;
|
||||||
|
this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (this.furnaceBurnTime <= 0
|
if (this.furnaceBurnTime <= 0
|
||||||
&& (this.canSmelt() || this.belowHeatableTile())) {
|
&& (this.canSmelt() || this.belowHeatableTile())) {
|
||||||
|
this.worldObj.markBlockForUpdate(this.xCoord, this.yCoord, this.zCoord);
|
||||||
this.currentItemBurnTime = this.furnaceBurnTime
|
this.currentItemBurnTime = this.furnaceBurnTime
|
||||||
= getItemBurnTime(this.furnaceItemStacks[18]);
|
= getItemBurnTime(this.furnaceItemStacks[18]);
|
||||||
if (this.furnaceBurnTime > 0) {
|
if (this.furnaceBurnTime > 0) {
|
||||||
|
@ -227,20 +234,10 @@ public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
||||||
this.furnaceMaxCookTime = (int
|
this.furnaceMaxCookTime = (int
|
||||||
) ((float) this.furnaceMaxCookTime
|
) ((float) this.furnaceMaxCookTime
|
||||||
* (1.0F - (float) this.bellows * 0.1F));
|
* (1.0F - (float) this.bellows * 0.1F));
|
||||||
this.worldObj.markBlockForUpdate(
|
|
||||||
this.xCoord, this.yCoord, this.zCoord
|
|
||||||
);
|
|
||||||
super.worldObj.updateLightByType(
|
super.worldObj.updateLightByType(
|
||||||
EnumSkyBlock.Block, super.xCoord, super.yCoord, super.zCoord
|
EnumSkyBlock.Block, super.xCoord, super.yCoord, super.zCoord
|
||||||
);
|
);
|
||||||
// TODO: WTF
|
|
||||||
//if (this.furnaceItemStacks[18].getItem().func_46056_k()) {
|
|
||||||
// this.furnaceItemStacks[18] = new ItemStack(
|
|
||||||
// this.furnaceItemStacks[18].getItem().setFull3D()
|
|
||||||
// );
|
|
||||||
//} else {
|
|
||||||
--this.furnaceItemStacks[18].stackSize;
|
--this.furnaceItemStacks[18].stackSize;
|
||||||
//}
|
|
||||||
|
|
||||||
if (this.furnaceItemStacks[18].stackSize == 0) {
|
if (this.furnaceItemStacks[18].stackSize == 0) {
|
||||||
this.furnaceItemStacks[18] = null;
|
this.furnaceItemStacks[18] = null;
|
||||||
|
@ -284,8 +281,7 @@ public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
||||||
}
|
}
|
||||||
|
|
||||||
if (flag1) {
|
if (flag1) {
|
||||||
// TODO: WTF
|
this.markDirty();
|
||||||
//this.onInventoryChanged();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -364,14 +360,7 @@ public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
||||||
} while (tryAgain);
|
} while (tryAgain);
|
||||||
|
|
||||||
if (smelted) {
|
if (smelted) {
|
||||||
// TODO: WTF
|
|
||||||
//if (this.furnaceItemStacks[input].getItem().func_46056_k()) {
|
|
||||||
// this.furnaceItemStacks[input] = new ItemStack(
|
|
||||||
// this.furnaceItemStacks[input].getItem().setFull3D()
|
|
||||||
// );
|
|
||||||
//} else {
|
|
||||||
--this.furnaceItemStacks[input].stackSize;
|
--this.furnaceItemStacks[input].stackSize;
|
||||||
//}
|
|
||||||
|
|
||||||
if (this.furnaceItemStacks[input].stackSize <= 0) {
|
if (this.furnaceItemStacks[input].stackSize <= 0) {
|
||||||
this.furnaceItemStacks[input] = null;
|
this.furnaceItemStacks[input] = null;
|
||||||
|
@ -477,14 +466,40 @@ public class TileArcaneFurnace extends TileVisUser implements ISidedInventory {
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean
|
public boolean canInsertItem(int slot, ItemStack is, int side) {
|
||||||
canInsertItem(int slot, ItemStack is, int side) {
|
|
||||||
return this.isItemValidForSlot(slot, is);
|
return this.isItemValidForSlot(slot, is);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean
|
public boolean canExtractItem(int slot, ItemStack is, int side) {
|
||||||
canExtractItem(int slot, ItemStack is, int side) {
|
|
||||||
return slot >= 9 && slot <= 17;
|
return slot >= 9 && slot <= 17;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Packet getDescriptionPacket() {
|
||||||
|
NBTTagCompound nbt = new NBTTagCompound();
|
||||||
|
|
||||||
|
nbt.setInteger("furnaceBurnTime", this.furnaceBurnTime);
|
||||||
|
nbt.setInteger("currentItemBurnTime", this.currentItemBurnTime);
|
||||||
|
nbt.setInteger("furnaceCookTime", this.furnaceCookTime);
|
||||||
|
nbt.setInteger("furnaceMaxCookTime", this.furnaceMaxCookTime);
|
||||||
|
nbt.setFloat("vis", this.vis);
|
||||||
|
nbt.setBoolean("boost", this.boost);
|
||||||
|
|
||||||
|
return new S35PacketUpdateTileEntity(
|
||||||
|
this.xCoord, this.yCoord, this.zCoord, this.getBlockMetadata(), nbt
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void onDataPacket(NetworkManager net, S35PacketUpdateTileEntity pkt) {
|
||||||
|
NBTTagCompound nbt = pkt.func_148857_g();
|
||||||
|
|
||||||
|
this.furnaceBurnTime = nbt.getInteger("furnaceBurnTime");
|
||||||
|
this.currentItemBurnTime = nbt.getInteger("currentItemBurnTime");
|
||||||
|
this.furnaceCookTime = nbt.getInteger("furnaceCookTime");
|
||||||
|
this.furnaceMaxCookTime = nbt.getInteger("furnaceMaxCookTime");
|
||||||
|
this.vis = nbt.getFloat("vis");
|
||||||
|
this.boost = nbt.getBoolean("boost");
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
Binary file not shown.
After Width: | Height: | Size: 3.5 KiB |
Loading…
Reference in a new issue