mirror of
https://github.com/Sollace/Unicopia.git
synced 2024-11-23 21:38:00 +01:00
Added filled jars
This commit is contained in:
parent
a94db2025a
commit
b5dc84a139
15 changed files with 274 additions and 83 deletions
|
@ -10,16 +10,23 @@ import com.minelittlepony.unicopia.client.particle.RainboomParticle;
|
||||||
import com.minelittlepony.unicopia.client.particle.RainbowTrailParticle;
|
import com.minelittlepony.unicopia.client.particle.RainbowTrailParticle;
|
||||||
import com.minelittlepony.unicopia.client.particle.RaindropsParticle;
|
import com.minelittlepony.unicopia.client.particle.RaindropsParticle;
|
||||||
import com.minelittlepony.unicopia.client.particle.SphereParticle;
|
import com.minelittlepony.unicopia.client.particle.SphereParticle;
|
||||||
|
import com.minelittlepony.unicopia.item.ChameleonItem;
|
||||||
import com.minelittlepony.unicopia.item.UItems;
|
import com.minelittlepony.unicopia.item.UItems;
|
||||||
import com.minelittlepony.unicopia.particle.UParticles;
|
import com.minelittlepony.unicopia.particle.UParticles;
|
||||||
|
|
||||||
import net.fabricmc.fabric.api.client.particle.v1.ParticleFactoryRegistry;
|
import net.fabricmc.fabric.api.client.particle.v1.ParticleFactoryRegistry;
|
||||||
import net.fabricmc.fabric.api.client.particle.v1.ParticleFactoryRegistry.PendingParticleFactory;
|
import net.fabricmc.fabric.api.client.particle.v1.ParticleFactoryRegistry.PendingParticleFactory;
|
||||||
import net.fabricmc.fabric.api.client.rendereregistry.v1.EntityRendererRegistry;
|
import net.fabricmc.fabric.api.client.rendereregistry.v1.EntityRendererRegistry;
|
||||||
|
import net.fabricmc.fabric.api.client.rendering.v1.BuiltinItemRendererRegistry;
|
||||||
import net.fabricmc.fabric.api.client.rendering.v1.ColorProviderRegistry;
|
import net.fabricmc.fabric.api.client.rendering.v1.ColorProviderRegistry;
|
||||||
|
import net.minecraft.client.MinecraftClient;
|
||||||
import net.minecraft.client.particle.Particle;
|
import net.minecraft.client.particle.Particle;
|
||||||
import net.minecraft.client.particle.SpriteProvider;
|
import net.minecraft.client.particle.SpriteProvider;
|
||||||
|
import net.minecraft.client.render.DiffuseLighting;
|
||||||
|
import net.minecraft.client.render.OverlayTexture;
|
||||||
|
import net.minecraft.client.render.VertexConsumerProvider;
|
||||||
import net.minecraft.client.render.entity.FlyingItemEntityRenderer;
|
import net.minecraft.client.render.entity.FlyingItemEntityRenderer;
|
||||||
|
import net.minecraft.client.render.item.ItemRenderer;
|
||||||
|
import net.minecraft.client.render.model.json.ModelTransformation;
|
||||||
import net.minecraft.client.world.ClientWorld;
|
import net.minecraft.client.world.ClientWorld;
|
||||||
import net.minecraft.item.DyeableItem;
|
import net.minecraft.item.DyeableItem;
|
||||||
import net.minecraft.particle.ParticleEffect;
|
import net.minecraft.particle.ParticleEffect;
|
||||||
|
@ -39,6 +46,37 @@ public interface URenderers {
|
||||||
EntityRendererRegistry.INSTANCE.register(UEntities.THROWN_ITEM, (manager, context) -> new FlyingItemEntityRenderer<>(manager, context.getItemRenderer()));
|
EntityRendererRegistry.INSTANCE.register(UEntities.THROWN_ITEM, (manager, context) -> new FlyingItemEntityRenderer<>(manager, context.getItemRenderer()));
|
||||||
|
|
||||||
ColorProviderRegistry.ITEM.register((stack, i) -> i > 0 ? -1 : ((DyeableItem)stack.getItem()).getColor(stack), UItems.FRIENDSHIP_BRACELET);
|
ColorProviderRegistry.ITEM.register((stack, i) -> i > 0 ? -1 : ((DyeableItem)stack.getItem()).getColor(stack), UItems.FRIENDSHIP_BRACELET);
|
||||||
|
BuiltinItemRendererRegistry.INSTANCE.register(UItems.FILLED_JAR, (stack, mode, matrices, vertexConsumers, light, overlay) -> {
|
||||||
|
|
||||||
|
ItemRenderer renderer = MinecraftClient.getInstance().getItemRenderer();
|
||||||
|
|
||||||
|
ChameleonItem item = (ChameleonItem)stack.getItem();
|
||||||
|
|
||||||
|
// Reset stuff done in the beforelands
|
||||||
|
matrices.pop();
|
||||||
|
|
||||||
|
if (mode == ModelTransformation.Mode.GUI) {
|
||||||
|
DiffuseLighting.disableGuiDepthLighting();
|
||||||
|
}
|
||||||
|
|
||||||
|
VertexConsumerProvider.Immediate immediate = MinecraftClient.getInstance().getBufferBuilders().getEntityVertexConsumers();
|
||||||
|
|
||||||
|
if (item.hasAppearance(stack)) {
|
||||||
|
matrices.push();
|
||||||
|
matrices.scale(0.5F, 0.5F, 0.5F);
|
||||||
|
matrices.translate(0.0125, 0.1, 0);
|
||||||
|
renderer.renderItem(item.getAppearanceStack(stack), mode, light, overlay, matrices, immediate);
|
||||||
|
matrices.pop();
|
||||||
|
}
|
||||||
|
renderer.renderItem(item.createAppearanceStack(stack, UItems.EMPTY_JAR), mode, light, OverlayTexture.DEFAULT_UV, matrices, immediate);
|
||||||
|
immediate.draw();
|
||||||
|
|
||||||
|
if (mode == ModelTransformation.Mode.GUI) {
|
||||||
|
DiffuseLighting.enableGuiDepthLighting();
|
||||||
|
}
|
||||||
|
matrices.push();
|
||||||
|
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
static <T extends ParticleEffect> PendingParticleFactory<T> createFactory(ParticleSupplier<T> supplier) {
|
static <T extends ParticleEffect> PendingParticleFactory<T> createFactory(ParticleSupplier<T> supplier) {
|
||||||
|
|
|
@ -0,0 +1,47 @@
|
||||||
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
|
import net.minecraft.item.Item;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.item.Items;
|
||||||
|
import net.minecraft.util.Identifier;
|
||||||
|
import net.minecraft.util.registry.Registry;
|
||||||
|
|
||||||
|
public interface ChameleonItem {
|
||||||
|
|
||||||
|
default boolean isFullyDisguised() {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
default ItemStack getAppearanceStack(ItemStack stack) {
|
||||||
|
Item appearance = getAppearance(stack);
|
||||||
|
if (appearance != Items.AIR) {
|
||||||
|
return createAppearanceStack(stack, appearance);
|
||||||
|
}
|
||||||
|
return stack;
|
||||||
|
}
|
||||||
|
|
||||||
|
default ItemStack createAppearanceStack(ItemStack stack, Item appearance) {
|
||||||
|
ItemStack newAppearance = new ItemStack(appearance, stack.getCount());
|
||||||
|
if (stack.hasTag()) {
|
||||||
|
newAppearance.setTag(stack.getTag().copy());
|
||||||
|
}
|
||||||
|
newAppearance.removeSubTag("appearance");
|
||||||
|
return newAppearance;
|
||||||
|
}
|
||||||
|
|
||||||
|
default boolean hasAppearance(ItemStack stack) {
|
||||||
|
return getAppearance(stack) != Items.AIR;
|
||||||
|
}
|
||||||
|
|
||||||
|
default Item getAppearance(ItemStack stack) {
|
||||||
|
if (stack.hasTag() && stack.getTag().contains("appearance")) {
|
||||||
|
return Registry.ITEM.get(new Identifier(stack.getTag().getString("appearance")));
|
||||||
|
}
|
||||||
|
|
||||||
|
return Items.AIR;
|
||||||
|
}
|
||||||
|
|
||||||
|
default void setAppearance(ItemStack stack, Item appearance) {
|
||||||
|
stack.getOrCreateTag().putString("appearance", Registry.ITEM.getId(appearance).toString());
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,39 @@
|
||||||
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
|
import com.minelittlepony.unicopia.entity.IItemEntity;
|
||||||
|
import com.minelittlepony.unicopia.projectile.MagicProjectileEntity;
|
||||||
|
import com.minelittlepony.unicopia.util.WorldEvent;
|
||||||
|
|
||||||
|
import net.minecraft.block.Blocks;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.text.Text;
|
||||||
|
import net.minecraft.text.TranslatableText;
|
||||||
|
import net.minecraft.util.ActionResult;
|
||||||
|
|
||||||
|
public class FilledJarItem extends JarItem implements ChameleonItem {
|
||||||
|
|
||||||
|
public FilledJarItem(Settings settings) {
|
||||||
|
super(settings, false, false, false);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Text getName(ItemStack stack) {
|
||||||
|
return hasAppearance(stack) ? new TranslatableText(getTranslationKey(stack), getAppearanceStack(stack).getName()) : UItems.EMPTY_JAR.getName(UItems.EMPTY_JAR.getDefaultStack());
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public boolean isFullyDisguised() {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public ActionResult onGroundTick(IItemEntity item) {
|
||||||
|
return ActionResult.PASS;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected void onImpact(MagicProjectileEntity projectile) {
|
||||||
|
projectile.dropStack(getAppearanceStack(projectile.getStack()));
|
||||||
|
WorldEvent.play(WorldEvent.DESTROY_BLOCK, projectile.world, projectile.getBlockPos(), Blocks.GLASS.getDefaultState());
|
||||||
|
}
|
||||||
|
}
|
|
@ -4,72 +4,39 @@ import net.minecraft.inventory.CraftingInventory;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.item.Items;
|
import net.minecraft.item.Items;
|
||||||
import net.minecraft.recipe.RecipeSerializer;
|
import net.minecraft.recipe.RecipeSerializer;
|
||||||
import net.minecraft.recipe.SpecialCraftingRecipe;
|
|
||||||
import net.minecraft.util.Identifier;
|
import net.minecraft.util.Identifier;
|
||||||
import net.minecraft.util.Pair;
|
import net.minecraft.util.Pair;
|
||||||
import net.minecraft.world.World;
|
|
||||||
|
|
||||||
public class GlowingRecipe extends SpecialCraftingRecipe {
|
public class GlowingRecipe extends ItemCombinationRecipe {
|
||||||
|
|
||||||
public GlowingRecipe(Identifier id) {
|
public GlowingRecipe(Identifier id) {
|
||||||
super(id);
|
super(id);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean matches(CraftingInventory inventory, World world) {
|
public final ItemStack craft(CraftingInventory inventory) {
|
||||||
Pair<ItemStack, ItemStack> result = runMatch(inventory);
|
|
||||||
|
|
||||||
return !result.getLeft().isEmpty() && !result.getRight().isEmpty();
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
|
||||||
public ItemStack craft(CraftingInventory inventory) {
|
|
||||||
Pair<ItemStack, ItemStack> pair = runMatch(inventory);
|
Pair<ItemStack, ItemStack> pair = runMatch(inventory);
|
||||||
|
|
||||||
ItemStack result = pair.getLeft().copy();
|
ItemStack result = pair.getLeft().copy();
|
||||||
|
|
||||||
((GlowableItem)result.getItem()).setGlowing(result, pair.getRight().getItem() == Items.GLOWSTONE_DUST);
|
((GlowableItem)result.getItem()).setGlowing(result, pair.getRight().getItem() == Items.GLOWSTONE_DUST);
|
||||||
|
|
||||||
return result;
|
return result;
|
||||||
}
|
}
|
||||||
|
|
||||||
private Pair<ItemStack, ItemStack> runMatch(CraftingInventory inventory) {
|
@Override
|
||||||
ItemStack bangle = ItemStack.EMPTY;
|
protected boolean isContainerItem(ItemStack stack) {
|
||||||
ItemStack dust = ItemStack.EMPTY;
|
return stack.getItem() instanceof GlowableItem;
|
||||||
|
|
||||||
for(int i = 0; i < inventory.size(); i++) {
|
|
||||||
ItemStack stack = inventory.getStack(i);
|
|
||||||
|
|
||||||
if (!stack.isEmpty()) {
|
|
||||||
if (stack.getItem() instanceof GlowableItem) {
|
|
||||||
if (!bangle.isEmpty()) {
|
|
||||||
return new Pair<>(bangle, dust);
|
|
||||||
}
|
|
||||||
|
|
||||||
bangle = stack;
|
|
||||||
} else {
|
|
||||||
if (!(stack.getItem() == Items.GLOWSTONE_DUST || stack.getItem() == Items.INK_SAC)) {
|
|
||||||
return new Pair<>(bangle, dust);
|
|
||||||
}
|
|
||||||
|
|
||||||
dust = stack;
|
|
||||||
|
|
||||||
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!bangle.isEmpty()) {
|
|
||||||
if ((dust.getItem() == Items.GLOWSTONE_DUST) == ((GlowableItem)bangle.getItem()).isGlowing(bangle)) {
|
|
||||||
return new Pair<>(ItemStack.EMPTY, ItemStack.EMPTY);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return new Pair<>(bangle, dust);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public boolean fits(int i, int j) {
|
protected boolean isInsertItem(ItemStack stack) {
|
||||||
return i * j >= 2;
|
return stack.getItem() == Items.GLOWSTONE_DUST || stack.getItem() == Items.INK_SAC;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean isCombinationInvalid(ItemStack bangle, ItemStack dust) {
|
||||||
|
return (dust.getItem() == Items.GLOWSTONE_DUST) == ((GlowableItem)bangle.getItem()).isGlowing(bangle);
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
|
|
@ -0,0 +1,66 @@
|
||||||
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
|
import net.minecraft.inventory.CraftingInventory;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.recipe.SpecialCraftingRecipe;
|
||||||
|
import net.minecraft.util.Identifier;
|
||||||
|
import net.minecraft.util.Pair;
|
||||||
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
|
public abstract class ItemCombinationRecipe extends SpecialCraftingRecipe {
|
||||||
|
|
||||||
|
public ItemCombinationRecipe(Identifier id) {
|
||||||
|
super(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public final boolean fits(int i, int j) {
|
||||||
|
return i * j >= 2;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public final boolean matches(CraftingInventory inventory, World world) {
|
||||||
|
Pair<ItemStack, ItemStack> result = runMatch(inventory);
|
||||||
|
|
||||||
|
return !result.getLeft().isEmpty() && !result.getRight().isEmpty();
|
||||||
|
}
|
||||||
|
|
||||||
|
protected Pair<ItemStack, ItemStack> runMatch(CraftingInventory inventory) {
|
||||||
|
ItemStack bangle = ItemStack.EMPTY;
|
||||||
|
ItemStack dust = ItemStack.EMPTY;
|
||||||
|
|
||||||
|
for(int i = 0; i < inventory.size(); i++) {
|
||||||
|
ItemStack stack = inventory.getStack(i);
|
||||||
|
|
||||||
|
if (!stack.isEmpty()) {
|
||||||
|
if (isContainerItem(stack)) {
|
||||||
|
if (!bangle.isEmpty()) {
|
||||||
|
return new Pair<>(bangle, dust);
|
||||||
|
}
|
||||||
|
|
||||||
|
bangle = stack;
|
||||||
|
} else {
|
||||||
|
if (!isInsertItem(stack)) {
|
||||||
|
return new Pair<>(bangle, dust);
|
||||||
|
}
|
||||||
|
|
||||||
|
dust = stack;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!bangle.isEmpty() && isCombinationInvalid(bangle, dust)) {
|
||||||
|
return new Pair<>(ItemStack.EMPTY, ItemStack.EMPTY);
|
||||||
|
}
|
||||||
|
|
||||||
|
return new Pair<>(bangle, dust);
|
||||||
|
}
|
||||||
|
|
||||||
|
protected boolean isCombinationInvalid(ItemStack bangle, ItemStack dust) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected abstract boolean isContainerItem(ItemStack stack);
|
||||||
|
|
||||||
|
protected abstract boolean isInsertItem(ItemStack stack);
|
||||||
|
}
|
|
@ -0,0 +1,44 @@
|
||||||
|
package com.minelittlepony.unicopia.item;
|
||||||
|
|
||||||
|
import net.minecraft.inventory.CraftingInventory;
|
||||||
|
import net.minecraft.item.ItemStack;
|
||||||
|
import net.minecraft.recipe.RecipeSerializer;
|
||||||
|
import net.minecraft.util.Identifier;
|
||||||
|
import net.minecraft.util.Pair;
|
||||||
|
|
||||||
|
public class JarInsertRecipe extends ItemCombinationRecipe {
|
||||||
|
|
||||||
|
public JarInsertRecipe(Identifier id) {
|
||||||
|
super(id);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public final ItemStack craft(CraftingInventory inventory) {
|
||||||
|
Pair<ItemStack, ItemStack> pair = runMatch(inventory);
|
||||||
|
|
||||||
|
ItemStack result = new ItemStack(UItems.FILLED_JAR);
|
||||||
|
UItems.FILLED_JAR.setAppearance(result, pair.getRight().getItem());
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean isContainerItem(ItemStack stack) {
|
||||||
|
return stack.getItem() == UItems.EMPTY_JAR;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean isInsertItem(ItemStack stack) {
|
||||||
|
return !(stack.getItem() instanceof JarItem);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
protected boolean isCombinationInvalid(ItemStack bangle, ItemStack dust) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public RecipeSerializer<?> getSerializer() {
|
||||||
|
return URecipes.JAR_INSERT_SERIALIZER;
|
||||||
|
}
|
||||||
|
}
|
|
@ -8,13 +8,11 @@ import com.minelittlepony.unicopia.util.WorldEvent;
|
||||||
|
|
||||||
import net.minecraft.block.BlockState;
|
import net.minecraft.block.BlockState;
|
||||||
import net.minecraft.block.Blocks;
|
import net.minecraft.block.Blocks;
|
||||||
import net.minecraft.block.DispenserBlock;
|
|
||||||
import net.minecraft.entity.Entity;
|
import net.minecraft.entity.Entity;
|
||||||
import net.minecraft.entity.EntityType;
|
import net.minecraft.entity.EntityType;
|
||||||
import net.minecraft.entity.ItemEntity;
|
import net.minecraft.entity.ItemEntity;
|
||||||
import net.minecraft.entity.LightningEntity;
|
import net.minecraft.entity.LightningEntity;
|
||||||
import net.minecraft.entity.player.PlayerEntity;
|
import net.minecraft.entity.player.PlayerEntity;
|
||||||
import net.minecraft.item.ArmorItem;
|
|
||||||
import net.minecraft.item.Item;
|
import net.minecraft.item.Item;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
import net.minecraft.server.world.ServerWorld;
|
import net.minecraft.server.world.ServerWorld;
|
||||||
|
@ -39,8 +37,6 @@ public class JarItem extends Item implements ProjectileDelegate, ItemImpl.Tickab
|
||||||
this.rain = rain;
|
this.rain = rain;
|
||||||
this.thunder = thunder;
|
this.thunder = thunder;
|
||||||
this.lightning = lightning;
|
this.lightning = lightning;
|
||||||
|
|
||||||
DispenserBlock.registerBehavior(this, ArmorItem.DISPENSER_BEHAVIOR);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
|
@ -70,7 +66,6 @@ public class JarItem extends Item implements ProjectileDelegate, ItemImpl.Tickab
|
||||||
return TypedActionResult.success(stack, world.isClient());
|
return TypedActionResult.success(stack, world.isClient());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public ActionResult onGroundTick(IItemEntity item) {
|
public ActionResult onGroundTick(IItemEntity item) {
|
||||||
ItemEntity entity = item.get().getMaster();
|
ItemEntity entity = item.get().getMaster();
|
||||||
|
@ -118,9 +113,7 @@ public class JarItem extends Item implements ProjectileDelegate, ItemImpl.Tickab
|
||||||
onImpact(projectile);
|
onImpact(projectile);
|
||||||
}
|
}
|
||||||
|
|
||||||
private void onImpact(MagicProjectileEntity projectile) {
|
protected void onImpact(MagicProjectileEntity projectile) {
|
||||||
|
|
||||||
|
|
||||||
if (!projectile.isClient()) {
|
if (!projectile.isClient()) {
|
||||||
ServerWorld world = (ServerWorld)projectile.world;
|
ServerWorld world = (ServerWorld)projectile.world;
|
||||||
|
|
||||||
|
|
|
@ -48,6 +48,7 @@ public interface UItems {
|
||||||
));
|
));
|
||||||
|
|
||||||
Item EMPTY_JAR = register("empty_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(16).fireproof(), false, false, false));
|
Item EMPTY_JAR = register("empty_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(16).fireproof(), false, false, false));
|
||||||
|
FilledJarItem FILLED_JAR = register("filled_jar", new FilledJarItem(new Item.Settings().maxCount(1)));
|
||||||
Item RAIN_CLOUD_JAR = register("rain_cloud_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(1).fireproof(), true, false, false));
|
Item RAIN_CLOUD_JAR = register("rain_cloud_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(1).fireproof(), true, false, false));
|
||||||
Item STORM_CLOUD_JAR = register("storm_cloud_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(1).fireproof(), true, true, false));
|
Item STORM_CLOUD_JAR = register("storm_cloud_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(1).fireproof(), true, true, false));
|
||||||
Item LIGHTNING_JAR = register("lightning_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(1).fireproof(), false, false, true));
|
Item LIGHTNING_JAR = register("lightning_jar", new JarItem(new Item.Settings().group(ItemGroup.DECORATIONS).maxCount(1).fireproof(), false, false, true));
|
||||||
|
@ -75,7 +76,11 @@ public interface UItems {
|
||||||
|
|
||||||
FabricItemGroupBuilder.create(new Identifier("unicopia", "items")).appendItems(list -> {
|
FabricItemGroupBuilder.create(new Identifier("unicopia", "items")).appendItems(list -> {
|
||||||
list.addAll(VanillaOverrides.REGISTRY.stream().map(Item::getDefaultStack).collect(Collectors.toList()));
|
list.addAll(VanillaOverrides.REGISTRY.stream().map(Item::getDefaultStack).collect(Collectors.toList()));
|
||||||
list.addAll(ITEMS.stream().map(Item::getDefaultStack).collect(Collectors.toList()));
|
list.addAll(ITEMS.stream()
|
||||||
|
.filter(item -> !(item instanceof ChameleonItem) || ((ChameleonItem)item).isFullyDisguised())
|
||||||
|
.map(Item::getDefaultStack)
|
||||||
|
.collect(Collectors.toList())
|
||||||
|
);
|
||||||
}).icon(ZAP_APPLE::getDefaultStack).build();
|
}).icon(ZAP_APPLE::getDefaultStack).build();
|
||||||
|
|
||||||
FabricItemGroupBuilder.create(new Identifier("unicopia", "horsefeed")).appendItems(list -> {
|
FabricItemGroupBuilder.create(new Identifier("unicopia", "horsefeed")).appendItems(list -> {
|
||||||
|
|
|
@ -16,6 +16,7 @@ public interface URecipes {
|
||||||
|
|
||||||
RecipeSerializer<ShapelessRecipe> ZAP_APPLE_SERIALIZER = register("crafting_zap_apple", new ZapAppleRecipe.Serializer());
|
RecipeSerializer<ShapelessRecipe> ZAP_APPLE_SERIALIZER = register("crafting_zap_apple", new ZapAppleRecipe.Serializer());
|
||||||
RecipeSerializer<GlowingRecipe> GLOWING_SERIALIZER = register("crafting_glowing", new SpecialRecipeSerializer<>(GlowingRecipe::new));
|
RecipeSerializer<GlowingRecipe> GLOWING_SERIALIZER = register("crafting_glowing", new SpecialRecipeSerializer<>(GlowingRecipe::new));
|
||||||
|
RecipeSerializer<JarInsertRecipe> JAR_INSERT_SERIALIZER = register("jar_insert", new SpecialRecipeSerializer<>(JarInsertRecipe::new));
|
||||||
|
|
||||||
static <T extends Recipe<?>> RecipeType<T> register(final String id) {
|
static <T extends Recipe<?>> RecipeType<T> register(final String id) {
|
||||||
return Registry.register(Registry.RECIPE_TYPE, new Identifier("unicopia", id), new RecipeType<T>() {
|
return Registry.register(Registry.RECIPE_TYPE, new Identifier("unicopia", id), new RecipeType<T>() {
|
||||||
|
|
|
@ -24,13 +24,12 @@ import net.minecraft.server.world.ServerWorld;
|
||||||
import net.minecraft.util.ActionResult;
|
import net.minecraft.util.ActionResult;
|
||||||
import net.minecraft.util.collection.DefaultedList;
|
import net.minecraft.util.collection.DefaultedList;
|
||||||
import net.minecraft.util.Hand;
|
import net.minecraft.util.Hand;
|
||||||
import net.minecraft.util.Identifier;
|
|
||||||
import net.minecraft.util.Rarity;
|
import net.minecraft.util.Rarity;
|
||||||
import net.minecraft.util.TypedActionResult;
|
import net.minecraft.util.TypedActionResult;
|
||||||
import net.minecraft.util.registry.Registry;
|
import net.minecraft.util.registry.Registry;
|
||||||
import net.minecraft.world.World;
|
import net.minecraft.world.World;
|
||||||
|
|
||||||
public class ZapAppleItem extends AppleItem {
|
public class ZapAppleItem extends AppleItem implements ChameleonItem {
|
||||||
|
|
||||||
public ZapAppleItem(Settings settings) {
|
public ZapAppleItem(Settings settings) {
|
||||||
super(settings);
|
super(settings);
|
||||||
|
@ -101,25 +100,6 @@ public class ZapAppleItem extends AppleItem {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemStack getAppearanceStack(ItemStack stack) {
|
|
||||||
Item appearance = ((ZapAppleItem)stack.getItem()).getAppearance(stack);
|
|
||||||
if (appearance != Items.AIR) {
|
|
||||||
ItemStack newAppearance = new ItemStack(appearance, stack.getCount());
|
|
||||||
newAppearance.setTag(stack.getTag().copy());
|
|
||||||
newAppearance.removeSubTag("appearance");
|
|
||||||
return newAppearance;
|
|
||||||
}
|
|
||||||
return stack;
|
|
||||||
}
|
|
||||||
|
|
||||||
public Item getAppearance(ItemStack stack) {
|
|
||||||
if (stack.hasTag() && stack.getTag().contains("appearance")) {
|
|
||||||
return Registry.ITEM.get(new Identifier(stack.getTag().getString("appearance")));
|
|
||||||
}
|
|
||||||
|
|
||||||
return Items.AIR;
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String getTranslationKey(ItemStack stack) {
|
public String getTranslationKey(ItemStack stack) {
|
||||||
Item appearance = getAppearance(stack);
|
Item appearance = getAppearance(stack);
|
||||||
|
|
|
@ -4,8 +4,7 @@ import org.spongepowered.asm.mixin.Mixin;
|
||||||
import org.spongepowered.asm.mixin.injection.At;
|
import org.spongepowered.asm.mixin.injection.At;
|
||||||
import org.spongepowered.asm.mixin.injection.ModifyVariable;
|
import org.spongepowered.asm.mixin.injection.ModifyVariable;
|
||||||
|
|
||||||
import com.minelittlepony.unicopia.item.ZapAppleItem;
|
import com.minelittlepony.unicopia.item.ChameleonItem;
|
||||||
|
|
||||||
import net.minecraft.client.render.item.ItemModels;
|
import net.minecraft.client.render.item.ItemModels;
|
||||||
import net.minecraft.item.ItemStack;
|
import net.minecraft.item.ItemStack;
|
||||||
|
|
||||||
|
@ -15,8 +14,8 @@ abstract class MixinItemModels {
|
||||||
at = @At("HEAD"),
|
at = @At("HEAD"),
|
||||||
index = 1)
|
index = 1)
|
||||||
private ItemStack modifyStack(ItemStack stack) {
|
private ItemStack modifyStack(ItemStack stack) {
|
||||||
if (stack.getItem() instanceof ZapAppleItem) {
|
if (stack.getItem() instanceof ChameleonItem && ((ChameleonItem)stack.getItem()).isFullyDisguised()) {
|
||||||
return ((ZapAppleItem)stack.getItem()).getAppearanceStack(stack);
|
return ((ChameleonItem)stack.getItem()).getAppearanceStack(stack);
|
||||||
}
|
}
|
||||||
return stack;
|
return stack;
|
||||||
}
|
}
|
||||||
|
|
|
@ -9,6 +9,7 @@ import com.minelittlepony.unicopia.ability.magic.Spell;
|
||||||
import com.minelittlepony.unicopia.ability.magic.spell.SpellRegistry;
|
import com.minelittlepony.unicopia.ability.magic.spell.SpellRegistry;
|
||||||
import com.minelittlepony.unicopia.entity.EntityPhysics;
|
import com.minelittlepony.unicopia.entity.EntityPhysics;
|
||||||
import com.minelittlepony.unicopia.entity.Physics;
|
import com.minelittlepony.unicopia.entity.Physics;
|
||||||
|
import com.minelittlepony.unicopia.item.UItems;
|
||||||
import com.minelittlepony.unicopia.network.Channel;
|
import com.minelittlepony.unicopia.network.Channel;
|
||||||
import com.minelittlepony.unicopia.network.EffectSync;
|
import com.minelittlepony.unicopia.network.EffectSync;
|
||||||
import com.minelittlepony.unicopia.network.MsgSpawnProjectile;
|
import com.minelittlepony.unicopia.network.MsgSpawnProjectile;
|
||||||
|
@ -193,6 +194,10 @@ public class MagicProjectileEntity extends ThrownItemEntity implements Magical,
|
||||||
return ParticleTypes.ITEM_SNOWBALL;
|
return ParticleTypes.ITEM_SNOWBALL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (stack.getItem() == UItems.FILLED_JAR) {
|
||||||
|
stack = UItems.EMPTY_JAR.getDefaultStack();
|
||||||
|
}
|
||||||
|
|
||||||
return new ItemStackParticleEffect(ParticleTypes.ITEM, stack);
|
return new ItemStackParticleEffect(ParticleTypes.ITEM, stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -17,8 +17,9 @@
|
||||||
"item.unicopia.zap_apple": "Zap Apple",
|
"item.unicopia.zap_apple": "Zap Apple",
|
||||||
|
|
||||||
"item.unicopia.empty_jar": "Glass Jar",
|
"item.unicopia.empty_jar": "Glass Jar",
|
||||||
"item.unicopia.rain_cloud_jar": "Rain Cloud in a Jar",
|
"item.unicopia.filled_jar": "%s in a Jar",
|
||||||
"item.unicopia.storm_cloud_jar": "Storm Cloud in a Jar",
|
"item.unicopia.rain_cloud_jar": "Rain in a Jar",
|
||||||
|
"item.unicopia.storm_cloud_jar": "Storm in a Jar",
|
||||||
"item.unicopia.lightning_jar": "Lightning in a Jar",
|
"item.unicopia.lightning_jar": "Lightning in a Jar",
|
||||||
"item.unicopia.zap_apple_jam_jar": "Zap Apple Jam",
|
"item.unicopia.zap_apple_jam_jar": "Zap Apple Jam",
|
||||||
|
|
||||||
|
|
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"parent": "builtin/entity"
|
||||||
|
}
|
3
src/main/resources/data/unicopia/recipes/filled_jar.json
Normal file
3
src/main/resources/data/unicopia/recipes/filled_jar.json
Normal file
|
@ -0,0 +1,3 @@
|
||||||
|
{
|
||||||
|
"type": "unicopia:jar_insert"
|
||||||
|
}
|
Loading…
Reference in a new issue