Change models loading (WIP)
This commit is contained in:
parent
60568cea18
commit
d11645aba3
7 changed files with 84 additions and 59 deletions
|
@ -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
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -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());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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());
|
||||||
|
|
|
@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
Loading…
Add table
Add a link
Reference in a new issue