Armored Elytra armor and toughness
This commit is contained in:
parent
b53fe71fb8
commit
9e3c7fc0be
1 changed files with 33 additions and 4 deletions
|
@ -1,28 +1,52 @@
|
|||
package ru.betterend.item;
|
||||
|
||||
import com.google.common.collect.ImmutableMultimap;
|
||||
import com.google.common.collect.Multimap;
|
||||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
import net.fabricmc.fabric.api.object.builder.v1.client.model.FabricModelPredicateProviderRegistry;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.world.entity.EquipmentSlot;
|
||||
import net.minecraft.world.entity.ai.attributes.Attribute;
|
||||
import net.minecraft.world.entity.ai.attributes.AttributeModifier;
|
||||
import net.minecraft.world.entity.ai.attributes.Attributes;
|
||||
import net.minecraft.world.item.*;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.interfaces.MultiModelItem;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
||||
import java.util.UUID;
|
||||
|
||||
public class ArmoredElytra extends ArmorItem implements MultiModelItem {
|
||||
|
||||
private static final UUID ARMOR_MODIFIER_UUID_CHEST = UUID.fromString("9F3D476D-C118-4544-8365-64846904B48E");
|
||||
|
||||
private final Multimap<Attribute, AttributeModifier> defaultModifiers;
|
||||
private final ResourceLocation wingTexture;
|
||||
private final Item repairItem;
|
||||
private final double movementFactor;
|
||||
private final float toughness;
|
||||
private final int defense;
|
||||
|
||||
public ArmoredElytra(String name, ArmorMaterial material, Item repairItem, int durability, double movementFactor, boolean fireproof) {
|
||||
super(material, EquipmentSlot.CHEST, fireproof ?
|
||||
EndItems.makeItemSettings().durability(durability).rarity(Rarity.RARE).fireResistant() :
|
||||
EndItems.makeItemSettings().durability(durability).rarity(Rarity.RARE));
|
||||
EndItems.makeItemSettings().durability(durability).rarity(Rarity.EPIC).fireResistant() :
|
||||
EndItems.makeItemSettings().durability(durability).rarity(Rarity.EPIC));
|
||||
this.wingTexture = BetterEnd.makeID("textures/entity/" + name + ".png");
|
||||
this.repairItem = repairItem;
|
||||
this.movementFactor = movementFactor;
|
||||
this.defense = (int) ((double) material.getDefenseForSlot(EquipmentSlot.CHEST) / 1.75);
|
||||
this.toughness = material.getToughness() / 1.75F;
|
||||
ImmutableMultimap.Builder<Attribute, AttributeModifier> builder = ImmutableMultimap.builder();
|
||||
builder.put(Attributes.ARMOR, new AttributeModifier(ARMOR_MODIFIER_UUID_CHEST,
|
||||
"Armor modifier", defense, AttributeModifier.Operation.ADDITION));
|
||||
builder.put(Attributes.ARMOR_TOUGHNESS, new AttributeModifier(ARMOR_MODIFIER_UUID_CHEST,
|
||||
"Armor toughness", toughness, AttributeModifier.Operation.ADDITION));
|
||||
if (material == ArmorMaterials.NETHERITE) {
|
||||
builder.put(Attributes.KNOCKBACK_RESISTANCE, new AttributeModifier(ARMOR_MODIFIER_UUID_CHEST,
|
||||
"Armor knockback resistance", knockbackResistance, AttributeModifier.Operation.ADDITION));
|
||||
}
|
||||
this.defaultModifiers = builder.build();
|
||||
}
|
||||
|
||||
public double getMovementFactor() {
|
||||
|
@ -39,14 +63,19 @@ public class ArmoredElytra extends ArmorItem implements MultiModelItem {
|
|||
return super.isValidRepairItem(itemStack, itemStack2) || itemStack2.getItem() == repairItem;
|
||||
}
|
||||
|
||||
@Override
|
||||
public Multimap<Attribute, AttributeModifier> getDefaultAttributeModifiers(EquipmentSlot equipmentSlot) {
|
||||
return equipmentSlot == slot ? defaultModifiers : super.getDefaultAttributeModifiers(equipmentSlot);
|
||||
}
|
||||
|
||||
@Override
|
||||
public int getDefense() {
|
||||
return (int) ((double) super.getDefense() / 1.25);
|
||||
return defense;
|
||||
}
|
||||
|
||||
@Override
|
||||
public float getToughness() {
|
||||
return super.getToughness() / 1.25F;
|
||||
return toughness;
|
||||
}
|
||||
|
||||
@Override
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue