package net.minecraft.enchantment; import net.minecraft.entity.Entity; import net.minecraft.util.DamageSource; import net.minecraft.util.MathHelper; public class EnchantmentProtection extends Enchantment { /** Holds the name to be translated of each protection type. */ private static final String[] protectionName = new String[] {"all", "fire", "fall", "explosion", "projectile"}; /** Holds the base factor of enchantability needed to be able to use the enchant. */ private static final int[] baseEnchantability = new int[] {1, 10, 5, 5, 3}; /** Holds how much each level increased the enchantability factor to be able to use this enchant. */ private static final int[] levelEnchantability = new int[] {11, 8, 6, 8, 6}; /** * Used on the formula of base enchantability, this is the 'window' factor of values to be able to use thing * enchant. */ private static final int[] thresholdEnchantability = new int[] {20, 12, 10, 12, 15}; /** * Defines the type of protection of the enchantment, 0 = all, 1 = fire, 2 = fall (feather fall), 3 = explosion and * 4 = projectile. */ public final int protectionType; private static final String __OBFID = "CL_00000121"; public EnchantmentProtection(int p_i1936_1_, int p_i1936_2_, int p_i1936_3_) { super(p_i1936_1_, p_i1936_2_, EnumEnchantmentType.armor); this.protectionType = p_i1936_3_; if (p_i1936_3_ == 2) { this.type = EnumEnchantmentType.armor_feet; } } /** * Returns the minimal value of enchantability needed on the enchantment level passed. */ public int getMinEnchantability(int p_77321_1_) { return baseEnchantability[this.protectionType] + (p_77321_1_ - 1) * levelEnchantability[this.protectionType]; } /** * Returns the maximum value of enchantability nedded on the enchantment level passed. */ public int getMaxEnchantability(int p_77317_1_) { return this.getMinEnchantability(p_77317_1_) + thresholdEnchantability[this.protectionType]; } /** * Returns the maximum level that the enchantment can have. */ public int getMaxLevel() { return 4; } /** * Calculates de damage protection of the enchantment based on level and damage source passed. */ public int calcModifierDamage(int p_77318_1_, DamageSource p_77318_2_) { if (p_77318_2_.canHarmInCreative()) { return 0; } else { float f = (float)(6 + p_77318_1_ * p_77318_1_) / 3.0F; return this.protectionType == 0 ? MathHelper.floor_float(f * 0.75F) : (this.protectionType == 1 && p_77318_2_.isFireDamage() ? MathHelper.floor_float(f * 1.25F) : (this.protectionType == 2 && p_77318_2_ == DamageSource.fall ? MathHelper.floor_float(f * 2.5F) : (this.protectionType == 3 && p_77318_2_.isExplosion() ? MathHelper.floor_float(f * 1.5F) : (this.protectionType == 4 && p_77318_2_.isProjectile() ? MathHelper.floor_float(f * 1.5F) : 0)))); } } /** * Return the name of key in translation table of this enchantment. */ public String getName() { return "enchantment.protect." + protectionName[this.protectionType]; } /** * Determines if the enchantment passed can be applyied together with this enchantment. */ public boolean canApplyTogether(Enchantment p_77326_1_) { if (p_77326_1_ instanceof EnchantmentProtection) { EnchantmentProtection enchantmentprotection = (EnchantmentProtection)p_77326_1_; return enchantmentprotection.protectionType == this.protectionType ? false : this.protectionType == 2 || enchantmentprotection.protectionType == 2; } else { return super.canApplyTogether(p_77326_1_); } } /** * Gets the amount of ticks an entity should be set fire, adjusted for fire protection. */ public static int getFireTimeForEntity(Entity p_92093_0_, int p_92093_1_) { int j = EnchantmentHelper.getMaxEnchantmentLevel(Enchantment.fireProtection.effectId, p_92093_0_.getInventory()); if (j > 0) { p_92093_1_ -= MathHelper.floor_float((float)p_92093_1_ * (float)j * 0.15F); } return p_92093_1_; } public static double func_92092_a(Entity p_92092_0_, double p_92092_1_) { int i = EnchantmentHelper.getMaxEnchantmentLevel(Enchantment.blastProtection.effectId, p_92092_0_.getInventory()); if (i > 0) { p_92092_1_ -= (double)MathHelper.floor_double(p_92092_1_ * (double)((float)i * 0.15F)); } return p_92092_1_; } }