Durability for Inscription Tools
This commit is contained in:
parent
7af53ce85b
commit
99c2b26c6b
|
@ -2,6 +2,7 @@ package WayofTime.bloodmagic.item;
|
||||||
|
|
||||||
import WayofTime.bloodmagic.api.Constants;
|
import WayofTime.bloodmagic.api.Constants;
|
||||||
import WayofTime.bloodmagic.api.ritual.EnumRuneType;
|
import WayofTime.bloodmagic.api.ritual.EnumRuneType;
|
||||||
|
import WayofTime.bloodmagic.api.util.helper.NBTHelper;
|
||||||
import WayofTime.bloodmagic.block.BlockRitualStone;
|
import WayofTime.bloodmagic.block.BlockRitualStone;
|
||||||
import WayofTime.bloodmagic.util.helper.TextHelper;
|
import WayofTime.bloodmagic.util.helper.TextHelper;
|
||||||
import net.minecraft.block.state.IBlockState;
|
import net.minecraft.block.state.IBlockState;
|
||||||
|
@ -18,7 +19,6 @@ import net.minecraftforge.fml.relauncher.SideOnly;
|
||||||
import java.util.Arrays;
|
import java.util.Arrays;
|
||||||
import java.util.List;
|
import java.util.List;
|
||||||
|
|
||||||
// TODO - NBT based damage
|
|
||||||
public class ItemInscriptionTool extends ItemBindable
|
public class ItemInscriptionTool extends ItemBindable
|
||||||
{
|
{
|
||||||
public ItemInscriptionTool()
|
public ItemInscriptionTool()
|
||||||
|
@ -42,24 +42,50 @@ public class ItemInscriptionTool extends ItemBindable
|
||||||
public void getSubItems(Item id, CreativeTabs creativeTab, List<ItemStack> list)
|
public void getSubItems(Item id, CreativeTabs creativeTab, List<ItemStack> list)
|
||||||
{
|
{
|
||||||
for (int i = 1; i < EnumRuneType.values().length; i++)
|
for (int i = 1; i < EnumRuneType.values().length; i++)
|
||||||
list.add(new ItemStack(id, 1, i));
|
{
|
||||||
|
ItemStack stack = NBTHelper.checkNBT(new ItemStack(id, 1, i));
|
||||||
|
stack.getTagCompound().setInteger(Constants.NBT.USES, 10);
|
||||||
|
list.add(stack);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean onItemUse(ItemStack stack, EntityPlayer player, World world, BlockPos pos, EnumFacing side, float hitX, float hitY, float hitZ)
|
public boolean onItemUse(ItemStack stack, EntityPlayer player, World world, BlockPos pos, EnumFacing side, float hitX, float hitY, float hitZ)
|
||||||
{
|
{
|
||||||
|
|
||||||
IBlockState state = world.getBlockState(pos);
|
IBlockState state = world.getBlockState(pos);
|
||||||
|
|
||||||
if (state.getBlock() instanceof BlockRitualStone && !((BlockRitualStone) state.getBlock()).isRuneType(world, pos, getType(stack)))
|
if (state.getBlock() instanceof BlockRitualStone && !((BlockRitualStone) state.getBlock()).isRuneType(world, pos, getType(stack)))
|
||||||
{
|
{
|
||||||
|
stack = NBTHelper.checkNBT(stack);
|
||||||
|
int uses = stack.getTagCompound().getInteger(Constants.NBT.USES);
|
||||||
|
|
||||||
world.setBlockState(pos, state.withProperty(((BlockRitualStone) state.getBlock()).getStringProp(), getType(stack).getName()));
|
world.setBlockState(pos, state.withProperty(((BlockRitualStone) state.getBlock()).getStringProp(), getType(stack).getName()));
|
||||||
|
if (!player.capabilities.isCreativeMode)
|
||||||
|
{
|
||||||
|
stack.getTagCompound().setInteger(Constants.NBT.USES, --uses);
|
||||||
|
if (uses <= 0)
|
||||||
|
player.inventory.setInventorySlotContents(player.inventory.currentItem, null);
|
||||||
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean showDurabilityBar(ItemStack stack) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public double getDurabilityForDisplay(ItemStack stack)
|
||||||
|
{
|
||||||
|
stack = NBTHelper.checkNBT(stack);
|
||||||
|
int uses = stack.getTagCompound().getInteger(Constants.NBT.USES);
|
||||||
|
|
||||||
|
return 1.0 - ((double) uses / (double) 10);
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
@SideOnly(Side.CLIENT)
|
@SideOnly(Side.CLIENT)
|
||||||
public void addInformation(ItemStack stack, EntityPlayer player, List<String> list, boolean advanced)
|
public void addInformation(ItemStack stack, EntityPlayer player, List<String> list, boolean advanced)
|
||||||
|
|
|
@ -6,6 +6,8 @@ import java.util.List;
|
||||||
import java.util.Random;
|
import java.util.Random;
|
||||||
import java.util.concurrent.CopyOnWriteArrayList;
|
import java.util.concurrent.CopyOnWriteArrayList;
|
||||||
|
|
||||||
|
import WayofTime.bloodmagic.api.event.AltarCraftedEvent;
|
||||||
|
import WayofTime.bloodmagic.item.ItemInscriptionTool;
|
||||||
import net.minecraft.block.Block;
|
import net.minecraft.block.Block;
|
||||||
import net.minecraft.enchantment.Enchantment;
|
import net.minecraft.enchantment.Enchantment;
|
||||||
import net.minecraft.enchantment.EnchantmentHelper;
|
import net.minecraft.enchantment.EnchantmentHelper;
|
||||||
|
@ -46,7 +48,6 @@ import net.minecraftforge.fml.common.eventhandler.EventPriority;
|
||||||
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
import net.minecraftforge.fml.common.eventhandler.SubscribeEvent;
|
||||||
import net.minecraftforge.fml.common.gameevent.TickEvent;
|
import net.minecraftforge.fml.common.gameevent.TickEvent;
|
||||||
import net.minecraftforge.fml.relauncher.Side;
|
import net.minecraftforge.fml.relauncher.Side;
|
||||||
import thaumcraft.common.lib.aura.AuraHandler;
|
|
||||||
import WayofTime.bloodmagic.ConfigHandler;
|
import WayofTime.bloodmagic.ConfigHandler;
|
||||||
import WayofTime.bloodmagic.api.BloodMagicAPI;
|
import WayofTime.bloodmagic.api.BloodMagicAPI;
|
||||||
import WayofTime.bloodmagic.api.Constants;
|
import WayofTime.bloodmagic.api.Constants;
|
||||||
|
@ -272,6 +273,15 @@ public class EventHandler
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@SubscribeEvent
|
||||||
|
public void onAltarCrafted(AltarCraftedEvent event)
|
||||||
|
{
|
||||||
|
if (event.getOutput().getItem() instanceof ItemInscriptionTool) {
|
||||||
|
NBTHelper.checkNBT(event.getOutput());
|
||||||
|
event.getOutput().getTagCompound().setInteger(Constants.NBT.USES, 10);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
@SubscribeEvent
|
@SubscribeEvent
|
||||||
public void onEntityHurt(LivingHurtEvent event)
|
public void onEntityHurt(LivingHurtEvent event)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue