2018-10-26 15:01:48 +02:00
|
|
|
package de.ellpeck.naturesaura.blocks.tiles;
|
|
|
|
|
2020-01-23 20:57:56 +01:00
|
|
|
import de.ellpeck.naturesaura.Helper;
|
|
|
|
import de.ellpeck.naturesaura.NaturesAura;
|
2018-11-11 13:26:19 +01:00
|
|
|
import de.ellpeck.naturesaura.api.aura.chunk.IAuraChunk;
|
2020-01-22 23:21:52 +01:00
|
|
|
import de.ellpeck.naturesaura.api.aura.type.IAuraType;
|
2018-11-12 15:42:56 +01:00
|
|
|
import de.ellpeck.naturesaura.blocks.BlockFurnaceHeater;
|
2020-01-22 23:21:52 +01:00
|
|
|
import de.ellpeck.naturesaura.packet.PacketHandler;
|
|
|
|
import de.ellpeck.naturesaura.packet.PacketParticleStream;
|
2020-01-23 20:57:56 +01:00
|
|
|
import net.minecraft.block.AbstractFurnaceBlock;
|
2018-10-26 15:01:48 +02:00
|
|
|
import net.minecraft.item.ItemStack;
|
2020-01-23 20:57:56 +01:00
|
|
|
import net.minecraft.item.crafting.AbstractCookingRecipe;
|
|
|
|
import net.minecraft.item.crafting.IRecipeType;
|
2019-10-20 22:30:49 +02:00
|
|
|
import net.minecraft.nbt.CompoundNBT;
|
2020-01-23 20:57:56 +01:00
|
|
|
import net.minecraft.tileentity.*;
|
2019-10-20 22:30:49 +02:00
|
|
|
import net.minecraft.util.Direction;
|
2020-01-23 20:57:56 +01:00
|
|
|
import net.minecraft.util.IIntArray;
|
2018-10-26 15:01:48 +02:00
|
|
|
import net.minecraft.util.math.BlockPos;
|
2020-01-23 20:57:56 +01:00
|
|
|
import net.minecraft.util.math.MathHelper;
|
|
|
|
import net.minecraftforge.fml.common.ObfuscationReflectionHelper;
|
|
|
|
|
|
|
|
import java.lang.reflect.Field;
|
2018-10-26 15:01:48 +02:00
|
|
|
|
2020-01-21 21:04:44 +01:00
|
|
|
public class TileEntityFurnaceHeater extends TileEntityImpl implements ITickableTileEntity {
|
2018-10-26 15:01:48 +02:00
|
|
|
|
2020-01-23 20:57:56 +01:00
|
|
|
private static final Field FURNACE_DATA_FIELD = ObfuscationReflectionHelper.findField(AbstractFurnaceTileEntity.class, "field_214013_b");
|
2018-10-26 15:01:48 +02:00
|
|
|
public boolean isActive;
|
|
|
|
|
2020-01-22 01:32:26 +01:00
|
|
|
public TileEntityFurnaceHeater() {
|
|
|
|
super(ModTileEntities.FURNACE_HEATER);
|
2020-01-21 21:04:44 +01:00
|
|
|
}
|
|
|
|
|
2018-10-26 15:01:48 +02:00
|
|
|
@Override
|
2020-01-21 21:04:44 +01:00
|
|
|
public void tick() {
|
|
|
|
if (!this.world.isRemote && this.world.getGameTime() % 5 == 0) {
|
2018-10-26 15:01:48 +02:00
|
|
|
boolean did = false;
|
|
|
|
|
2020-01-21 21:04:44 +01:00
|
|
|
Direction facing = this.world.getBlockState(this.pos).get(BlockFurnaceHeater.FACING);
|
2018-11-12 15:42:56 +01:00
|
|
|
BlockPos tilePos = this.pos.offset(facing.getOpposite());
|
|
|
|
TileEntity tile = this.world.getTileEntity(tilePos);
|
2020-01-23 20:57:56 +01:00
|
|
|
if (tile instanceof AbstractFurnaceTileEntity) {
|
|
|
|
AbstractFurnaceTileEntity furnace = (AbstractFurnaceTileEntity) tile;
|
|
|
|
if (this.isReady(furnace)) {
|
2020-01-26 02:20:08 +01:00
|
|
|
IIntArray data = getFurnaceData(furnace);
|
2020-01-23 20:57:56 +01:00
|
|
|
int burnTime = data.get(0);
|
|
|
|
if (burnTime <= 0)
|
|
|
|
this.world.setBlockState(tilePos, this.world.getBlockState(tilePos).with(AbstractFurnaceBlock.LIT, true));
|
|
|
|
|
2020-01-26 15:52:16 +01:00
|
|
|
data.set(0, 200);
|
2018-10-26 15:01:48 +02:00
|
|
|
//if set higher than 199, it'll never finish because the furnace does ++ and then ==
|
2020-01-26 15:52:16 +01:00
|
|
|
data.set(2, Math.min(data.get(3) - 1, data.get(2) + 5));
|
2018-10-26 15:01:48 +02:00
|
|
|
|
2018-11-26 00:31:58 +01:00
|
|
|
BlockPos spot = IAuraChunk.getHighestSpot(this.world, this.pos, 20, this.pos);
|
2018-11-11 13:26:19 +01:00
|
|
|
IAuraChunk chunk = IAuraChunk.getAuraChunk(this.world, spot);
|
2020-01-26 15:52:16 +01:00
|
|
|
chunk.drainAura(spot, MathHelper.ceil((200 - burnTime) * 16.6F));
|
2018-10-26 15:01:48 +02:00
|
|
|
did = true;
|
|
|
|
|
2020-01-21 21:04:44 +01:00
|
|
|
if (this.world.getGameTime() % 15 == 0) {
|
2020-01-22 23:21:52 +01:00
|
|
|
PacketHandler.sendToAllAround(this.world, this.pos, 32, new PacketParticleStream(
|
2018-10-26 15:01:48 +02:00
|
|
|
this.pos.getX() + (float) this.world.rand.nextGaussian() * 5F,
|
|
|
|
this.pos.getY() + 1 + this.world.rand.nextFloat() * 5F,
|
|
|
|
this.pos.getZ() + (float) this.world.rand.nextGaussian() * 5F,
|
2018-11-12 15:42:56 +01:00
|
|
|
tilePos.getX() + this.world.rand.nextFloat(),
|
|
|
|
tilePos.getY() + this.world.rand.nextFloat(),
|
|
|
|
tilePos.getZ() + this.world.rand.nextFloat(),
|
2018-11-13 00:36:47 +01:00
|
|
|
this.world.rand.nextFloat() * 0.07F + 0.07F, IAuraType.forWorld(this.world).getColor(), this.world.rand.nextFloat() + 0.5F
|
2020-01-22 23:21:52 +01:00
|
|
|
));
|
2018-11-12 15:42:56 +01:00
|
|
|
}
|
2018-10-26 15:01:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-11-04 16:38:09 +01:00
|
|
|
if (did != this.isActive) {
|
2018-10-26 15:01:48 +02:00
|
|
|
this.isActive = did;
|
|
|
|
this.sendToClients();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-26 02:20:08 +01:00
|
|
|
public static IIntArray getFurnaceData(AbstractFurnaceTileEntity tile) {
|
|
|
|
try {
|
|
|
|
return (IIntArray) FURNACE_DATA_FIELD.get(tile);
|
|
|
|
} catch (IllegalAccessException e) {
|
|
|
|
NaturesAura.LOGGER.fatal("Couldn't reflect furnace field", e);
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-01-23 20:57:56 +01:00
|
|
|
private boolean isReady(AbstractFurnaceTileEntity furnace) {
|
2018-10-26 15:01:48 +02:00
|
|
|
if (!furnace.getStackInSlot(1).isEmpty())
|
|
|
|
return false;
|
|
|
|
|
|
|
|
ItemStack input = furnace.getStackInSlot(0);
|
|
|
|
if (!input.isEmpty()) {
|
2020-01-23 20:57:56 +01:00
|
|
|
AbstractCookingRecipe recipe = this.world.getRecipeManager().getRecipe(getRecipeType(furnace), furnace, this.world).orElse(null);
|
|
|
|
if (recipe == null)
|
|
|
|
return false;
|
|
|
|
ItemStack output = recipe.getRecipeOutput();
|
|
|
|
ItemStack currOutput = furnace.getStackInSlot(2);
|
|
|
|
return currOutput.isEmpty() || Helper.areItemsEqual(currOutput, output, true) && currOutput.getCount() + output.getCount() <= output.getMaxStackSize();
|
2018-10-26 15:01:48 +02:00
|
|
|
} else
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2020-01-26 02:20:08 +01:00
|
|
|
public static IRecipeType<? extends AbstractCookingRecipe> getRecipeType(AbstractFurnaceTileEntity furnace) {
|
2020-01-23 20:57:56 +01:00
|
|
|
if (furnace instanceof BlastFurnaceTileEntity) {
|
|
|
|
return IRecipeType.BLASTING;
|
|
|
|
} else if (furnace instanceof SmokerTileEntity) {
|
|
|
|
return IRecipeType.SMOKING;
|
|
|
|
} else {
|
|
|
|
return IRecipeType.SMELTING;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-10-26 15:01:48 +02:00
|
|
|
@Override
|
2019-10-20 22:30:49 +02:00
|
|
|
public void writeNBT(CompoundNBT compound, SaveType type) {
|
2018-11-04 16:38:09 +01:00
|
|
|
super.writeNBT(compound, type);
|
2018-10-26 15:01:48 +02:00
|
|
|
|
2018-11-04 16:38:09 +01:00
|
|
|
if (type == SaveType.SYNC)
|
2020-01-21 21:04:44 +01:00
|
|
|
compound.putBoolean("active", this.isActive);
|
2018-10-26 15:01:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
2019-10-20 22:30:49 +02:00
|
|
|
public void readNBT(CompoundNBT compound, SaveType type) {
|
2018-11-04 16:38:09 +01:00
|
|
|
super.readNBT(compound, type);
|
2018-10-26 15:01:48 +02:00
|
|
|
|
2018-11-04 16:38:09 +01:00
|
|
|
if (type == SaveType.SYNC)
|
2018-10-26 15:01:48 +02:00
|
|
|
this.isActive = compound.getBoolean("active");
|
|
|
|
}
|
|
|
|
}
|