2016-01-28 14:56:49 -08:00
|
|
|
package WayofTime.bloodmagic.livingArmour.upgrade;
|
2016-01-05 18:06:07 -05:00
|
|
|
|
2017-08-14 20:53:42 -07:00
|
|
|
import WayofTime.bloodmagic.BloodMagic;
|
2016-01-05 18:06:07 -05:00
|
|
|
import WayofTime.bloodmagic.api.livingArmour.LivingArmourUpgrade;
|
|
|
|
import com.google.common.collect.HashMultimap;
|
|
|
|
import com.google.common.collect.Multimap;
|
2016-03-17 13:00:44 -07:00
|
|
|
import net.minecraft.entity.SharedMonsterAttributes;
|
|
|
|
import net.minecraft.entity.ai.attributes.AttributeModifier;
|
|
|
|
import net.minecraft.nbt.NBTTagCompound;
|
2017-02-13 19:35:14 -08:00
|
|
|
import org.apache.commons.codec.binary.StringUtils;
|
2016-03-17 13:00:44 -07:00
|
|
|
|
|
|
|
import java.util.UUID;
|
2016-01-05 18:06:07 -05:00
|
|
|
|
|
|
|
public class LivingArmourUpgradeKnockbackResist extends LivingArmourUpgrade
|
|
|
|
{
|
|
|
|
public static final int[] costs = new int[] { 3, 7, 13, 26, 42 };
|
|
|
|
public static final double[] kbModifier = new double[] { 0.2, 0.4, 0.6, 0.8, 1.0 };
|
|
|
|
public static final int[] healthModifier = new int[] { 0, 0, 0, 4, 10 };
|
|
|
|
|
|
|
|
public LivingArmourUpgradeKnockbackResist(int level)
|
|
|
|
{
|
|
|
|
super(level);
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public Multimap<String, AttributeModifier> getAttributeModifiers()
|
|
|
|
{
|
|
|
|
Multimap<String, AttributeModifier> modifierMap = HashMultimap.<String, AttributeModifier>create();
|
|
|
|
|
2017-02-13 19:35:14 -08:00
|
|
|
String name = getUniqueIdentifier() + "-KnockbackModifier1";
|
|
|
|
modifierMap.put(SharedMonsterAttributes.KNOCKBACK_RESISTANCE.getName(), new AttributeModifier(UUID.nameUUIDFromBytes(StringUtils.getBytesUtf8(name)), "KnockbackModifier1", kbModifier[this.level], 0));
|
2016-01-05 18:06:07 -05:00
|
|
|
|
|
|
|
if (healthModifier[this.level] > 0)
|
|
|
|
{
|
2017-02-13 19:35:14 -08:00
|
|
|
name = getUniqueIdentifier() + "-HealthModifier1";
|
|
|
|
modifierMap.put(SharedMonsterAttributes.MAX_HEALTH.getName(), new AttributeModifier(UUID.nameUUIDFromBytes(StringUtils.getBytesUtf8(name)), "HealthModifier1", healthModifier[this.level], 0));
|
2016-01-05 18:06:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
return modifierMap;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getUniqueIdentifier()
|
|
|
|
{
|
2017-08-14 20:53:42 -07:00
|
|
|
return BloodMagic.MODID + ".upgrade.knockback";
|
2016-01-05 18:06:07 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getMaxTier()
|
|
|
|
{
|
|
|
|
return 5;
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public int getCostOfUpgrade()
|
|
|
|
{
|
|
|
|
return costs[this.level];
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void writeToNBT(NBTTagCompound tag)
|
|
|
|
{
|
|
|
|
// EMPTY
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public void readFromNBT(NBTTagCompound tag)
|
|
|
|
{
|
|
|
|
// EMPTY
|
|
|
|
}
|
|
|
|
|
|
|
|
@Override
|
|
|
|
public String getUnlocalizedName()
|
|
|
|
{
|
|
|
|
return tooltipBase + "knockback";
|
|
|
|
}
|
|
|
|
}
|