Add inputs to crafting events + implement SF/AT events (#1270)
This commit is contained in:
parent
2d83e8047d
commit
79ccd1f3bb
|
@ -1,16 +1,17 @@
|
||||||
package WayofTime.bloodmagic.api.event;
|
package WayofTime.bloodmagic.api.event;
|
||||||
|
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.crafting.Ingredient;
|
|
||||||
import net.minecraftforge.fml.common.eventhandler.Event;
|
import net.minecraftforge.fml.common.eventhandler.Event;
|
||||||
|
|
||||||
public class BloodMagicCraftedEvent extends Event {
|
public class BloodMagicCraftedEvent extends Event {
|
||||||
|
|
||||||
private final boolean modifiable;
|
private final boolean modifiable;
|
||||||
|
private final ItemStack[] inputs;
|
||||||
private ItemStack output;
|
private ItemStack output;
|
||||||
|
|
||||||
public BloodMagicCraftedEvent(ItemStack output, boolean modifiable) {
|
public BloodMagicCraftedEvent(ItemStack output, ItemStack[] inputs, boolean modifiable) {
|
||||||
this.modifiable = modifiable;
|
this.modifiable = modifiable;
|
||||||
|
this.inputs = inputs;
|
||||||
this.output = output;
|
this.output = output;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,6 +19,10 @@ public class BloodMagicCraftedEvent extends Event {
|
||||||
return modifiable;
|
return modifiable;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ItemStack[] getInputs() {
|
||||||
|
return inputs;
|
||||||
|
}
|
||||||
|
|
||||||
public ItemStack getOutput() {
|
public ItemStack getOutput() {
|
||||||
return output;
|
return output;
|
||||||
}
|
}
|
||||||
|
@ -28,22 +33,39 @@ public class BloodMagicCraftedEvent extends Event {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Fired whenever a craft is completed in a BloodAltar.
|
* Fired whenever a craft is completed in a Blood Altar.
|
||||||
* <p>
|
*
|
||||||
* It is not cancelable, however you can modify the output stack.
|
* It is not cancelable, however you can modify the output stack.
|
||||||
*/
|
*/
|
||||||
public static class Altar extends BloodMagicCraftedEvent {
|
public static class Altar extends BloodMagicCraftedEvent {
|
||||||
|
|
||||||
private final Ingredient input;
|
public Altar(ItemStack output, ItemStack input) {
|
||||||
|
super(output, new ItemStack[] { input }, true);
|
||||||
public Altar(Ingredient input, ItemStack output) {
|
|
||||||
super(output, true);
|
|
||||||
|
|
||||||
this.input = input;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Ingredient getInput() {
|
|
||||||
return input;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired whenever a craft is completed in a Soul Forge.
|
||||||
|
*
|
||||||
|
* It is not cancelable, however you can modify the output stack.
|
||||||
|
*/
|
||||||
|
public static class SoulForge extends BloodMagicCraftedEvent {
|
||||||
|
|
||||||
|
public SoulForge(ItemStack output, ItemStack[] inputs) {
|
||||||
|
super(output, inputs, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Fired whenever a craft is completed in an Alchemy Table.
|
||||||
|
*
|
||||||
|
* It is not cancelable, however you can modify the output stack.
|
||||||
|
*/
|
||||||
|
public static class AlchemyTable extends BloodMagicCraftedEvent {
|
||||||
|
|
||||||
|
public AlchemyTable(ItemStack output, ItemStack[] inputs) {
|
||||||
|
super(output, inputs, true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -3,6 +3,7 @@ package WayofTime.bloodmagic.tile;
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
|
import WayofTime.bloodmagic.api.event.BloodMagicCraftedEvent;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
import net.minecraft.inventory.ISidedInventory;
|
import net.minecraft.inventory.ISidedInventory;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
@ -12,6 +13,7 @@ import net.minecraft.tileentity.TileEntityHopper;
|
||||||
import net.minecraft.util.EnumFacing;
|
import net.minecraft.util.EnumFacing;
|
||||||
import net.minecraft.util.ITickable;
|
import net.minecraft.util.ITickable;
|
||||||
import net.minecraft.util.math.BlockPos;
|
import net.minecraft.util.math.BlockPos;
|
||||||
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.common.capabilities.Capability;
|
import net.minecraftforge.common.capabilities.Capability;
|
||||||
import net.minecraftforge.items.CapabilityItemHandler;
|
import net.minecraftforge.items.CapabilityItemHandler;
|
||||||
import net.minecraftforge.items.ItemHandlerHelper;
|
import net.minecraftforge.items.ItemHandlerHelper;
|
||||||
|
@ -26,6 +28,7 @@ import WayofTime.bloodmagic.orb.IBloodOrb;
|
||||||
import WayofTime.bloodmagic.recipe.alchemyTable.AlchemyTableRecipe;
|
import WayofTime.bloodmagic.recipe.alchemyTable.AlchemyTableRecipe;
|
||||||
import WayofTime.bloodmagic.util.Constants;
|
import WayofTime.bloodmagic.util.Constants;
|
||||||
import WayofTime.bloodmagic.util.helper.NetworkHelper;
|
import WayofTime.bloodmagic.util.helper.NetworkHelper;
|
||||||
|
import org.apache.commons.lang3.ArrayUtils;
|
||||||
|
|
||||||
public class TileAlchemyTable extends TileInventory implements ISidedInventory, ITickable
|
public class TileAlchemyTable extends TileInventory implements ISidedInventory, ITickable
|
||||||
{
|
{
|
||||||
|
@ -315,11 +318,18 @@ public class TileAlchemyTable extends TileInventory implements ISidedInventory,
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
ItemStack[] inputs = new ItemStack[0];
|
||||||
|
for (ItemStack stack : inputList)
|
||||||
|
ArrayUtils.add(inputs, stack.copy());
|
||||||
|
|
||||||
|
BloodMagicCraftedEvent.AlchemyTable event = new BloodMagicCraftedEvent.AlchemyTable(recipeAlchemyTable.getOutput().copy(), inputs);
|
||||||
|
MinecraftForge.EVENT_BUS.post(event);
|
||||||
|
|
||||||
ItemStack outputSlotStack = getStackInSlot(outputSlot);
|
ItemStack outputSlotStack = getStackInSlot(outputSlot);
|
||||||
if (outputSlotStack.isEmpty())
|
if (outputSlotStack.isEmpty())
|
||||||
setInventorySlotContents(outputSlot, recipeAlchemyTable.getOutput().copy());
|
setInventorySlotContents(outputSlot, event.getOutput());
|
||||||
else
|
else
|
||||||
outputSlotStack.grow(recipeAlchemyTable.getOutput().getCount());
|
outputSlotStack.grow(event.getOutput().getCount());
|
||||||
|
|
||||||
for (int i = 0; i < 6; i++)
|
for (int i = 0; i < 6; i++)
|
||||||
{
|
{
|
||||||
|
@ -399,11 +409,19 @@ public class TileAlchemyTable extends TileInventory implements ISidedInventory,
|
||||||
|
|
||||||
public void craftItem(List<ItemStack> inputList, AlchemyTableRecipe recipe)
|
public void craftItem(List<ItemStack> inputList, AlchemyTableRecipe recipe)
|
||||||
{
|
{
|
||||||
if (this.canCraft(recipe.getRecipeOutput(inputList)))
|
ItemStack outputStack = recipe.getRecipeOutput(inputList);
|
||||||
|
if (this.canCraft(outputStack))
|
||||||
{
|
{
|
||||||
ItemStack outputStack = recipe.getRecipeOutput(inputList);
|
|
||||||
ItemStack currentOutputStack = getStackInSlot(outputSlot);
|
ItemStack currentOutputStack = getStackInSlot(outputSlot);
|
||||||
|
|
||||||
|
ItemStack[] inputs = new ItemStack[0];
|
||||||
|
for (ItemStack stack : inputList)
|
||||||
|
ArrayUtils.add(inputs, stack.copy());
|
||||||
|
|
||||||
|
BloodMagicCraftedEvent.AlchemyTable event = new BloodMagicCraftedEvent.AlchemyTable(outputStack.copy(), inputs);
|
||||||
|
MinecraftForge.EVENT_BUS.post(event);
|
||||||
|
outputStack = event.getOutput();
|
||||||
|
|
||||||
if (currentOutputStack.isEmpty())
|
if (currentOutputStack.isEmpty())
|
||||||
{
|
{
|
||||||
setInventorySlotContents(outputSlot, outputStack);
|
setInventorySlotContents(outputSlot, outputStack);
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
package WayofTime.bloodmagic.tile;
|
package WayofTime.bloodmagic.tile;
|
||||||
|
|
||||||
|
import WayofTime.bloodmagic.api.event.BloodMagicCraftedEvent;
|
||||||
import WayofTime.bloodmagic.api.impl.BloodMagicAPI;
|
import WayofTime.bloodmagic.api.impl.BloodMagicAPI;
|
||||||
import WayofTime.bloodmagic.api.impl.recipe.RecipeTartaricForge;
|
import WayofTime.bloodmagic.api.impl.recipe.RecipeTartaricForge;
|
||||||
import WayofTime.bloodmagic.util.Constants;
|
import WayofTime.bloodmagic.util.Constants;
|
||||||
|
@ -11,6 +12,7 @@ import WayofTime.bloodmagic.demonAura.WorldDemonWillHandler;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.nbt.NBTTagCompound;
|
import net.minecraft.nbt.NBTTagCompound;
|
||||||
import net.minecraft.util.ITickable;
|
import net.minecraft.util.ITickable;
|
||||||
|
import net.minecraftforge.common.MinecraftForge;
|
||||||
import net.minecraftforge.items.ItemHandlerHelper;
|
import net.minecraftforge.items.ItemHandlerHelper;
|
||||||
|
|
||||||
import java.util.ArrayList;
|
import java.util.ArrayList;
|
||||||
|
@ -132,10 +134,18 @@ public class TileSoulForge extends TileInventory implements ITickable, IDemonWil
|
||||||
if (this.canCraft(recipe)) {
|
if (this.canCraft(recipe)) {
|
||||||
ItemStack currentOutputStack = getStackInSlot(outputSlot);
|
ItemStack currentOutputStack = getStackInSlot(outputSlot);
|
||||||
|
|
||||||
|
List<ItemStack> inputList = new ArrayList<>();
|
||||||
|
for (int i = 0; i < 4; i++)
|
||||||
|
if (!getStackInSlot(i).isEmpty())
|
||||||
|
inputList.add(getStackInSlot(i).copy());
|
||||||
|
|
||||||
|
BloodMagicCraftedEvent.SoulForge event = new BloodMagicCraftedEvent.SoulForge(recipe.getOutput().copy(), inputList.toArray(new ItemStack[0]));
|
||||||
|
MinecraftForge.EVENT_BUS.post(event);
|
||||||
|
|
||||||
if (currentOutputStack.isEmpty()) {
|
if (currentOutputStack.isEmpty()) {
|
||||||
setInventorySlotContents(outputSlot, recipe.getOutput().copy());
|
setInventorySlotContents(outputSlot, event.getOutput());
|
||||||
} else if (ItemHandlerHelper.canItemStacksStack(currentOutputStack, recipe.getOutput())) {
|
} else if (ItemHandlerHelper.canItemStacksStack(currentOutputStack, event.getOutput())) {
|
||||||
currentOutputStack.grow(recipe.getOutput().getCount());
|
currentOutputStack.grow(event.getOutput().getCount());
|
||||||
}
|
}
|
||||||
|
|
||||||
consumeInventory();
|
consumeInventory();
|
||||||
|
|
Loading…
Reference in a new issue