Change models loading (WIP)

This commit is contained in:
Aleksey 2021-05-16 12:10:24 +03:00
parent 60568cea18
commit d11645aba3
7 changed files with 84 additions and 59 deletions

View file

@ -19,6 +19,7 @@ import net.minecraft.world.level.storage.loot.LootContext;
import ru.betterend.client.render.ERenderLayer; import ru.betterend.client.render.ERenderLayer;
import ru.betterend.interfaces.IRenderTypeable; import ru.betterend.interfaces.IRenderTypeable;
import ru.betterend.patterns.BlockModelProvider; import ru.betterend.patterns.BlockModelProvider;
import ru.betterend.patterns.ModelProvider;
import ru.betterend.patterns.Patterns; import ru.betterend.patterns.Patterns;
public class EndChainBlock extends ChainBlock implements BlockModelProvider, IRenderTypeable { public class EndChainBlock extends ChainBlock implements BlockModelProvider, IRenderTypeable {
@ -48,7 +49,7 @@ public class EndChainBlock extends ChainBlock implements BlockModelProvider, IRe
@Override @Override
public BlockModel getModel(ResourceLocation blockId) { public BlockModel getModel(ResourceLocation blockId) {
return BlockModelProvider.createItemModel(blockId.getPath()); return ModelProvider.createItemModel(blockId.getPath());
} }
@Override @Override

View file

@ -1,59 +1,76 @@
package ru.betterend.item; package ru.betterend.item;
import net.fabricmc.api.EnvType;
import net.fabricmc.api.Environment;
import net.fabricmc.fabric.api.item.v1.EquipmentSlotProvider; import net.fabricmc.fabric.api.item.v1.EquipmentSlotProvider;
import net.fabricmc.fabric.api.object.builder.v1.client.model.FabricModelPredicateProviderRegistry; import net.fabricmc.fabric.api.object.builder.v1.client.model.FabricModelPredicateProviderRegistry;
import net.minecraft.client.renderer.block.model.BlockModel;
import net.minecraft.resources.ResourceLocation; import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.entity.EquipmentSlot; import net.minecraft.world.entity.EquipmentSlot;
import net.minecraft.world.item.ElytraItem; import net.minecraft.world.entity.ai.attributes.AttributeModifier;
import net.minecraft.world.item.Item; import net.minecraft.world.entity.ai.attributes.Attributes;
import net.minecraft.world.item.ItemStack; import net.minecraft.world.item.*;
import net.minecraft.world.item.Rarity;
import ru.betterend.BetterEnd; import ru.betterend.BetterEnd;
import ru.betterend.interfaces.BreakableItem; import ru.betterend.interfaces.BreakableItem;
import ru.betterend.patterns.ModelProvider; import ru.betterend.patterns.ModelProvider;
import ru.betterend.patterns.Patterns; import ru.betterend.patterns.Patterns;
import ru.betterend.registry.EndItems; import ru.betterend.registry.EndItems;
public class ArmoredElytra extends ElytraItem implements EquipmentSlotProvider, BreakableItem, ModelProvider { import java.util.UUID;
public class ArmoredElytra extends EndArmorItem implements MultiModelItem {
private static final UUID ARMOR_MODIFIER_UUID_CHEST = ARMOR_MODIFIER_UUID_PER_SLOT[2];
private final ResourceLocation wingTexture; private final ResourceLocation wingTexture;
private final Item repairItem; private final Item repairItem;
private final double movementFactor; private final double movementFactor;
private final float toughness;
private final int defense;
public ArmoredElytra(String name, Item repairItem, int durability, double movementFactor, boolean fireproof) { public ArmoredElytra(String name, ArmorMaterial material, Item repairItem, int durability, double movementFactor, boolean fireproof) {
super(fireproof ? EndItems.makeItemSettings().durability(durability).rarity(Rarity.RARE).fireResistant() : super(material, EquipmentSlot.CHEST, fireproof ?
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.wingTexture = BetterEnd.makeID("textures/entity/" + name + ".png");
this.repairItem = repairItem; this.repairItem = repairItem;
this.movementFactor = movementFactor; this.movementFactor = movementFactor;
this.defense = (int) ((double) material.getDefenseForSlot(EquipmentSlot.CHEST) / 1.75);
this.toughness = material.getToughness() / 1.75F;
addAttributeModifier(Attributes.ARMOR, new AttributeModifier(ARMOR_MODIFIER_UUID_CHEST,
"Armor modifier", defense, AttributeModifier.Operation.ADDITION));
addAttributeModifier(Attributes.ARMOR_TOUGHNESS, new AttributeModifier(ARMOR_MODIFIER_UUID_CHEST,
"Armor toughness", toughness, AttributeModifier.Operation.ADDITION));
} }
public double getMovementFactor() { public double getMovementFactor() {
return movementFactor; return movementFactor;
} }
@Environment(EnvType.CLIENT)
public ResourceLocation getWingTexture() { public ResourceLocation getWingTexture() {
return wingTexture; return wingTexture;
} }
@Override @Override
public boolean isValidRepairItem(ItemStack itemStack, ItemStack itemStack2) { public boolean isValidRepairItem(ItemStack itemStack, ItemStack itemStack2) {
return itemStack2.getItem() == repairItem; return super.isValidRepairItem(itemStack, itemStack2) || itemStack2.getItem() == repairItem;
} }
@Override @Override
public void registerBrokenItem() { public int getDefense() {
return defense;
}
@Override
public float getToughness() {
return toughness;
}
@Override
@Environment(EnvType.CLIENT)
public void registerModelPredicate() {
FabricModelPredicateProviderRegistry.register(this, new ResourceLocation("broken"), FabricModelPredicateProviderRegistry.register(this, new ResourceLocation("broken"),
(itemStack, clientLevel, livingEntity) -> ElytraItem.isFlyEnabled(itemStack) ? 0.0F : 1.0F); (itemStack, clientLevel, livingEntity) -> ElytraItem.isFlyEnabled(itemStack) ? 0.0F : 1.0F);
} }
@Override
public String getModelPattern(String name) {
return Patterns.createItemGenerated(name);
}
@Override
public EquipmentSlot getPreferredEquipmentSlot(ItemStack stack) {
return EquipmentSlot.CHEST;
}
} }

View file

@ -2,9 +2,12 @@ package ru.betterend.item;
import java.util.UUID; import java.util.UUID;
import com.google.common.collect.HashMultimap;
import com.google.common.collect.ImmutableMultimap; import com.google.common.collect.ImmutableMultimap;
import com.google.common.collect.Multimap; import com.google.common.collect.Multimap;
import net.minecraft.client.renderer.block.model.BlockModel;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.entity.EquipmentSlot; import net.minecraft.world.entity.EquipmentSlot;
import net.minecraft.world.entity.ai.attributes.Attribute; import net.minecraft.world.entity.ai.attributes.Attribute;
import net.minecraft.world.entity.ai.attributes.AttributeModifier; import net.minecraft.world.entity.ai.attributes.AttributeModifier;
@ -17,36 +20,41 @@ import ru.betterend.patterns.ModelProvider;
import ru.betterend.patterns.Patterns; import ru.betterend.patterns.Patterns;
public class EndArmorItem extends ArmorItem implements ModelProvider { public class EndArmorItem extends ArmorItem implements ModelProvider {
public EndArmorItem(ArmorMaterial material, EquipmentSlot slot, Item.Properties settings) {
super(material, slot, settings);
addKnockbackResistance((ArmorItemAccessor) this, slot, this.knockbackResistance); protected static final UUID[] ARMOR_MODIFIER_UUID_PER_SLOT = new UUID[] {
} UUID.fromString("845DB27C-C624-495F-8C9F-6020A9A58B6B"),
UUID.fromString("D8499B04-0E66-4726-AB29-64469D734E0D"),
UUID.fromString("9F3D476D-C118-4544-8365-64846904B48E"),
UUID.fromString("2AD3F246-FEE1-4E67-B886-69FD380BB150")
};
/** Ensures knockback resistance is actually applied */ protected final Multimap<Attribute, AttributeModifier> defaultModifiers;
private static void addKnockbackResistance(ArmorItemAccessor accessor, EquipmentSlot slot, double knockbackResistance) {
if (knockbackResistance == 0) { public EndArmorItem(ArmorMaterial material, EquipmentSlot equipmentSlot, Properties settings) {
return; super(material, equipmentSlot, settings);
this.defaultModifiers = HashMultimap.create();
UUID uuid = ARMOR_MODIFIER_UUID_PER_SLOT[equipmentSlot.getIndex()];
addAttributeModifier(Attributes.ARMOR, new AttributeModifier(uuid, "Armor modifier", getDefense(), AttributeModifier.Operation.ADDITION));
addAttributeModifier(Attributes.ARMOR_TOUGHNESS, new AttributeModifier(uuid, "Armor toughness", getToughness(), AttributeModifier.Operation.ADDITION));
if (knockbackResistance > 0.0F) {
addAttributeModifier(Attributes.KNOCKBACK_RESISTANCE, new AttributeModifier(uuid, "Armor knockback resistance", knockbackResistance, AttributeModifier.Operation.ADDITION));
} }
Multimap<Attribute, AttributeModifier> attributeModifiers = accessor.be_getDefaultModifiers();
// In case Mojang or anyone else decided to fix this
if (attributeModifiers.keys().contains(Attributes.KNOCKBACK_RESISTANCE)) {
return;
}
UUID uuid = accessor.be_getModifiers()[slot.getIndex()];
// Rebuild attributeModifiers to include knockback resistance
ImmutableMultimap.Builder<Attribute, AttributeModifier> builder = ImmutableMultimap.builder();
builder.putAll(attributeModifiers);
builder.put(Attributes.KNOCKBACK_RESISTANCE, new AttributeModifier(uuid, "Armor knockback resistance", knockbackResistance, AttributeModifier.Operation.ADDITION));
accessor.be_setDefaultModifiers(builder.build());
} }
@Override @Override
public String getModelPattern(String name) { public Multimap<Attribute, AttributeModifier> getDefaultAttributeModifiers(EquipmentSlot equipmentSlot) {
return Patterns.createJson(Patterns.ITEM_GENERATED, name); return equipmentSlot == slot ? defaultModifiers : super.getDefaultAttributeModifiers(equipmentSlot);
}
protected void addAttributeModifier(Attribute attribute, AttributeModifier modifier) {
if (defaultModifiers.containsKey(attribute)) {
defaultModifiers.removeAll(attribute);
}
defaultModifiers.put(attribute, modifier);
}
@Override
public String getModelString(String name) {
return Patterns.createItemGenerated(name);
} }
} }

View file

@ -15,9 +15,4 @@ public class ModelProviderDiscItem extends RecordItem implements ModelProvider {
public String getModelString(String name) { public String getModelString(String name) {
return Patterns.createJson(Patterns.ITEM_GENERATED, name); return Patterns.createJson(Patterns.ITEM_GENERATED, name);
} }
@Override
public BlockModel getModel() {
return null;
}
} }

View file

@ -1,6 +1,7 @@
package ru.betterend.item; package ru.betterend.item;
import net.minecraft.client.renderer.block.model.BlockModel; import net.minecraft.client.renderer.block.model.BlockModel;
import net.minecraft.resources.ResourceLocation;
import net.minecraft.world.item.Item; import net.minecraft.world.item.Item;
import ru.betterend.patterns.ModelProvider; import ru.betterend.patterns.ModelProvider;
import ru.betterend.patterns.Patterns; import ru.betterend.patterns.Patterns;
@ -16,7 +17,7 @@ public class ModelProviderItem extends Item implements ModelProvider {
} }
@Override @Override
public BlockModel getModel() { public BlockModel getModel(ResourceLocation resourceLocation) {
return null; return ModelProvider.createItemModel(resourceLocation.getPath());
} }
} }

View file

@ -18,11 +18,6 @@ public interface BlockModelProvider extends ModelProvider {
BlockModel getBlockModel(ResourceLocation resourceLocation, BlockState blockState); BlockModel getBlockModel(ResourceLocation resourceLocation, BlockState blockState);
MultiVariant getModelVariant(ResourceLocation resourceLocation, BlockState blockState); MultiVariant getModelVariant(ResourceLocation resourceLocation, BlockState blockState);
static BlockModel createItemModel(String name) {
String pattern = Patterns.createItemGenerated("item/" + name);
return BlockModel.fromString(pattern);
}
static BlockModel createBlockModel(ResourceLocation blockId, String pattern) { static BlockModel createBlockModel(ResourceLocation blockId, String pattern) {
BlockModel model = BlockModel.fromString(pattern); BlockModel model = BlockModel.fromString(pattern);
ResourceLocation modelLoc = new ResourceLocation(blockId.getNamespace(), "blocks/" + blockId.getPath()); ResourceLocation modelLoc = new ResourceLocation(blockId.getNamespace(), "blocks/" + blockId.getPath());

View file

@ -5,5 +5,13 @@ import net.minecraft.resources.ResourceLocation;
public interface ModelProvider { public interface ModelProvider {
String getModelString(String name); String getModelString(String name);
BlockModel getModel(ResourceLocation resourceLocation);
default BlockModel getModel(ResourceLocation resourceLocation) {
return createItemModel(resourceLocation.getPath());
}
static BlockModel createItemModel(String name) {
String pattern = Patterns.createItemGenerated("item/" + name);
return BlockModel.fromString(pattern);
}
} }