Merge pull request #116 from Fourmisain/master
Fix knockback resistance not being applied
This commit is contained in:
commit
836cac6f7e
3 changed files with 56 additions and 1 deletions
|
@ -1,17 +1,49 @@
|
||||||
package ru.betterend.item;
|
package ru.betterend.item;
|
||||||
|
|
||||||
|
import com.google.common.collect.ImmutableMultimap;
|
||||||
|
import com.google.common.collect.Multimap;
|
||||||
import net.minecraft.entity.EquipmentSlot;
|
import net.minecraft.entity.EquipmentSlot;
|
||||||
|
import net.minecraft.entity.attribute.EntityAttribute;
|
||||||
|
import net.minecraft.entity.attribute.EntityAttributeModifier;
|
||||||
|
import net.minecraft.entity.attribute.EntityAttributes;
|
||||||
import net.minecraft.item.ArmorItem;
|
import net.minecraft.item.ArmorItem;
|
||||||
import net.minecraft.item.ArmorMaterial;
|
import net.minecraft.item.ArmorMaterial;
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
|
import ru.betterend.mixin.common.ArmorItemAccessor;
|
||||||
import ru.betterend.patterns.Patterned;
|
import ru.betterend.patterns.Patterned;
|
||||||
import ru.betterend.patterns.Patterns;
|
import ru.betterend.patterns.Patterns;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
public class EndArmorItem extends ArmorItem implements Patterned {
|
public class EndArmorItem extends ArmorItem implements Patterned {
|
||||||
public EndArmorItem(ArmorMaterial material, EquipmentSlot slot, Item.Settings settings) {
|
public EndArmorItem(ArmorMaterial material, EquipmentSlot slot, Item.Settings settings) {
|
||||||
super(material, slot, settings);
|
super(material, slot, settings);
|
||||||
|
|
||||||
|
addKnockbackResistance((ArmorItemAccessor) this, slot, this.knockbackResistance);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/** Ensures knockback resistance is actually applied */
|
||||||
|
private static void addKnockbackResistance(ArmorItemAccessor accessor, EquipmentSlot slot, double knockbackResistance) {
|
||||||
|
if (knockbackResistance == 0) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
Multimap<EntityAttribute, EntityAttributeModifier> attributeModifiers = accessor.getAttributeModifiers();
|
||||||
|
|
||||||
|
// In case Mojang or anyone else decided to fix this
|
||||||
|
if (attributeModifiers.keys().contains(EntityAttributes.GENERIC_KNOCKBACK_RESISTANCE)) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
UUID uuid = accessor.getModifiers()[slot.getEntitySlotId()];
|
||||||
|
|
||||||
|
// Rebuild attributeModifiers to include knockback resistance
|
||||||
|
ImmutableMultimap.Builder<EntityAttribute, EntityAttributeModifier> builder = ImmutableMultimap.builder();
|
||||||
|
builder.putAll(attributeModifiers);
|
||||||
|
builder.put(EntityAttributes.GENERIC_KNOCKBACK_RESISTANCE, new EntityAttributeModifier(uuid, "Armor knockback resistance", knockbackResistance, EntityAttributeModifier.Operation.ADDITION));
|
||||||
|
accessor.setAttributeModifiers(builder.build());
|
||||||
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getModelPattern(String name) {
|
public String getModelPattern(String name) {
|
||||||
return Patterns.createJson(Patterns.ITEM_GENERATED, name);
|
return Patterns.createJson(Patterns.ITEM_GENERATED, name);
|
||||||
|
|
|
@ -0,0 +1,22 @@
|
||||||
|
package ru.betterend.mixin.common;
|
||||||
|
|
||||||
|
import com.google.common.collect.Multimap;
|
||||||
|
import net.minecraft.entity.attribute.EntityAttribute;
|
||||||
|
import net.minecraft.entity.attribute.EntityAttributeModifier;
|
||||||
|
import net.minecraft.item.ArmorItem;
|
||||||
|
import org.spongepowered.asm.mixin.Mixin;
|
||||||
|
import org.spongepowered.asm.mixin.gen.Accessor;
|
||||||
|
|
||||||
|
import java.util.UUID;
|
||||||
|
|
||||||
|
@Mixin(ArmorItem.class)
|
||||||
|
public interface ArmorItemAccessor {
|
||||||
|
@Accessor("MODIFIERS")
|
||||||
|
UUID[] getModifiers();
|
||||||
|
|
||||||
|
@Accessor("attributeModifiers")
|
||||||
|
Multimap<EntityAttribute, EntityAttributeModifier> getAttributeModifiers();
|
||||||
|
|
||||||
|
@Accessor("attributeModifiers")
|
||||||
|
void setAttributeModifiers(Multimap<EntityAttribute, EntityAttributeModifier> attributeModifiers);
|
||||||
|
}
|
|
@ -4,6 +4,7 @@
|
||||||
"package": "ru.betterend.mixin.common",
|
"package": "ru.betterend.mixin.common",
|
||||||
"compatibilityLevel": "JAVA_8",
|
"compatibilityLevel": "JAVA_8",
|
||||||
"mixins": [
|
"mixins": [
|
||||||
|
"ArmorItemAccessor",
|
||||||
"EnchantmentScreenHandlerMixin",
|
"EnchantmentScreenHandlerMixin",
|
||||||
"PlayerAdvancementTrackerMixin",
|
"PlayerAdvancementTrackerMixin",
|
||||||
"CraftingScreenHandlerMixin",
|
"CraftingScreenHandlerMixin",
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue