Start migration
This commit is contained in:
parent
6630ce0cab
commit
47ed597358
491 changed files with 12045 additions and 11953 deletions
|
@ -1,46 +1,25 @@
|
|||
package ru.betterend.recipe;
|
||||
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
import net.minecraft.world.item.Items;
|
||||
import ru.betterend.recipe.builders.AlloyingRecipe;
|
||||
import ru.betterend.registry.EndBlocks;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
||||
public class AlloyingRecipes {
|
||||
public static void register() {
|
||||
AlloyingRecipe.Builder.create("additional_iron")
|
||||
.setInput(Blocks.IRON_ORE, Blocks.IRON_ORE)
|
||||
.setOutput(Items.IRON_INGOT, 3)
|
||||
.setExpiriense(2.1F)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("additional_gold")
|
||||
.setInput(Blocks.GOLD_ORE, Blocks.GOLD_ORE)
|
||||
.setOutput(Items.GOLD_INGOT, 3)
|
||||
.setExpiriense(3F)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("additional_netherite")
|
||||
.setInput(Blocks.ANCIENT_DEBRIS, Blocks.ANCIENT_DEBRIS)
|
||||
.setOutput(Items.NETHERITE_SCRAP, 3)
|
||||
.setExpiriense(6F)
|
||||
.setSmeltTime(1000)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("terminite_ingot")
|
||||
.setInput(Items.IRON_INGOT, EndItems.ENDER_DUST)
|
||||
.setOutput(EndBlocks.TERMINITE.ingot, 1)
|
||||
.setExpiriense(2.5F)
|
||||
.setSmeltTime(450)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("aeternium_ingot")
|
||||
.setInput(EndBlocks.TERMINITE.ingot, Items.NETHERITE_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_INGOT, 1)
|
||||
.setExpiriense(4.5F)
|
||||
.setSmeltTime(850)
|
||||
.build();
|
||||
AlloyingRecipe.Builder.create("additional_iron").setInput(Blocks.IRON_ORE, Blocks.IRON_ORE)
|
||||
.setOutput(Items.IRON_INGOT, 3).setExpiriense(2.1F).build();
|
||||
AlloyingRecipe.Builder.create("additional_gold").setInput(Blocks.GOLD_ORE, Blocks.GOLD_ORE)
|
||||
.setOutput(Items.GOLD_INGOT, 3).setExpiriense(3F).build();
|
||||
AlloyingRecipe.Builder.create("additional_netherite").setInput(Blocks.ANCIENT_DEBRIS, Blocks.ANCIENT_DEBRIS)
|
||||
.setOutput(Items.NETHERITE_SCRAP, 3).setExpiriense(6F).setSmeltTime(1000).build();
|
||||
AlloyingRecipe.Builder.create("terminite_ingot").setInput(Items.IRON_INGOT, EndItems.ENDER_DUST)
|
||||
.setOutput(EndBlocks.TERMINITE.ingot, 1).setExpiriense(2.5F).setSmeltTime(450).build();
|
||||
AlloyingRecipe.Builder.create("aeternium_ingot").setInput(EndBlocks.TERMINITE.ingot, Items.NETHERITE_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_INGOT, 1).setExpiriense(4.5F).setSmeltTime(850).build();
|
||||
AlloyingRecipe.Builder.create("terminite_ingot_thallasium")
|
||||
.setInput(EndBlocks.THALLASIUM.ingot, EndItems.ENDER_DUST)
|
||||
.setOutput(EndBlocks.TERMINITE.ingot, 1)
|
||||
.setExpiriense(2.5F)
|
||||
.setSmeltTime(450)
|
||||
.build();
|
||||
.setInput(EndBlocks.THALLASIUM.ingot, EndItems.ENDER_DUST).setOutput(EndBlocks.TERMINITE.ingot, 1)
|
||||
.setExpiriense(2.5F).setSmeltTime(450).build();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,67 +1,33 @@
|
|||
package ru.betterend.recipe;
|
||||
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.world.item.Items;
|
||||
import ru.betterend.item.material.EndToolMaterial;
|
||||
import ru.betterend.recipe.builders.AnvilRecipe;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
||||
public class AnvilRecipes {
|
||||
public static void register() {
|
||||
AnvilRecipe.Builder.create("ender_pearl_to_dust")
|
||||
.setInput(Items.ENDER_PEARL)
|
||||
.setOutput(EndItems.ENDER_DUST)
|
||||
.setToolLevel(4)
|
||||
.setDamage(5)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("ender_shard_to_dust")
|
||||
.setInput(EndItems.ENDER_SHARD)
|
||||
.setOutput(EndItems.ENDER_DUST)
|
||||
.setToolLevel(0)
|
||||
.setDamage(3)
|
||||
.build();
|
||||
|
||||
int anvilLevel = EndToolMaterial.AETERNIUM.getMiningLevel();
|
||||
AnvilRecipe.Builder.create("aeternium_axe_head")
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_AXE_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(4)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_pickaxe_head")
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_PICKAXE_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(4)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_shovel_head")
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_SHOVEL_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(4)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_hoe_head")
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_HOE_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(4)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_hammer_head")
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_HAMMER_HEAD)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(4)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_sword_blade")
|
||||
.setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_SWORD_BLADE)
|
||||
.setAnvilLevel(anvilLevel)
|
||||
.setToolLevel(4)
|
||||
.setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("ender_pearl_to_dust").setInput(Items.ENDER_PEARL).setOutput(EndItems.ENDER_DUST)
|
||||
.setToolLevel(4).setDamage(5).build();
|
||||
AnvilRecipe.Builder.create("ender_shard_to_dust").setInput(EndItems.ENDER_SHARD).setOutput(EndItems.ENDER_DUST)
|
||||
.setToolLevel(0).setDamage(3).build();
|
||||
|
||||
int anvilLevel = EndToolMaterial.AETERNIUM.getLevel();
|
||||
AnvilRecipe.Builder.create("aeternium_axe_head").setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_AXE_HEAD).setAnvilLevel(anvilLevel).setToolLevel(4).setDamage(6).build();
|
||||
AnvilRecipe.Builder.create("aeternium_pickaxe_head").setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_PICKAXE_HEAD).setAnvilLevel(anvilLevel).setToolLevel(4).setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_shovel_head").setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_SHOVEL_HEAD).setAnvilLevel(anvilLevel).setToolLevel(4).setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_hoe_head").setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_HOE_HEAD).setAnvilLevel(anvilLevel).setToolLevel(4).setDamage(6).build();
|
||||
AnvilRecipe.Builder.create("aeternium_hammer_head").setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_HAMMER_HEAD).setAnvilLevel(anvilLevel).setToolLevel(4).setDamage(6)
|
||||
.build();
|
||||
AnvilRecipe.Builder.create("aeternium_sword_blade").setInput(EndItems.AETERNIUM_INGOT)
|
||||
.setOutput(EndItems.AETERNIUM_SWORD_BLADE).setAnvilLevel(anvilLevel).setToolLevel(4).setDamage(6)
|
||||
.build();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,10 +1,10 @@
|
|||
package ru.betterend.recipe;
|
||||
|
||||
import net.minecraft.block.Block;
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.world.level.block.Block;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.Items;
|
||||
import net.minecraft.potion.PotionUtil;
|
||||
import net.minecraft.potion.Potions;
|
||||
import ru.betterend.BetterEnd;
|
||||
|
@ -15,71 +15,66 @@ import ru.betterend.registry.EndItems;
|
|||
import ru.betterend.registry.EndTags;
|
||||
|
||||
public class CraftingRecipes {
|
||||
|
||||
|
||||
public static void register() {
|
||||
if (BetterEnd.hasGuideBook()) {
|
||||
GridRecipe.make("guide_book", GuideBookItem.GUIDE_BOOK)
|
||||
.setShape("D", "B", "C")
|
||||
.addMaterial('D', EndItems.ENDER_DUST)
|
||||
.addMaterial('B', Items.BOOK)
|
||||
.addMaterial('C', EndItems.CRYSTAL_SHARDS)
|
||||
.build();
|
||||
GridRecipe.make("guide_book", GuideBookItem.GUIDE_BOOK).setShape("D", "B", "C")
|
||||
.addMaterial('D', EndItems.ENDER_DUST).addMaterial('B', Items.BOOK)
|
||||
.addMaterial('C', EndItems.CRYSTAL_SHARDS).build();
|
||||
}
|
||||
|
||||
GridRecipe.make("ender_perl_to_block", EndBlocks.ENDER_BLOCK)
|
||||
.setShape("OO", "OO")
|
||||
.addMaterial('O', Items.ENDER_PEARL)
|
||||
.build();
|
||||
GridRecipe.make("ender_block_to_perl", Items.ENDER_PEARL)
|
||||
.addMaterial('#', EndBlocks.ENDER_BLOCK)
|
||||
.setOutputCount(4)
|
||||
.setList("#")
|
||||
.build();
|
||||
|
||||
GridRecipe.make("end_stone_smelter", EndBlocks.END_STONE_SMELTER)
|
||||
.setShape("T#T", "V V", "T#T")
|
||||
.addMaterial('#', Blocks.END_STONE_BRICKS)
|
||||
.addMaterial('T', EndBlocks.THALLASIUM.ingot)
|
||||
.addMaterial('V', EndTags.FURNACES)
|
||||
.build();
|
||||
|
||||
registerPedestal("andesite_pedestal", EndBlocks.ANDESITE_PEDESTAL, Blocks.POLISHED_ANDESITE_SLAB, Blocks.POLISHED_ANDESITE);
|
||||
registerPedestal("diorite_pedestal", EndBlocks.DIORITE_PEDESTAL, Blocks.POLISHED_DIORITE_SLAB, Blocks.POLISHED_DIORITE);
|
||||
registerPedestal("granite_pedestal", EndBlocks.GRANITE_PEDESTAL, Blocks.POLISHED_GRANITE_SLAB, Blocks.POLISHED_GRANITE);
|
||||
|
||||
GridRecipe.make("ender_perl_to_block", EndBlocks.ENDER_BLOCK).setShape("OO", "OO")
|
||||
.addMaterial('O', Items.ENDER_PEARL).build();
|
||||
GridRecipe.make("ender_block_to_perl", Items.ENDER_PEARL).addMaterial('#', EndBlocks.ENDER_BLOCK)
|
||||
.setOutputCount(4).setList("#").build();
|
||||
|
||||
GridRecipe.make("end_stone_smelter", EndBlocks.END_STONE_SMELTER).setShape("T#T", "V V", "T#T")
|
||||
.addMaterial('#', Blocks.END_STONE_BRICKS).addMaterial('T', EndBlocks.THALLASIUM.ingot)
|
||||
.addMaterial('V', EndTags.FURNACES).build();
|
||||
|
||||
registerPedestal("andesite_pedestal", EndBlocks.ANDESITE_PEDESTAL, Blocks.POLISHED_ANDESITE_SLAB,
|
||||
Blocks.POLISHED_ANDESITE);
|
||||
registerPedestal("diorite_pedestal", EndBlocks.DIORITE_PEDESTAL, Blocks.POLISHED_DIORITE_SLAB,
|
||||
Blocks.POLISHED_DIORITE);
|
||||
registerPedestal("granite_pedestal", EndBlocks.GRANITE_PEDESTAL, Blocks.POLISHED_GRANITE_SLAB,
|
||||
Blocks.POLISHED_GRANITE);
|
||||
registerPedestal("quartz_pedestal", EndBlocks.QUARTZ_PEDESTAL, Blocks.QUARTZ_SLAB, Blocks.QUARTZ_PILLAR);
|
||||
registerPedestal("purpur_pedestal", EndBlocks.PURPUR_PEDESTAL, Blocks.PURPUR_SLAB, Blocks.PURPUR_PILLAR);
|
||||
|
||||
GridRecipe.make("infusion_pedestal", EndBlocks.INFUSION_PEDESTAL)
|
||||
.setShape(" Y ", "O#O", " # ")
|
||||
.addMaterial('O', Items.ENDER_PEARL)
|
||||
.addMaterial('Y', Items.ENDER_EYE)
|
||||
.addMaterial('#', Blocks.OBSIDIAN)
|
||||
.build();
|
||||
|
||||
|
||||
GridRecipe.make("infusion_pedestal", EndBlocks.INFUSION_PEDESTAL).setShape(" Y ", "O#O", " # ")
|
||||
.addMaterial('O', Items.ENDER_PEARL).addMaterial('Y', Items.ENDER_EYE).addMaterial('#', Blocks.OBSIDIAN)
|
||||
.build();
|
||||
|
||||
String material = "aeternium";
|
||||
GridRecipe.make(material + "_block", EndBlocks.AETERNIUM_BLOCK)
|
||||
.setShape("III", "III", "III")
|
||||
.addMaterial('I', EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
GridRecipe.make(material + "_block", EndBlocks.AETERNIUM_BLOCK).setShape("III", "III", "III")
|
||||
.addMaterial('I', EndItems.AETERNIUM_INGOT).build();
|
||||
GridRecipe.make(material + "_block_to_ingot", EndItems.AETERNIUM_INGOT)
|
||||
.addMaterial('#', EndBlocks.AETERNIUM_BLOCK)
|
||||
.setOutputCount(9)
|
||||
.setList("#")
|
||||
.build();
|
||||
|
||||
GridRecipe.make("blue_vine_seed_dye", Items.BLUE_DYE).setList("#").addMaterial('#', EndBlocks.BLUE_VINE_SEED).build();
|
||||
GridRecipe.make("creeping_moss_dye", Items.CYAN_DYE).setList("#").addMaterial('#', EndBlocks.CREEPING_MOSS).build();
|
||||
GridRecipe.make("umbrella_moss_dye", Items.YELLOW_DYE).setList("#").addMaterial('#', EndBlocks.UMBRELLA_MOSS).build();
|
||||
GridRecipe.make("umbrella_moss_tall_dye", Items.YELLOW_DYE).setOutputCount(2).setList("#").addMaterial('#', EndBlocks.UMBRELLA_MOSS_TALL).build();
|
||||
GridRecipe.make("shadow_plant_dye", Items.BLACK_DYE).setList("#").addMaterial('#', EndBlocks.SHADOW_PLANT).build();
|
||||
|
||||
GridRecipe.make("paper", Items.PAPER).setShape("###").addMaterial('#', EndItems.END_LILY_LEAF_DRIED).setOutputCount(3).build();
|
||||
|
||||
GridRecipe.make("aurora_block", EndBlocks.AURORA_CRYSTAL).setShape("##", "##").addMaterial('#', EndItems.CRYSTAL_SHARDS).build();
|
||||
GridRecipe.make("lotus_block", EndBlocks.END_LOTUS.log).setShape("##", "##").addMaterial('#', EndBlocks.END_LOTUS_STEM).build();
|
||||
GridRecipe.make("needlegrass_stick", Items.STICK).setList("#").setOutputCount(2).addMaterial('#', EndBlocks.NEEDLEGRASS).build();
|
||||
GridRecipe.make("shadow_berry_seeds", EndBlocks.SHADOW_BERRY).setList("#").setOutputCount(4).addMaterial('#', EndItems.SHADOW_BERRY_RAW).build();
|
||||
GridRecipe.make("purple_polypore_dye", Items.PURPLE_DYE).setList("#").addMaterial('#', EndBlocks.PURPLE_POLYPORE).build();
|
||||
.addMaterial('#', EndBlocks.AETERNIUM_BLOCK).setOutputCount(9).setList("#").build();
|
||||
|
||||
GridRecipe.make("blue_vine_seed_dye", Items.BLUE_DYE).setList("#").addMaterial('#', EndBlocks.BLUE_VINE_SEED)
|
||||
.build();
|
||||
GridRecipe.make("creeping_moss_dye", Items.CYAN_DYE).setList("#").addMaterial('#', EndBlocks.CREEPING_MOSS)
|
||||
.build();
|
||||
GridRecipe.make("umbrella_moss_dye", Items.YELLOW_DYE).setList("#").addMaterial('#', EndBlocks.UMBRELLA_MOSS)
|
||||
.build();
|
||||
GridRecipe.make("umbrella_moss_tall_dye", Items.YELLOW_DYE).setOutputCount(2).setList("#")
|
||||
.addMaterial('#', EndBlocks.UMBRELLA_MOSS_TALL).build();
|
||||
GridRecipe.make("shadow_plant_dye", Items.BLACK_DYE).setList("#").addMaterial('#', EndBlocks.SHADOW_PLANT)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("paper", Items.PAPER).setShape("###").addMaterial('#', EndItems.END_LILY_LEAF_DRIED)
|
||||
.setOutputCount(3).build();
|
||||
|
||||
GridRecipe.make("aurora_block", EndBlocks.AURORA_CRYSTAL).setShape("##", "##")
|
||||
.addMaterial('#', EndItems.CRYSTAL_SHARDS).build();
|
||||
GridRecipe.make("lotus_block", EndBlocks.END_LOTUS.log).setShape("##", "##")
|
||||
.addMaterial('#', EndBlocks.END_LOTUS_STEM).build();
|
||||
GridRecipe.make("needlegrass_stick", Items.STICK).setList("#").setOutputCount(2)
|
||||
.addMaterial('#', EndBlocks.NEEDLEGRASS).build();
|
||||
GridRecipe.make("shadow_berry_seeds", EndBlocks.SHADOW_BERRY).setList("#").setOutputCount(4)
|
||||
.addMaterial('#', EndItems.SHADOW_BERRY_RAW).build();
|
||||
GridRecipe.make("purple_polypore_dye", Items.PURPLE_DYE).setList("#")
|
||||
.addMaterial('#', EndBlocks.PURPLE_POLYPORE).build();
|
||||
|
||||
registerLantern("end_stone_lantern", EndBlocks.END_STONE_LANTERN, Blocks.END_STONE_BRICK_SLAB);
|
||||
registerLantern("andesite_lantern", EndBlocks.ANDESITE_LANTERN, Blocks.ANDESITE_SLAB);
|
||||
|
@ -88,136 +83,130 @@ public class CraftingRecipes {
|
|||
registerLantern("quartz_lantern", EndBlocks.QUARTZ_LANTERN, Blocks.QUARTZ_SLAB);
|
||||
registerLantern("purpur_lantern", EndBlocks.PURPUR_LANTERN, Blocks.PURPUR_SLAB);
|
||||
registerLantern("blackstone_lantern", EndBlocks.BLACKSTONE_LANTERN, Blocks.BLACKSTONE_SLAB);
|
||||
|
||||
GridRecipe.make("amber_gem", EndItems.AMBER_GEM).setShape("##", "##").addMaterial('#', EndItems.RAW_AMBER).build();
|
||||
GridRecipe.make("amber_block", EndBlocks.AMBER_BLOCK).setShape("##", "##").addMaterial('#', EndItems.AMBER_GEM).build();
|
||||
GridRecipe.make("amber_gem_block", EndItems.AMBER_GEM).setOutputCount(4).setList("#").addMaterial('#', EndBlocks.AMBER_BLOCK).build();
|
||||
GridRecipe.make("iron_bulb_lantern", EndBlocks.IRON_BULB_LANTERN).setShape("C", "I", "#").addMaterial('C', Items.CHAIN).addMaterial('I', Items.IRON_INGOT).addMaterial('#', EndItems.GLOWING_BULB).build();
|
||||
GridRecipe.make("twisted_moss_dye", Items.PINK_DYE).setList("#").addMaterial('#', EndBlocks.TWISTED_MOSS).build();
|
||||
GridRecipe.make("byshy_grass_dye", Items.MAGENTA_DYE).setList("#").addMaterial('#', EndBlocks.BUSHY_GRASS).build();
|
||||
|
||||
GridRecipe.make("amber_gem", EndItems.AMBER_GEM).setShape("##", "##").addMaterial('#', EndItems.RAW_AMBER)
|
||||
.build();
|
||||
GridRecipe.make("amber_block", EndBlocks.AMBER_BLOCK).setShape("##", "##").addMaterial('#', EndItems.AMBER_GEM)
|
||||
.build();
|
||||
GridRecipe.make("amber_gem_block", EndItems.AMBER_GEM).setOutputCount(4).setList("#")
|
||||
.addMaterial('#', EndBlocks.AMBER_BLOCK).build();
|
||||
GridRecipe.make("iron_bulb_lantern", EndBlocks.IRON_BULB_LANTERN).setShape("C", "I", "#")
|
||||
.addMaterial('C', Items.CHAIN).addMaterial('I', Items.IRON_INGOT)
|
||||
.addMaterial('#', EndItems.GLOWING_BULB).build();
|
||||
GridRecipe.make("twisted_moss_dye", Items.PINK_DYE).setList("#").addMaterial('#', EndBlocks.TWISTED_MOSS)
|
||||
.build();
|
||||
GridRecipe.make("byshy_grass_dye", Items.MAGENTA_DYE).setList("#").addMaterial('#', EndBlocks.BUSHY_GRASS)
|
||||
.build();
|
||||
GridRecipe.make("tail_moss_dye", Items.GRAY_DYE).setList("#").addMaterial('#', EndBlocks.TAIL_MOSS).build();
|
||||
GridRecipe.make("petal_block", EndBlocks.HYDRALUX_PETAL_BLOCK).setShape("##", "##").addMaterial('#', EndItems.HYDRALUX_PETAL).build();
|
||||
GridRecipe.make("petal_white_dye", Items.WHITE_DYE).setList("#").addMaterial('#', EndItems.HYDRALUX_PETAL).build();
|
||||
|
||||
GridRecipe.make("sweet_berry_jelly", EndItems.SWEET_BERRY_JELLY)
|
||||
.setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtil.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR).addMaterial('B', Items.SWEET_BERRIES)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("shadow_berry_jelly", EndItems.SHADOW_BERRY_JELLY)
|
||||
.setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtil.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR)
|
||||
.addMaterial('B', EndItems.SHADOW_BERRY_COOKED)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("sulphur_gunpowder", Items.GUNPOWDER).setList("SCB").addMaterial('S', EndItems.CRYSTALLINE_SULPHUR).addMaterial('C', Items.COAL, Items.CHARCOAL).addMaterial('B', Items.BONE_MEAL).build();
|
||||
|
||||
GridRecipe.make("dense_emerald_ice", EndBlocks.DENSE_EMERALD_ICE).setShape("##", "##").addMaterial('#', EndBlocks.EMERALD_ICE).build();
|
||||
GridRecipe.make("ancient_emerald_ice", EndBlocks.ANCIENT_EMERALD_ICE).setShape("###", "###", "###").addMaterial('#', EndBlocks.DENSE_EMERALD_ICE).build();
|
||||
|
||||
GridRecipe.make("charnia_cyan_dye", Items.CYAN_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_CYAN).build();
|
||||
GridRecipe.make("charnia_green_dye", Items.GREEN_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_GREEN).build();
|
||||
GridRecipe.make("charnia_light_blue_dye", Items.LIGHT_BLUE_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_LIGHT_BLUE).build();
|
||||
GridRecipe.make("charnia_orange_dye", Items.ORANGE_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_ORANGE).build();
|
||||
GridRecipe.make("charnia_purple_dye", Items.PURPLE_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_PURPLE).build();
|
||||
GridRecipe.make("petal_block", EndBlocks.HYDRALUX_PETAL_BLOCK).setShape("##", "##")
|
||||
.addMaterial('#', EndItems.HYDRALUX_PETAL).build();
|
||||
GridRecipe.make("petal_white_dye", Items.WHITE_DYE).setList("#").addMaterial('#', EndItems.HYDRALUX_PETAL)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("sweet_berry_jelly", EndItems.SWEET_BERRY_JELLY).setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtil.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR).addMaterial('B', Items.SWEET_BERRIES).build();
|
||||
|
||||
GridRecipe.make("shadow_berry_jelly", EndItems.SHADOW_BERRY_JELLY).setList("JWSB")
|
||||
.addMaterial('J', EndItems.GELATINE)
|
||||
.addMaterial('W', PotionUtil.setPotion(new ItemStack(Items.POTION), Potions.WATER))
|
||||
.addMaterial('S', Items.SUGAR).addMaterial('B', EndItems.SHADOW_BERRY_COOKED).build();
|
||||
|
||||
GridRecipe.make("sulphur_gunpowder", Items.GUNPOWDER).setList("SCB")
|
||||
.addMaterial('S', EndItems.CRYSTALLINE_SULPHUR).addMaterial('C', Items.COAL, Items.CHARCOAL)
|
||||
.addMaterial('B', Items.BONE_MEAL).build();
|
||||
|
||||
GridRecipe.make("dense_emerald_ice", EndBlocks.DENSE_EMERALD_ICE).setShape("##", "##")
|
||||
.addMaterial('#', EndBlocks.EMERALD_ICE).build();
|
||||
GridRecipe.make("ancient_emerald_ice", EndBlocks.ANCIENT_EMERALD_ICE).setShape("###", "###", "###")
|
||||
.addMaterial('#', EndBlocks.DENSE_EMERALD_ICE).build();
|
||||
|
||||
GridRecipe.make("charnia_cyan_dye", Items.CYAN_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_CYAN)
|
||||
.build();
|
||||
GridRecipe.make("charnia_green_dye", Items.GREEN_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_GREEN)
|
||||
.build();
|
||||
GridRecipe.make("charnia_light_blue_dye", Items.LIGHT_BLUE_DYE).setList("#")
|
||||
.addMaterial('#', EndBlocks.CHARNIA_LIGHT_BLUE).build();
|
||||
GridRecipe.make("charnia_orange_dye", Items.ORANGE_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_ORANGE)
|
||||
.build();
|
||||
GridRecipe.make("charnia_purple_dye", Items.PURPLE_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_PURPLE)
|
||||
.build();
|
||||
GridRecipe.make("charnia_red_dye", Items.RED_DYE).setList("#").addMaterial('#', EndBlocks.CHARNIA_RED).build();
|
||||
|
||||
GridRecipe.make("respawn_obelisk", EndBlocks.RESPAWN_OBELISK)
|
||||
.setShape("CSC", "CSC", "AAA")
|
||||
.addMaterial('C', EndBlocks.AURORA_CRYSTAL)
|
||||
.addMaterial('S', EndItems.ETERNAL_CRYSTAL)
|
||||
.addMaterial('A', EndBlocks.AMBER_BLOCK)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("hopper", Blocks.HOPPER)
|
||||
.setShape("I I", "ICI", " I ")
|
||||
.addMaterial('I', Items.IRON_INGOT)
|
||||
.addMaterial('C', EndTags.ITEM_CHEST)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("shulker_box", Blocks.SHULKER_BOX)
|
||||
.setShape("S", "C", "S")
|
||||
.addMaterial('S', Items.SHULKER_SHELL)
|
||||
.addMaterial('C', EndTags.ITEM_CHEST)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("twisted_umbrella_moss_dye", Items.PURPLE_DYE).setList("#").addMaterial('#', EndBlocks.TWISTED_UMBRELLA_MOSS).build();
|
||||
GridRecipe.make("twisted_umbrella_moss_dye_tall", Items.PURPLE_DYE).setOutputCount(2).setList("#").addMaterial('#', EndBlocks.TWISTED_UMBRELLA_MOSS_TALL).build();
|
||||
|
||||
GridRecipe.make("leather_to_stripes", EndItems.LEATHER_STRIPE)
|
||||
.setList("L")
|
||||
.addMaterial('L', Items.LEATHER)
|
||||
.setOutputCount(3)
|
||||
.build();
|
||||
GridRecipe.make("stripes_to_leather", Items.LEATHER)
|
||||
.setList("SSS")
|
||||
.addMaterial('S', EndItems.LEATHER_STRIPE)
|
||||
.build();
|
||||
GridRecipe.make("leather_wrapped_stick", EndItems.LEATHER_WRAPPED_STICK)
|
||||
.setList("SL")
|
||||
.addMaterial('S', Items.STICK)
|
||||
.addMaterial('L', EndItems.LEATHER_STRIPE)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("fiber_string", Items.STRING).setOutputCount(6).setShape("#", "#", "#").addMaterial('#', EndItems.SILK_FIBER).build();
|
||||
|
||||
GridRecipe.make("ender_eye_amber", Items.ENDER_EYE)
|
||||
.setShape("SAS", "APA", "SAS")
|
||||
.addMaterial('S', EndItems.CRYSTAL_SHARDS)
|
||||
.addMaterial('A', EndItems.AMBER_GEM)
|
||||
.addMaterial('P', Items.ENDER_PEARL)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("iron_chandelier", EndBlocks.IRON_CHANDELIER).setShape("I#I", " # ").addMaterial('#', Items.IRON_INGOT).addMaterial('I', EndItems.LUMECORN_ROD).setGroup("end_metal_chandelier").build();
|
||||
GridRecipe.make("gold_chandelier", EndBlocks.GOLD_CHANDELIER).setShape("I#I", " # ").addMaterial('#', Items.GOLD_INGOT).addMaterial('I', EndItems.LUMECORN_ROD).setGroup("end_metal_chandelier").build();
|
||||
|
||||
GridRecipe.make("missing_tile", EndBlocks.MISSING_TILE)
|
||||
.setOutputCount(4)
|
||||
.setShape("#P", "P#")
|
||||
.addMaterial('#', EndBlocks.VIOLECITE.stone, EndBlocks.VIOLECITE.bricks, EndBlocks.VIOLECITE.tiles)
|
||||
.addMaterial('P', Blocks.PURPUR_BLOCK)
|
||||
.build();
|
||||
|
||||
GridRecipe.make("respawn_obelisk", EndBlocks.RESPAWN_OBELISK).setShape("CSC", "CSC", "AAA")
|
||||
.addMaterial('C', EndBlocks.AURORA_CRYSTAL).addMaterial('S', EndItems.ETERNAL_CRYSTAL)
|
||||
.addMaterial('A', EndBlocks.AMBER_BLOCK).build();
|
||||
|
||||
GridRecipe.make("hopper", Blocks.HOPPER).setShape("I I", "ICI", " I ").addMaterial('I', Items.IRON_INGOT)
|
||||
.addMaterial('C', EndTags.ITEM_CHEST).build();
|
||||
|
||||
GridRecipe.make("shulker_box", Blocks.SHULKER_BOX).setShape("S", "C", "S").addMaterial('S', Items.SHULKER_SHELL)
|
||||
.addMaterial('C', EndTags.ITEM_CHEST).build();
|
||||
|
||||
GridRecipe.make("twisted_umbrella_moss_dye", Items.PURPLE_DYE).setList("#")
|
||||
.addMaterial('#', EndBlocks.TWISTED_UMBRELLA_MOSS).build();
|
||||
GridRecipe.make("twisted_umbrella_moss_dye_tall", Items.PURPLE_DYE).setOutputCount(2).setList("#")
|
||||
.addMaterial('#', EndBlocks.TWISTED_UMBRELLA_MOSS_TALL).build();
|
||||
|
||||
GridRecipe.make("leather_to_stripes", EndItems.LEATHER_STRIPE).setList("L").addMaterial('L', Items.LEATHER)
|
||||
.setOutputCount(3).build();
|
||||
GridRecipe.make("stripes_to_leather", Items.LEATHER).setList("SSS").addMaterial('S', EndItems.LEATHER_STRIPE)
|
||||
.build();
|
||||
GridRecipe.make("leather_wrapped_stick", EndItems.LEATHER_WRAPPED_STICK).setList("SL")
|
||||
.addMaterial('S', Items.STICK).addMaterial('L', EndItems.LEATHER_STRIPE).build();
|
||||
|
||||
GridRecipe.make("fiber_string", Items.STRING).setOutputCount(6).setShape("#", "#", "#")
|
||||
.addMaterial('#', EndItems.SILK_FIBER).build();
|
||||
|
||||
GridRecipe.make("ender_eye_amber", Items.ENDER_EYE).setShape("SAS", "APA", "SAS")
|
||||
.addMaterial('S', EndItems.CRYSTAL_SHARDS).addMaterial('A', EndItems.AMBER_GEM)
|
||||
.addMaterial('P', Items.ENDER_PEARL).build();
|
||||
|
||||
GridRecipe.make("iron_chandelier", EndBlocks.IRON_CHANDELIER).setShape("I#I", " # ")
|
||||
.addMaterial('#', Items.IRON_INGOT).addMaterial('I', EndItems.LUMECORN_ROD)
|
||||
.setGroup("end_metal_chandelier").build();
|
||||
GridRecipe.make("gold_chandelier", EndBlocks.GOLD_CHANDELIER).setShape("I#I", " # ")
|
||||
.addMaterial('#', Items.GOLD_INGOT).addMaterial('I', EndItems.LUMECORN_ROD)
|
||||
.setGroup("end_metal_chandelier").build();
|
||||
|
||||
GridRecipe.make("missing_tile", EndBlocks.MISSING_TILE).setOutputCount(4).setShape("#P", "P#")
|
||||
.addMaterial('#', EndBlocks.VIOLECITE.stone, EndBlocks.VIOLECITE.bricks, EndBlocks.VIOLECITE.tiles)
|
||||
.addMaterial('P', Blocks.PURPUR_BLOCK).build();
|
||||
|
||||
registerHammer("iron", Items.IRON_INGOT, EndItems.IRON_HAMMER);
|
||||
registerHammer("golden", Items.GOLD_INGOT, EndItems.GOLDEN_HAMMER);
|
||||
registerHammer("diamond", Items.DIAMOND, EndItems.DIAMOND_HAMMER);
|
||||
|
||||
GridRecipe.make("charcoal_block", EndBlocks.CHARCOAL_BLOCK).setShape("###", "###", "###").addMaterial('#', Items.CHARCOAL).build();
|
||||
GridRecipe.make("end_stone_furnace", EndBlocks.END_STONE_FURNACE).setShape("###", "# #", "###").addMaterial('#', Blocks.END_STONE).build();
|
||||
GridRecipe.make("filalux_lantern", EndBlocks.FILALUX_LANTERN).setShape("###", "###", "###").addMaterial('#', EndBlocks.FILALUX).build();
|
||||
|
||||
GridRecipe.make("silk_moth_hive", EndBlocks.SILK_MOTH_HIVE).setShape("#L#", "LML", "#L#").addMaterial('#', EndBlocks.TENANEA.planks).addMaterial('L', EndBlocks.TENANEA_LEAVES).addMaterial('M', EndItems.SILK_MOTH_MATRIX).build();
|
||||
GridRecipe.make("cave_pumpkin_pie", EndItems.CAVE_PUMPKIN_PIE).setShape(" B ", "BPB", " B ").addMaterial('P', EndBlocks.CAVE_PUMPKIN).addMaterial('B', EndItems.BLOSSOM_BERRY, EndItems.SHADOW_BERRY_RAW).build();
|
||||
GridRecipe.make("cave_pumpkin_seeds", EndBlocks.CAVE_PUMPKIN_SEED).setOutputCount(4).setList("#").addMaterial('#', EndBlocks.CAVE_PUMPKIN).build();
|
||||
GridRecipe.make("charcoal_block", EndBlocks.CHARCOAL_BLOCK).setShape("###", "###", "###")
|
||||
.addMaterial('#', Items.CHARCOAL).build();
|
||||
GridRecipe.make("end_stone_furnace", EndBlocks.END_STONE_FURNACE).setShape("###", "# #", "###")
|
||||
.addMaterial('#', Blocks.END_STONE).build();
|
||||
GridRecipe.make("filalux_lantern", EndBlocks.FILALUX_LANTERN).setShape("###", "###", "###")
|
||||
.addMaterial('#', EndBlocks.FILALUX).build();
|
||||
|
||||
GridRecipe.make("silk_moth_hive", EndBlocks.SILK_MOTH_HIVE).setShape("#L#", "LML", "#L#")
|
||||
.addMaterial('#', EndBlocks.TENANEA.planks).addMaterial('L', EndBlocks.TENANEA_LEAVES)
|
||||
.addMaterial('M', EndItems.SILK_MOTH_MATRIX).build();
|
||||
GridRecipe.make("cave_pumpkin_pie", EndItems.CAVE_PUMPKIN_PIE).setShape(" B ", "BPB", " B ")
|
||||
.addMaterial('P', EndBlocks.CAVE_PUMPKIN)
|
||||
.addMaterial('B', EndItems.BLOSSOM_BERRY, EndItems.SHADOW_BERRY_RAW).build();
|
||||
GridRecipe.make("cave_pumpkin_seeds", EndBlocks.CAVE_PUMPKIN_SEED).setOutputCount(4).setList("#")
|
||||
.addMaterial('#', EndBlocks.CAVE_PUMPKIN).build();
|
||||
}
|
||||
|
||||
|
||||
private static void registerLantern(String name, Block lantern, Block slab) {
|
||||
GridRecipe.make(name, lantern)
|
||||
.setShape("S", "#", "S")
|
||||
.addMaterial('#', EndItems.CRYSTAL_SHARDS)
|
||||
.addMaterial('S', slab)
|
||||
.setGroup("end_stone_lanterns")
|
||||
.build();
|
||||
GridRecipe.make(name, lantern).setShape("S", "#", "S").addMaterial('#', EndItems.CRYSTAL_SHARDS)
|
||||
.addMaterial('S', slab).setGroup("end_stone_lanterns").build();
|
||||
}
|
||||
|
||||
|
||||
public static void registerPedestal(String name, Block pedestal, Block slab, Block pillar) {
|
||||
GridRecipe.make(name, pedestal)
|
||||
.setShape("S", "#", "S")
|
||||
.addMaterial('S', slab)
|
||||
.addMaterial('#', pillar)
|
||||
.setOutputCount(2)
|
||||
.build();
|
||||
GridRecipe.make(name, pedestal).setShape("S", "#", "S").addMaterial('S', slab).addMaterial('#', pillar)
|
||||
.setOutputCount(2).build();
|
||||
}
|
||||
|
||||
private static void registerHammer(String name, Item material, Item result) {
|
||||
GridRecipe.make(name + "_hammer", result)
|
||||
.setShape("I I", "I#I", " # ")
|
||||
.addMaterial('I', material)
|
||||
.addMaterial('#', Items.STICK)
|
||||
.build();
|
||||
GridRecipe.make(name + "_hammer", result).setShape("I I", "I#I", " # ").addMaterial('I', material)
|
||||
.addMaterial('#', Items.STICK).build();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,52 +5,53 @@ import java.util.Map.Entry;
|
|||
|
||||
import com.google.common.collect.Maps;
|
||||
|
||||
import net.minecraft.recipe.Recipe;
|
||||
import net.minecraft.recipe.RecipeSerializer;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.util.registry.Registry;
|
||||
import net.minecraft.world.item.crafting.Recipe;
|
||||
import net.minecraft.world.item.crafting.RecipeSerializer;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.core.Registry;
|
||||
import ru.betterend.BetterEnd;
|
||||
|
||||
public class EndRecipeManager {
|
||||
private static final Map<RecipeType<?>, Map<Identifier, Recipe<?>>> RECIPES = Maps.newHashMap();
|
||||
private static final Map<RecipeType<?>, Map<ResourceLocation, Recipe<?>>> RECIPES = Maps.newHashMap();
|
||||
|
||||
public static void addRecipe(RecipeType<?> type, Recipe<?> recipe) {
|
||||
Map<Identifier, Recipe<?>> list = RECIPES.get(type);
|
||||
Map<ResourceLocation, Recipe<?>> list = RECIPES.get(type);
|
||||
if (list == null) {
|
||||
list = Maps.newHashMap();
|
||||
RECIPES.put(type, list);
|
||||
}
|
||||
list.put(recipe.getId(), recipe);
|
||||
}
|
||||
|
||||
|
||||
@SuppressWarnings("unchecked")
|
||||
public static <T extends Recipe<?>> T getRecipe(RecipeType<T> type, Identifier id) {
|
||||
public static <T extends Recipe<?>> T getRecipe(RecipeType<T> type, ResourceLocation id) {
|
||||
if (RECIPES.containsKey(type)) {
|
||||
return (T) RECIPES.get(type).get(id);
|
||||
}
|
||||
return null;
|
||||
}
|
||||
|
||||
public static Map<RecipeType<?>, Map<Identifier, Recipe<?>>> getMap(Map<RecipeType<?>, Map<Identifier, Recipe<?>>> recipes) {
|
||||
Map<RecipeType<?>, Map<Identifier, Recipe<?>>> result = Maps.newHashMap();
|
||||
public static Map<RecipeType<?>, Map<ResourceLocation, Recipe<?>>> getMap(
|
||||
Map<RecipeType<?>, Map<ResourceLocation, Recipe<?>>> recipes) {
|
||||
Map<RecipeType<?>, Map<ResourceLocation, Recipe<?>>> result = Maps.newHashMap();
|
||||
|
||||
for (RecipeType<?> type : recipes.keySet()) {
|
||||
Map<Identifier, Recipe<?>> typeList = Maps.newHashMap();
|
||||
Map<ResourceLocation, Recipe<?>> typeList = Maps.newHashMap();
|
||||
typeList.putAll(recipes.get(type));
|
||||
result.put(type, typeList);
|
||||
}
|
||||
|
||||
for (RecipeType<?> type : RECIPES.keySet()) {
|
||||
Map<Identifier, Recipe<?>> list = RECIPES.get(type);
|
||||
Map<ResourceLocation, Recipe<?>> list = RECIPES.get(type);
|
||||
if (list != null) {
|
||||
Map<Identifier, Recipe<?>> typeList = result.get(type);
|
||||
Map<ResourceLocation, Recipe<?>> typeList = result.get(type);
|
||||
if (typeList == null) {
|
||||
typeList = Maps.newHashMap();
|
||||
result.put(type, typeList);
|
||||
}
|
||||
for (Entry<Identifier, Recipe<?>> entry : list.entrySet()) {
|
||||
Identifier id = entry.getKey();
|
||||
for (Entry<ResourceLocation, Recipe<?>> entry : list.entrySet()) {
|
||||
ResourceLocation id = entry.getKey();
|
||||
if (!typeList.containsKey(id))
|
||||
typeList.put(id, entry.getValue());
|
||||
}
|
||||
|
@ -65,11 +66,11 @@ public class EndRecipeManager {
|
|||
}
|
||||
|
||||
public static <T extends Recipe<?>> RecipeType<T> registerType(String type) {
|
||||
Identifier recipeTypeId = BetterEnd.makeID(type);
|
||||
ResourceLocation recipeTypeId = BetterEnd.makeID(type);
|
||||
return Registry.register(Registry.RECIPE_TYPE, recipeTypeId, new RecipeType<T>() {
|
||||
public String toString() {
|
||||
return type;
|
||||
}
|
||||
});
|
||||
});
|
||||
}
|
||||
}
|
|
@ -1,7 +1,7 @@
|
|||
package ru.betterend.recipe;
|
||||
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
import net.minecraft.world.item.Items;
|
||||
import ru.betterend.recipe.builders.FurnaceRecipe;
|
||||
import ru.betterend.registry.EndBlocks;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
@ -14,7 +14,8 @@ public class FurnaceRecipes {
|
|||
FurnaceRecipe.make("end_fish", EndItems.END_FISH_RAW, EndItems.END_FISH_COOKED).buildFoodlike();
|
||||
FurnaceRecipe.make("slime_ball", EndBlocks.JELLYSHROOM_CAP_PURPLE, Items.SLIME_BALL).build();
|
||||
FurnaceRecipe.make("menger_sponge", EndBlocks.MENGER_SPONGE_WET, EndBlocks.MENGER_SPONGE).build();
|
||||
FurnaceRecipe.make("chorus_mushroom", EndItems.CHORUS_MUSHROOM_RAW, EndItems.CHORUS_MUSHROOM_COOKED).buildFoodlike();
|
||||
FurnaceRecipe.make("chorus_mushroom", EndItems.CHORUS_MUSHROOM_RAW, EndItems.CHORUS_MUSHROOM_COOKED)
|
||||
.buildFoodlike();
|
||||
FurnaceRecipe.make("bolux_mushroom", EndBlocks.BOLUX_MUSHROOM, EndItems.BOLUX_MUSHROOM_COOKED).buildFoodlike();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -1,588 +1,265 @@
|
|||
package ru.betterend.recipe;
|
||||
|
||||
import net.minecraft.block.Blocks;
|
||||
import net.minecraft.enchantment.Enchantment;
|
||||
import net.minecraft.enchantment.EnchantmentLevelEntry;
|
||||
import net.minecraft.enchantment.Enchantments;
|
||||
import net.minecraft.item.EnchantedBookItem;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.world.level.block.Blocks;
|
||||
import net.minecraft.world.item.enchantment.Enchantment;
|
||||
import net.minecraft.world.item.enchantment.EnchantmentLevelEntry;
|
||||
import net.minecraft.world.item.enchantment.Enchantments;
|
||||
import net.minecraft.world.item.EnchantedBookItem;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.Items;
|
||||
import ru.betterend.recipe.builders.InfusionRecipe;
|
||||
import ru.betterend.registry.EndBlocks;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
||||
public class InfusionRecipes {
|
||||
public static void register() {
|
||||
InfusionRecipe.Builder.create("runed_flavolite")
|
||||
.setInput(EndBlocks.FLAVOLITE.polished)
|
||||
.setOutput(EndBlocks.FLAVOLITE_RUNED)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(100)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("eternal_crystal")
|
||||
.setInput(Items.END_CRYSTAL)
|
||||
.setOutput(EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(1, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(3, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(5, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(7, EndItems.ENDER_SHARD)
|
||||
.setTime(250)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("crystalite_helmet")
|
||||
.setInput(EndBlocks.TERMINITE.helmet)
|
||||
.setOutput(EndItems.CRYSTALITE_HELMET)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(150)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("crystalite_chestplate")
|
||||
.setInput(EndBlocks.TERMINITE.chestplate)
|
||||
.setOutput(EndItems.CRYSTALITE_CHESTPLATE)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(3, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(5, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(7, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("crystalite_leggings")
|
||||
.setInput(EndBlocks.TERMINITE.leggings)
|
||||
.setOutput(EndItems.CRYSTALITE_LEGGINGS)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(225)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("crystalite_boots")
|
||||
.setInput(EndBlocks.TERMINITE.boots)
|
||||
.setOutput(EndItems.CRYSTALITE_BOOTS)
|
||||
.addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(150)
|
||||
.build();
|
||||
|
||||
InfusionRecipe.Builder.create("enchanted_petal")
|
||||
.setInput(EndItems.HYDRALUX_PETAL)
|
||||
.setOutput(EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.setTime(75)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("runed_flavolite").setInput(EndBlocks.FLAVOLITE.polished)
|
||||
.setOutput(EndBlocks.FLAVOLITE_RUNED).addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS).addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS).setTime(100).build();
|
||||
|
||||
InfusionRecipe.Builder.create("protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, Items.TURTLE_HELMET)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("fire_protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FIRE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_ROD)
|
||||
.addCatalyst(4, Items.BLAZE_ROD)
|
||||
.addCatalyst(6, Items.BLAZE_ROD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("feather_falling_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FEATHER_FALLING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.FEATHER)
|
||||
.addCatalyst(4, Items.FEATHER)
|
||||
.addCatalyst(6, Items.FEATHER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("blast_protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BLAST_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.OBSIDIAN)
|
||||
.addCatalyst(4, Blocks.OBSIDIAN)
|
||||
.addCatalyst(6, Blocks.OBSIDIAN)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("projectile_protection_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PROJECTILE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.SCUTE)
|
||||
.addCatalyst(4, Items.SHIELD)
|
||||
.addCatalyst(6, Items.SCUTE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("respiration_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.RESPIRATION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(4, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(6, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("aqua_affinity_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.AQUA_AFFINITY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(4, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(6, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("thorns_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.THORNS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.CACTUS)
|
||||
.addCatalyst(4, Blocks.CACTUS)
|
||||
.addCatalyst(6, Blocks.CACTUS)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("depth_strider_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.DEPTH_STRIDER, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.LILY_PAD)
|
||||
.addCatalyst(4, EndBlocks.END_LILY_SEED)
|
||||
.addCatalyst(6, Blocks.LILY_PAD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("frost_walker_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FROST_WALKER, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, EndBlocks.ANCIENT_EMERALD_ICE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("soul_speed_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SOUL_SPEED, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(4, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(6, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("sharpness_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SHARPNESS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, Items.NETHERITE_SCRAP)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("smite_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SMITE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.SUNFLOWER)
|
||||
.addCatalyst(4, Items.GOLD_INGOT)
|
||||
.addCatalyst(6, Blocks.SUNFLOWER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("bane_of_arthropods_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BANE_OF_ARTHROPODS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.FERMENTED_SPIDER_EYE)
|
||||
.addCatalyst(4, Items.IRON_INGOT)
|
||||
.addCatalyst(6, Items.FERMENTED_SPIDER_EYE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("knockback_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.KNOCKBACK, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.REDSTONE)
|
||||
.addCatalyst(4, Blocks.PISTON)
|
||||
.addCatalyst(6, Items.REDSTONE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("fire_aspect_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FIRE_ASPECT, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_POWDER)
|
||||
.addCatalyst(4, Items.MAGMA_CREAM)
|
||||
.addCatalyst(6, Items.BLAZE_POWDER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("looting_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LOOTING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.GOLD_INGOT)
|
||||
.addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("sweeping_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SWEEPING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GOLDEN_SWORD)
|
||||
.addCatalyst(4, Items.IRON_SWORD)
|
||||
.addCatalyst(6, Items.GOLDEN_SWORD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("efficiency_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.EFFICIENCY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, EndItems.AMBER_GEM)
|
||||
.addCatalyst(4, EndItems.AMBER_GEM)
|
||||
.addCatalyst(6, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("silk_touch_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SILK_TOUCH, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.COBWEB)
|
||||
.addCatalyst(4, EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(6, Blocks.COBWEB)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("unbreaking_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.UNBREAKING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.DIAMOND)
|
||||
.addCatalyst(4, Items.DIAMOND)
|
||||
.addCatalyst(6, Items.DIAMOND)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("fortune_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FORTUNE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.RABBIT_FOOT)
|
||||
.addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("power_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.POWER, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, EndItems.AMBER_GEM)
|
||||
.addCatalyst(4, Items.DIAMOND_SWORD)
|
||||
.addCatalyst(6, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("punch_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PUNCH, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.POPPED_CHORUS_FRUIT)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.POPPED_CHORUS_FRUIT)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("flame_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FLAME, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_POWDER)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.BLAZE_POWDER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("infinity_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.INFINITY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(4, EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(6, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("luck_of_sea_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LUCK_OF_THE_SEA, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.FISHING_ROD)
|
||||
.addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("lure_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LURE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GOLD_NUGGET)
|
||||
.addCatalyst(4, Items.FISHING_ROD)
|
||||
.addCatalyst(6, Items.GOLD_NUGGET)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("loyalty_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LOYALTY, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.ENDER_EYE)
|
||||
.addCatalyst(4, Items.HEART_OF_THE_SEA)
|
||||
.addCatalyst(6, Items.ENDER_EYE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("impaling_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.IMPALING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.PRISMARINE_SHARD)
|
||||
.addCatalyst(4, Items.IRON_SWORD)
|
||||
.addCatalyst(6, Items.PRISMARINE_SHARD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("riptide_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.RIPTIDE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.LEAD)
|
||||
.addCatalyst(4, Items.HEART_OF_THE_SEA)
|
||||
.addCatalyst(6, Items.LEAD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("channeling_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.CHANNELING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.CHAIN)
|
||||
.addCatalyst(4, Items.HEART_OF_THE_SEA)
|
||||
.addCatalyst(6, Items.CHAIN)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("multishot_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MULTISHOT, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.ARROW)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.ARROW)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("quick_charge_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.QUICK_CHARGE, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.QUARTZ)
|
||||
.addCatalyst(4, Items.GLOWSTONE_DUST)
|
||||
.addCatalyst(6, Items.QUARTZ)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("piercing_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PIERCING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GLOWSTONE_DUST)
|
||||
.addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.GLOWSTONE_DUST)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(300)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("mending_book")
|
||||
.setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MENDING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EXPERIENCE_BOTTLE)
|
||||
.addCatalyst(4, Blocks.ANVIL)
|
||||
.addCatalyst(6, Items.EXPERIENCE_BOTTLE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI)
|
||||
.setGroup("enchantment")
|
||||
.setTime(375)
|
||||
.build();
|
||||
InfusionRecipe.Builder.create("eternal_crystal").setInput(Items.END_CRYSTAL).setOutput(EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(0, EndItems.CRYSTAL_SHARDS).addCatalyst(2, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(4, EndItems.CRYSTAL_SHARDS).addCatalyst(6, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(1, EndItems.ENDER_SHARD).addCatalyst(3, EndItems.ENDER_SHARD)
|
||||
.addCatalyst(5, EndItems.ENDER_SHARD).addCatalyst(7, EndItems.ENDER_SHARD).setTime(250).build();
|
||||
|
||||
InfusionRecipe.Builder.create("crystalite_helmet").setInput(EndBlocks.TERMINITE.helmet)
|
||||
.setOutput(EndItems.CRYSTALITE_HELMET).addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS).addCatalyst(6, EndItems.CRYSTAL_SHARDS).setTime(150).build();
|
||||
InfusionRecipe.Builder.create("crystalite_chestplate").setInput(EndBlocks.TERMINITE.chestplate)
|
||||
.setOutput(EndItems.CRYSTALITE_CHESTPLATE).addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(1, EndItems.CRYSTAL_SHARDS).addCatalyst(3, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(5, EndItems.CRYSTAL_SHARDS).addCatalyst(7, EndItems.CRYSTAL_SHARDS).setTime(300).build();
|
||||
InfusionRecipe.Builder.create("crystalite_leggings").setInput(EndBlocks.TERMINITE.leggings)
|
||||
.setOutput(EndItems.CRYSTALITE_LEGGINGS).addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS).addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS).setTime(225).build();
|
||||
InfusionRecipe.Builder.create("crystalite_boots").setInput(EndBlocks.TERMINITE.boots)
|
||||
.setOutput(EndItems.CRYSTALITE_BOOTS).addCatalyst(0, EndItems.AMBER_GEM)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS).addCatalyst(6, EndItems.CRYSTAL_SHARDS).setTime(150).build();
|
||||
|
||||
InfusionRecipe.Builder.create("enchanted_petal").setInput(EndItems.HYDRALUX_PETAL)
|
||||
.setOutput(EndItems.ENCHANTED_PETAL).addCatalyst(0, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(2, EndItems.CRYSTAL_SHARDS).addCatalyst(4, EndItems.CRYSTAL_SHARDS)
|
||||
.addCatalyst(6, EndItems.CRYSTAL_SHARDS).setTime(75).build();
|
||||
|
||||
InfusionRecipe.Builder.create("protection_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PROTECTION, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, Items.TURTLE_HELMET).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("fire_protection_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FIRE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL).addCatalyst(2, Items.BLAZE_ROD)
|
||||
.addCatalyst(4, Items.BLAZE_ROD).addCatalyst(6, Items.BLAZE_ROD).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("feather_falling_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FEATHER_FALLING, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL).addCatalyst(2, Items.FEATHER).addCatalyst(4, Items.FEATHER)
|
||||
.addCatalyst(6, Items.FEATHER).addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("blast_protection_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BLAST_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL).addCatalyst(2, Blocks.OBSIDIAN)
|
||||
.addCatalyst(4, Blocks.OBSIDIAN).addCatalyst(6, Blocks.OBSIDIAN).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("projectile_protection_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PROJECTILE_PROTECTION, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL).addCatalyst(2, Items.SCUTE).addCatalyst(4, Items.SHIELD)
|
||||
.addCatalyst(6, Items.SCUTE).addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("respiration_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.RESPIRATION, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.NAUTILUS_SHELL).addCatalyst(4, Items.NAUTILUS_SHELL)
|
||||
.addCatalyst(6, Items.NAUTILUS_SHELL).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("aqua_affinity_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.AQUA_AFFINITY, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.PRISMARINE_CRYSTALS).addCatalyst(4, Items.PRISMARINE_CRYSTALS)
|
||||
.addCatalyst(6, Items.PRISMARINE_CRYSTALS).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("thorns_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.THORNS, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.CACTUS).addCatalyst(4, Blocks.CACTUS).addCatalyst(6, Blocks.CACTUS)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("depth_strider_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.DEPTH_STRIDER, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.LILY_PAD).addCatalyst(4, EndBlocks.END_LILY_SEED).addCatalyst(6, Blocks.LILY_PAD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("frost_walker_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FROST_WALKER, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, EndBlocks.ANCIENT_EMERALD_ICE).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("soul_speed_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SOUL_SPEED, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.SOUL_SAND, Blocks.SOUL_SOIL).addCatalyst(4, Blocks.SOUL_SAND, Blocks.SOUL_SOIL)
|
||||
.addCatalyst(6, Blocks.SOUL_SAND, Blocks.SOUL_SOIL).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("sharpness_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SHARPNESS, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(4, Items.NETHERITE_SCRAP).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("smite_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SMITE, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.SUNFLOWER).addCatalyst(4, Items.GOLD_INGOT).addCatalyst(6, Blocks.SUNFLOWER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("bane_of_arthropods_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BANE_OF_ARTHROPODS, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL).addCatalyst(2, Items.FERMENTED_SPIDER_EYE)
|
||||
.addCatalyst(4, Items.IRON_INGOT).addCatalyst(6, Items.FERMENTED_SPIDER_EYE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("knockback_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.KNOCKBACK, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.REDSTONE).addCatalyst(4, Blocks.PISTON).addCatalyst(6, Items.REDSTONE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("fire_aspect_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FIRE_ASPECT, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_POWDER).addCatalyst(4, Items.MAGMA_CREAM).addCatalyst(6, Items.BLAZE_POWDER)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("looting_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LOOTING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD).addCatalyst(4, Items.GOLD_INGOT).addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("sweeping_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SWEEPING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GOLDEN_SWORD).addCatalyst(4, Items.IRON_SWORD).addCatalyst(6, Items.GOLDEN_SWORD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("efficiency_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.EFFICIENCY, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, EndItems.AMBER_GEM).addCatalyst(4, EndItems.AMBER_GEM)
|
||||
.addCatalyst(6, EndItems.AMBER_GEM).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("silk_touch_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.SILK_TOUCH, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Blocks.COBWEB).addCatalyst(4, EndItems.ETERNAL_CRYSTAL).addCatalyst(6, Blocks.COBWEB)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(375).build();
|
||||
InfusionRecipe.Builder.create("unbreaking_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.UNBREAKING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.DIAMOND).addCatalyst(4, Items.DIAMOND).addCatalyst(6, Items.DIAMOND)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("fortune_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.BLOCK_FORTUNE, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EMERALD).addCatalyst(4, Items.RABBIT_FOOT).addCatalyst(6, Items.EMERALD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("power_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.POWER, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, EndItems.AMBER_GEM).addCatalyst(4, Items.DIAMOND_SWORD)
|
||||
.addCatalyst(6, EndItems.AMBER_GEM).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("punch_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PUNCH, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.POPPED_CHORUS_FRUIT).addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.POPPED_CHORUS_FRUIT).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("flame_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.FLAME, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.BLAZE_POWDER).addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.BLAZE_POWDER).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("infinity_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.INFINITY, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.SPECTRAL_ARROW).addCatalyst(4, EndItems.ETERNAL_CRYSTAL)
|
||||
.addCatalyst(6, Items.SPECTRAL_ARROW).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(375).build();
|
||||
InfusionRecipe.Builder.create("luck_of_sea_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LUCK_OF_THE_SEA, 1))
|
||||
.addCatalyst(0, EndItems.ENCHANTED_PETAL).addCatalyst(2, Items.EMERALD)
|
||||
.addCatalyst(4, Items.FISHING_ROD).addCatalyst(6, Items.EMERALD).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("lure_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LURE, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GOLD_NUGGET).addCatalyst(4, Items.FISHING_ROD).addCatalyst(6, Items.GOLD_NUGGET)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("loyalty_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.LOYALTY, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.ENDER_EYE).addCatalyst(4, Items.HEART_OF_THE_SEA).addCatalyst(6, Items.ENDER_EYE)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(375).build();
|
||||
InfusionRecipe.Builder.create("impaling_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.IMPALING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.PRISMARINE_SHARD).addCatalyst(4, Items.IRON_SWORD)
|
||||
.addCatalyst(6, Items.PRISMARINE_SHARD).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("riptide_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.RIPTIDE, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.LEAD).addCatalyst(4, Items.HEART_OF_THE_SEA).addCatalyst(6, Items.LEAD)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(375).build();
|
||||
InfusionRecipe.Builder.create("channeling_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.CHANNELING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.CHAIN).addCatalyst(4, Items.HEART_OF_THE_SEA).addCatalyst(6, Items.CHAIN)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(375).build();
|
||||
InfusionRecipe.Builder.create("multishot_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MULTISHOT, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.ARROW).addCatalyst(4, Items.SPECTRAL_ARROW).addCatalyst(6, Items.ARROW)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("quick_charge_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.QUICK_CHARGE, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.QUARTZ).addCatalyst(4, Items.GLOWSTONE_DUST).addCatalyst(6, Items.QUARTZ)
|
||||
.addCatalyst(1, Items.LAPIS_LAZULI).addCatalyst(3, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(5, Items.LAPIS_LAZULI).addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment")
|
||||
.setTime(300).build();
|
||||
InfusionRecipe.Builder.create("piercing_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.PIERCING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.GLOWSTONE_DUST).addCatalyst(4, Items.SPECTRAL_ARROW)
|
||||
.addCatalyst(6, Items.GLOWSTONE_DUST).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(300).build();
|
||||
InfusionRecipe.Builder.create("mending_book").setInput(Items.BOOK)
|
||||
.setOutput(createEnchantedBook(Enchantments.MENDING, 1)).addCatalyst(0, EndItems.ENCHANTED_PETAL)
|
||||
.addCatalyst(2, Items.EXPERIENCE_BOTTLE).addCatalyst(4, Blocks.ANVIL)
|
||||
.addCatalyst(6, Items.EXPERIENCE_BOTTLE).addCatalyst(1, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(3, Items.LAPIS_LAZULI).addCatalyst(5, Items.LAPIS_LAZULI)
|
||||
.addCatalyst(7, Items.LAPIS_LAZULI).setGroup("enchantment").setTime(375).build();
|
||||
}
|
||||
|
||||
|
||||
private static ItemStack createEnchantedBook(Enchantment enchantment, int level) {
|
||||
ItemStack book = new ItemStack(Items.ENCHANTED_BOOK);
|
||||
EnchantedBookItem.addEnchantment(book, new EnchantmentLevelEntry(enchantment, level));
|
||||
|
|
|
@ -1,87 +1,45 @@
|
|||
package ru.betterend.recipe;
|
||||
|
||||
import net.minecraft.item.Items;
|
||||
import net.minecraft.world.item.Items;
|
||||
import ru.betterend.recipe.builders.SmithingTableRecipe;
|
||||
import ru.betterend.registry.EndBlocks;
|
||||
import ru.betterend.registry.EndItems;
|
||||
|
||||
public class SmithingRecipes {
|
||||
|
||||
public static void register() {
|
||||
SmithingTableRecipe.create("aeternium_sword_handle")
|
||||
.setResult(EndItems.AETERNIUM_SWORD_HANDLE)
|
||||
.setBase(EndBlocks.TERMINITE.ingot)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create("aeternium_sword")
|
||||
.setResult(EndItems.AETERNIUM_SWORD)
|
||||
.setBase(EndItems.AETERNIUM_SWORD_BLADE)
|
||||
.setAddition(EndItems.AETERNIUM_SWORD_HANDLE)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_pickaxe")
|
||||
.setResult(EndItems.AETERNIUM_PICKAXE)
|
||||
.setBase(EndItems.AETERNIUM_PICKAXE_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_axe")
|
||||
.setResult(EndItems.AETERNIUM_AXE)
|
||||
.setBase(EndItems.AETERNIUM_AXE_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_shovel")
|
||||
.setResult(EndItems.AETERNIUM_SHOVEL)
|
||||
.setBase(EndItems.AETERNIUM_SHOVEL_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_hoe")
|
||||
.setResult(EndItems.AETERNIUM_HOE)
|
||||
.setBase(EndItems.AETERNIUM_HOE_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_hammer")
|
||||
.setResult(EndItems.AETERNIUM_HAMMER)
|
||||
.setBase(EndItems.AETERNIUM_HAMMER_HEAD)
|
||||
.setAddition(EndItems.LEATHER_WRAPPED_STICK)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create("netherite_hammer")
|
||||
.setResult(EndItems.NETHERITE_HAMMER)
|
||||
.setBase(EndItems.DIAMOND_HAMMER)
|
||||
.setAddition(Items.NETHERITE_INGOT)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create("aeternium_helmet")
|
||||
.setResult(EndItems.AETERNIUM_HELMET)
|
||||
.setBase(EndBlocks.TERMINITE.helmet)
|
||||
.setAddition(EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_chestplate")
|
||||
.setResult(EndItems.AETERNIUM_CHESTPLATE)
|
||||
.setBase(EndBlocks.TERMINITE.chestplate)
|
||||
.setAddition(EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_leggings")
|
||||
.setResult(EndItems.AETERNIUM_LEGGINGS)
|
||||
.setBase(EndBlocks.TERMINITE.leggings)
|
||||
.setAddition(EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
SmithingTableRecipe.create("aeternium_boots")
|
||||
.setResult(EndItems.AETERNIUM_BOOTS)
|
||||
.setBase(EndBlocks.TERMINITE.boots)
|
||||
.setAddition(EndItems.AETERNIUM_INGOT)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create("thallasium_anvil_updrade")
|
||||
.setResult(EndBlocks.TERMINITE.anvil)
|
||||
.setBase(EndBlocks.THALLASIUM.anvil)
|
||||
.setAddition(EndBlocks.TERMINITE.block)
|
||||
.build();
|
||||
|
||||
SmithingTableRecipe.create("terminite_anvil_updrade")
|
||||
.setResult(EndBlocks.AETERNIUM_ANVIL)
|
||||
.setBase(EndBlocks.TERMINITE.anvil)
|
||||
.setAddition(EndBlocks.AETERNIUM_BLOCK)
|
||||
.build();
|
||||
public static void register() {
|
||||
SmithingTableRecipe.create("aeternium_sword_handle").setResult(EndItems.AETERNIUM_SWORD_HANDLE)
|
||||
.setBase(EndBlocks.TERMINITE.ingot).setAddition(EndItems.LEATHER_WRAPPED_STICK).build();
|
||||
|
||||
SmithingTableRecipe.create("aeternium_sword").setResult(EndItems.AETERNIUM_SWORD)
|
||||
.setBase(EndItems.AETERNIUM_SWORD_BLADE).setAddition(EndItems.AETERNIUM_SWORD_HANDLE).build();
|
||||
SmithingTableRecipe.create("aeternium_pickaxe").setResult(EndItems.AETERNIUM_PICKAXE)
|
||||
.setBase(EndItems.AETERNIUM_PICKAXE_HEAD).setAddition(EndItems.LEATHER_WRAPPED_STICK).build();
|
||||
SmithingTableRecipe.create("aeternium_axe").setResult(EndItems.AETERNIUM_AXE)
|
||||
.setBase(EndItems.AETERNIUM_AXE_HEAD).setAddition(EndItems.LEATHER_WRAPPED_STICK).build();
|
||||
SmithingTableRecipe.create("aeternium_shovel").setResult(EndItems.AETERNIUM_SHOVEL)
|
||||
.setBase(EndItems.AETERNIUM_SHOVEL_HEAD).setAddition(EndItems.LEATHER_WRAPPED_STICK).build();
|
||||
SmithingTableRecipe.create("aeternium_hoe").setResult(EndItems.AETERNIUM_HOE)
|
||||
.setBase(EndItems.AETERNIUM_HOE_HEAD).setAddition(EndItems.LEATHER_WRAPPED_STICK).build();
|
||||
SmithingTableRecipe.create("aeternium_hammer").setResult(EndItems.AETERNIUM_HAMMER)
|
||||
.setBase(EndItems.AETERNIUM_HAMMER_HEAD).setAddition(EndItems.LEATHER_WRAPPED_STICK).build();
|
||||
|
||||
SmithingTableRecipe.create("netherite_hammer").setResult(EndItems.NETHERITE_HAMMER)
|
||||
.setBase(EndItems.DIAMOND_HAMMER).setAddition(Items.NETHERITE_INGOT).build();
|
||||
|
||||
SmithingTableRecipe.create("aeternium_helmet").setResult(EndItems.AETERNIUM_HELMET)
|
||||
.setBase(EndBlocks.TERMINITE.helmet).setAddition(EndItems.AETERNIUM_INGOT).build();
|
||||
SmithingTableRecipe.create("aeternium_chestplate").setResult(EndItems.AETERNIUM_CHESTPLATE)
|
||||
.setBase(EndBlocks.TERMINITE.chestplate).setAddition(EndItems.AETERNIUM_INGOT).build();
|
||||
SmithingTableRecipe.create("aeternium_leggings").setResult(EndItems.AETERNIUM_LEGGINGS)
|
||||
.setBase(EndBlocks.TERMINITE.leggings).setAddition(EndItems.AETERNIUM_INGOT).build();
|
||||
SmithingTableRecipe.create("aeternium_boots").setResult(EndItems.AETERNIUM_BOOTS)
|
||||
.setBase(EndBlocks.TERMINITE.boots).setAddition(EndItems.AETERNIUM_INGOT).build();
|
||||
|
||||
SmithingTableRecipe.create("thallasium_anvil_updrade").setResult(EndBlocks.TERMINITE.anvil)
|
||||
.setBase(EndBlocks.THALLASIUM.anvil).setAddition(EndBlocks.TERMINITE.block).build();
|
||||
|
||||
SmithingTableRecipe.create("terminite_anvil_updrade").setResult(EndBlocks.AETERNIUM_ANVIL)
|
||||
.setBase(EndBlocks.TERMINITE.anvil).setAddition(EndBlocks.AETERNIUM_BLOCK).build();
|
||||
}
|
||||
}
|
||||
|
|
|
@ -6,19 +6,19 @@ import com.google.gson.JsonObject;
|
|||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
import net.minecraft.inventory.Inventory;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemConvertible;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.recipe.Ingredient;
|
||||
import net.minecraft.recipe.Recipe;
|
||||
import net.minecraft.recipe.RecipeSerializer;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.tag.Tag;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.Recipe;
|
||||
import net.minecraft.world.item.crafting.RecipeSerializer;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.tags.Tag;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.util.JsonHelper;
|
||||
import net.minecraft.util.collection.DefaultedList;
|
||||
import net.minecraft.world.World;
|
||||
import net.minecraft.world.level.Level;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
import ru.betterend.interfaces.BetterEndRecipe;
|
||||
|
@ -28,22 +28,23 @@ import ru.betterend.util.ItemUtil;
|
|||
import ru.betterend.util.RecipeHelper;
|
||||
|
||||
public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
||||
|
||||
|
||||
public final static String GROUP = "alloying";
|
||||
public final static RecipeType<AlloyingRecipe> TYPE = EndRecipeManager.registerType(GROUP);
|
||||
public final static Serializer SERIALIZER = EndRecipeManager.registerSerializer(GROUP, new Serializer());
|
||||
public final static Identifier ID = BetterEnd.makeID(GROUP);
|
||||
|
||||
public final static ResourceLocation ID = BetterEnd.makeID(GROUP);
|
||||
|
||||
protected final RecipeType<?> type;
|
||||
protected final Identifier id;
|
||||
protected final ResourceLocation id;
|
||||
protected final Ingredient primaryInput;
|
||||
protected final Ingredient secondaryInput;
|
||||
protected final ItemStack output;
|
||||
protected final String group;
|
||||
protected final float experience;
|
||||
protected final int smeltTime;
|
||||
|
||||
public AlloyingRecipe(Identifier id, String group, Ingredient primaryInput, Ingredient secondaryInput, ItemStack output, float experience, int smeltTime) {
|
||||
|
||||
public AlloyingRecipe(ResourceLocation id, String group, Ingredient primaryInput, Ingredient secondaryInput,
|
||||
ItemStack output, float experience, int smeltTime) {
|
||||
this.group = group;
|
||||
this.id = id;
|
||||
this.primaryInput = primaryInput;
|
||||
|
@ -53,11 +54,11 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
this.smeltTime = smeltTime;
|
||||
this.type = TYPE;
|
||||
}
|
||||
|
||||
|
||||
public float getExperience() {
|
||||
return this.experience;
|
||||
}
|
||||
|
||||
|
||||
public int getSmeltTime() {
|
||||
return this.smeltTime;
|
||||
}
|
||||
|
@ -67,14 +68,14 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
DefaultedList<Ingredient> defaultedList = DefaultedList.of();
|
||||
defaultedList.add(primaryInput);
|
||||
defaultedList.add(secondaryInput);
|
||||
|
||||
|
||||
return defaultedList;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean matches(Inventory inv, World world) {
|
||||
return this.primaryInput.test(inv.getStack(0)) && this.secondaryInput.test(inv.getStack(1)) ||
|
||||
this.primaryInput.test(inv.getStack(1)) && this.secondaryInput.test(inv.getStack(0));
|
||||
public boolean matches(Inventory inv, Level world) {
|
||||
return this.primaryInput.test(inv.getStack(0)) && this.secondaryInput.test(inv.getStack(1))
|
||||
|| this.primaryInput.test(inv.getStack(1)) && this.secondaryInput.test(inv.getStack(0));
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -93,7 +94,7 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
}
|
||||
|
||||
@Override
|
||||
public Identifier getId() {
|
||||
public ResourceLocation getId() {
|
||||
return this.id;
|
||||
}
|
||||
|
||||
|
@ -106,23 +107,23 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
public RecipeType<?> getType() {
|
||||
return this.type;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
@Environment(EnvType.CLIENT)
|
||||
public String getGroup() {
|
||||
return this.group;
|
||||
}
|
||||
|
||||
|
||||
@Environment(EnvType.CLIENT)
|
||||
public ItemStack getRecipeKindIcon() {
|
||||
return new ItemStack(EndBlocks.END_STONE_SMELTER);
|
||||
}
|
||||
|
||||
|
||||
public static class Builder {
|
||||
private final static Builder INSTANCE = new Builder();
|
||||
private static boolean exist;
|
||||
|
||||
public static Builder create(Identifier id) {
|
||||
|
||||
public static Builder create(ResourceLocation id) {
|
||||
INSTANCE.id = id;
|
||||
INSTANCE.group = String.format("%s_%s", GROUP, id);
|
||||
INSTANCE.primaryInput = null;
|
||||
|
@ -131,15 +132,15 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
INSTANCE.experience = 0.0F;
|
||||
INSTANCE.smeltTime = 350;
|
||||
exist = Configs.RECIPE_CONFIG.getBoolean("alloying", id.getPath(), true);
|
||||
|
||||
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
|
||||
public static Builder create(String id) {
|
||||
return create(BetterEnd.makeID(id));
|
||||
}
|
||||
|
||||
private Identifier id;
|
||||
|
||||
private ResourceLocation id;
|
||||
private Ingredient primaryInput;
|
||||
private Ingredient secondaryInput;
|
||||
private ItemStack output;
|
||||
|
@ -147,79 +148,82 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
private float experience;
|
||||
private int smeltTime;
|
||||
private boolean alright = true;
|
||||
|
||||
private Builder() {}
|
||||
|
||||
|
||||
private Builder() {
|
||||
}
|
||||
|
||||
public Builder setGroup(String group) {
|
||||
this.group = group;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setPrimaryInput(ItemConvertible... inputs) {
|
||||
for (ItemConvertible item : inputs) {
|
||||
this.alright &= RecipeHelper.exists(item);
|
||||
}
|
||||
this.primaryInput = Ingredient.ofItems(inputs);
|
||||
this.primaryInput = Ingredient.of(inputs);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setSecondaryInput(ItemConvertible... inputs) {
|
||||
for (ItemConvertible item : inputs) {
|
||||
this.alright &= RecipeHelper.exists(item);
|
||||
}
|
||||
this.secondaryInput = Ingredient.ofItems(inputs);
|
||||
this.secondaryInput = Ingredient.of(inputs);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setPrimaryInput(Tag<Item> input) {
|
||||
this.primaryInput = Ingredient.fromTag(input);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setSecondaryInput(Tag<Item> input) {
|
||||
this.secondaryInput = Ingredient.fromTag(input);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setInput(ItemConvertible primaryInput, ItemConvertible secondaryInput) {
|
||||
this.setPrimaryInput(primaryInput);
|
||||
this.setSecondaryInput(secondaryInput);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setInput(Tag<Item> primaryInput, Tag<Item> secondaryInput) {
|
||||
this.setPrimaryInput(primaryInput);
|
||||
this.setSecondaryInput(secondaryInput);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setOutput(ItemConvertible output, int amount) {
|
||||
this.alright &= RecipeHelper.exists(output);
|
||||
this.output = new ItemStack(output, amount);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setExpiriense(float amount) {
|
||||
this.experience = amount;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setSmeltTime(int time) {
|
||||
this.smeltTime = time;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public void build() {
|
||||
if (exist) {
|
||||
if (primaryInput == null) {
|
||||
BetterEnd.LOGGER.warning("Primary input for Alloying recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
BetterEnd.LOGGER.warning(
|
||||
"Primary input for Alloying recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
if(secondaryInput == null) {
|
||||
BetterEnd.LOGGER.warning("Secondary input for Alloying can't be 'null', recipe {} will be ignored!", id);
|
||||
if (secondaryInput == null) {
|
||||
BetterEnd.LOGGER.warning("Secondary input for Alloying can't be 'null', recipe {} will be ignored!",
|
||||
id);
|
||||
return;
|
||||
}
|
||||
if(output == null) {
|
||||
if (output == null) {
|
||||
BetterEnd.LOGGER.warning("Output for Alloying can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
|
@ -231,14 +235,15 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
BetterEnd.LOGGER.debug("Can't add Alloying recipe {}! Ingeredient or output not exists.", id);
|
||||
return;
|
||||
}
|
||||
EndRecipeManager.addRecipe(TYPE, new AlloyingRecipe(id, group, primaryInput, secondaryInput, output, experience, smeltTime));
|
||||
EndRecipeManager.addRecipe(TYPE,
|
||||
new AlloyingRecipe(id, group, primaryInput, secondaryInput, output, experience, smeltTime));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public static class Serializer implements RecipeSerializer<AlloyingRecipe> {
|
||||
@Override
|
||||
public AlloyingRecipe read(Identifier id, JsonObject json) {
|
||||
public AlloyingRecipe read(ResourceLocation id, JsonObject json) {
|
||||
JsonArray ingredients = JsonHelper.getArray(json, "ingredients");
|
||||
Ingredient primaryInput = Ingredient.fromJson(ingredients.get(0));
|
||||
Ingredient secondaryInput = Ingredient.fromJson(ingredients.get(1));
|
||||
|
@ -250,19 +255,19 @@ public class AlloyingRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
}
|
||||
float experience = JsonHelper.getFloat(json, "experience", 0.0F);
|
||||
int smeltTime = JsonHelper.getInt(json, "smelttime", 350);
|
||||
|
||||
|
||||
return new AlloyingRecipe(id, group, primaryInput, secondaryInput, output, experience, smeltTime);
|
||||
}
|
||||
|
||||
@Override
|
||||
public AlloyingRecipe read(Identifier id, PacketByteBuf packetBuffer) {
|
||||
public AlloyingRecipe read(ResourceLocation id, PacketByteBuf packetBuffer) {
|
||||
String group = packetBuffer.readString(32767);
|
||||
Ingredient primary = Ingredient.fromPacket(packetBuffer);
|
||||
Ingredient secondary = Ingredient.fromPacket(packetBuffer);
|
||||
ItemStack output = packetBuffer.readItemStack();
|
||||
float experience = packetBuffer.readFloat();
|
||||
int smeltTime = packetBuffer.readVarInt();
|
||||
|
||||
|
||||
return new AlloyingRecipe(id, group, primary, secondary, output, experience, smeltTime);
|
||||
}
|
||||
|
||||
|
|
|
@ -6,22 +6,22 @@ import com.google.gson.JsonObject;
|
|||
|
||||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
import net.minecraft.entity.player.PlayerEntity;
|
||||
import net.minecraft.world.entity.player.PlayerEntity;
|
||||
import net.minecraft.inventory.Inventory;
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.item.ToolItem;
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemConvertible;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.ToolItem;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.recipe.Ingredient;
|
||||
import net.minecraft.recipe.Recipe;
|
||||
import net.minecraft.recipe.RecipeSerializer;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.tag.Tag;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.Recipe;
|
||||
import net.minecraft.world.item.crafting.RecipeSerializer;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.tags.Tag;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.util.JsonHelper;
|
||||
import net.minecraft.util.collection.DefaultedList;
|
||||
import net.minecraft.world.World;
|
||||
import net.minecraft.world.level.Level;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
import ru.betterend.interfaces.BetterEndRecipe;
|
||||
|
@ -31,21 +31,22 @@ import ru.betterend.util.ItemUtil;
|
|||
import ru.betterend.util.RecipeHelper;
|
||||
|
||||
public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
||||
|
||||
|
||||
public final static String GROUP = "smithing";
|
||||
public final static RecipeType<AnvilRecipe> TYPE = EndRecipeManager.registerType(GROUP);
|
||||
public final static Serializer SERIALIZER = EndRecipeManager.registerSerializer(GROUP, new Serializer());
|
||||
public final static Identifier ID = BetterEnd.makeID(GROUP);
|
||||
|
||||
private final Identifier id;
|
||||
public final static ResourceLocation ID = BetterEnd.makeID(GROUP);
|
||||
|
||||
private final ResourceLocation id;
|
||||
private final Ingredient input;
|
||||
private final ItemStack output;
|
||||
private final int damage;
|
||||
private final int toolLevel;
|
||||
private final int anvilLevel;
|
||||
private final int inputCount;
|
||||
|
||||
public AnvilRecipe(Identifier identifier, Ingredient input, ItemStack output, int inputCount, int toolLevel, int anvilLevel, int damage) {
|
||||
|
||||
public AnvilRecipe(ResourceLocation identifier, Ingredient input, ItemStack output, int inputCount, int toolLevel,
|
||||
int anvilLevel, int damage) {
|
||||
this.id = identifier;
|
||||
this.input = input;
|
||||
this.output = output;
|
||||
|
@ -64,34 +65,35 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
public ItemStack getOutput() {
|
||||
return this.output;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean matches(Inventory craftingInventory, World world) {
|
||||
public boolean matches(Inventory craftingInventory, Level world) {
|
||||
return this.matches(craftingInventory);
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public ItemStack craft(Inventory craftingInventory) {
|
||||
return this.output.copy();
|
||||
}
|
||||
|
||||
|
||||
public ItemStack craft(Inventory craftingInventory, PlayerEntity player) {
|
||||
if (!player.isCreative()) {
|
||||
if (!checkHammerDurability(craftingInventory, player)) return ItemStack.EMPTY;
|
||||
if (!checkHammerDurability(craftingInventory, player))
|
||||
return ItemStack.EMPTY;
|
||||
ItemStack hammer = craftingInventory.getStack(1);
|
||||
hammer.damage(this.damage, player, entity ->
|
||||
entity.sendEquipmentBreakStatus(null));
|
||||
hammer.damage(this.damage, player, entity -> entity.sendEquipmentBreakStatus(null));
|
||||
}
|
||||
return this.craft(craftingInventory);
|
||||
}
|
||||
|
||||
public boolean checkHammerDurability(Inventory craftingInventory, PlayerEntity player) {
|
||||
if (player.isCreative()) return true;
|
||||
if (player.isCreative())
|
||||
return true;
|
||||
ItemStack hammer = craftingInventory.getStack(1);
|
||||
int damage = hammer.getDamage() + this.damage;
|
||||
return damage < hammer.getMaxDamage();
|
||||
}
|
||||
|
||||
|
||||
public boolean matches(Inventory craftingInventory) {
|
||||
ItemStack hammer = craftingInventory.getStack(1);
|
||||
if (hammer.isEmpty() || !EndTags.HAMMERS.contains(hammer.getItem())) {
|
||||
|
@ -99,12 +101,11 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
}
|
||||
ItemStack material = craftingInventory.getStack(0);
|
||||
int materialCount = material.getCount();
|
||||
int level = ((ToolItem) hammer.getItem()).getMaterial().getMiningLevel();
|
||||
return this.input.test(craftingInventory.getStack(0)) &&
|
||||
materialCount >= this.inputCount &&
|
||||
level >= this.toolLevel;
|
||||
int level = ((ToolItem) hammer.getItem()).getTier().getLevel();
|
||||
return this.input.test(craftingInventory.getStack(0)) && materialCount >= this.inputCount
|
||||
&& level >= this.toolLevel;
|
||||
}
|
||||
|
||||
|
||||
public int getDamage() {
|
||||
return this.damage;
|
||||
}
|
||||
|
@ -120,10 +121,10 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
@Override
|
||||
public DefaultedList<Ingredient> getPreviewInputs() {
|
||||
DefaultedList<Ingredient> defaultedList = DefaultedList.of();
|
||||
defaultedList.add(Ingredient.ofStacks(EndTags.HAMMERS.values().stream().filter(hammer ->
|
||||
((ToolItem) hammer).getMaterial().getMiningLevel() >= toolLevel).map(ItemStack::new)));
|
||||
defaultedList.add(Ingredient.ofStacks(EndTags.HAMMERS.values().stream()
|
||||
.filter(hammer -> ((ToolItem) hammer).getTier().getLevel() >= toolLevel).map(ItemStack::new)));
|
||||
defaultedList.add(input);
|
||||
|
||||
|
||||
return defaultedList;
|
||||
}
|
||||
|
||||
|
@ -134,7 +135,7 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
}
|
||||
|
||||
@Override
|
||||
public Identifier getId() {
|
||||
public ResourceLocation getId() {
|
||||
return this.id;
|
||||
}
|
||||
|
||||
|
@ -142,7 +143,7 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
public RecipeType<?> getType() {
|
||||
return TYPE;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public boolean isIgnoredInRecipeBook() {
|
||||
return true;
|
||||
|
@ -150,10 +151,13 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
|
||||
@Override
|
||||
public boolean equals(Object o) {
|
||||
if (this == o) return true;
|
||||
if (o == null || getClass() != o.getClass()) return false;
|
||||
if (this == o)
|
||||
return true;
|
||||
if (o == null || getClass() != o.getClass())
|
||||
return false;
|
||||
AnvilRecipe that = (AnvilRecipe) o;
|
||||
return damage == that.damage && toolLevel == that.toolLevel && id.equals(that.id) && input.equals(that.input) && output.equals(that.output);
|
||||
return damage == that.damage && toolLevel == that.toolLevel && id.equals(that.id) && input.equals(that.input)
|
||||
&& output.equals(that.output);
|
||||
}
|
||||
|
||||
@Override
|
||||
|
@ -168,12 +172,12 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
|
||||
public static class Builder {
|
||||
private final static Builder INSTANCE = new Builder();
|
||||
|
||||
|
||||
public static Builder create(String id) {
|
||||
return create(BetterEnd.makeID(id));
|
||||
}
|
||||
|
||||
public static Builder create(Identifier id) {
|
||||
|
||||
public static Builder create(ResourceLocation id) {
|
||||
INSTANCE.id = id;
|
||||
INSTANCE.input = null;
|
||||
INSTANCE.output = null;
|
||||
|
@ -182,11 +186,11 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
INSTANCE.anvilLevel = 1;
|
||||
INSTANCE.damage = 1;
|
||||
INSTANCE.alright = true;
|
||||
|
||||
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
private Identifier id;
|
||||
|
||||
private ResourceLocation id;
|
||||
private Ingredient input;
|
||||
private ItemStack output;
|
||||
private int inputCount = 1;
|
||||
|
@ -194,20 +198,21 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
private int anvilLevel = 1;
|
||||
private int damage = 1;
|
||||
private boolean alright;
|
||||
|
||||
private Builder() {}
|
||||
|
||||
|
||||
private Builder() {
|
||||
}
|
||||
|
||||
public Builder setInput(ItemConvertible... inputItems) {
|
||||
this.alright &= RecipeHelper.exists(inputItems);
|
||||
this.setInput(Ingredient.ofItems(inputItems));
|
||||
this.setInput(Ingredient.of(inputItems));
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setInput(Tag<Item> inputTag) {
|
||||
this.setInput(Ingredient.fromTag(inputTag));
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setInput(Ingredient ingredient) {
|
||||
this.input = ingredient;
|
||||
return this;
|
||||
|
@ -217,17 +222,17 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
this.inputCount = count;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setOutput(ItemConvertible output) {
|
||||
return this.setOutput(output, 1);
|
||||
}
|
||||
|
||||
|
||||
public Builder setOutput(ItemConvertible output, int amount) {
|
||||
this.alright &= RecipeHelper.exists(output);
|
||||
this.output = new ItemStack(output, amount);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setToolLevel(int level) {
|
||||
this.toolLevel = level;
|
||||
return this;
|
||||
|
@ -237,19 +242,19 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
this.anvilLevel = level;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setDamage(int damage) {
|
||||
this.damage = damage;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public void build() {
|
||||
if (Configs.RECIPE_CONFIG.getBoolean("anvil", id.getPath(), true)) {
|
||||
if (input == null) {
|
||||
BetterEnd.LOGGER.warning("Input for Anvil recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
if(output == null) {
|
||||
if (output == null) {
|
||||
BetterEnd.LOGGER.warning("Output for Anvil recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
|
@ -261,14 +266,15 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
BetterEnd.LOGGER.debug("Can't add Anvil recipe {}! Ingeredient or output not exists.", id);
|
||||
return;
|
||||
}
|
||||
EndRecipeManager.addRecipe(TYPE, new AnvilRecipe(id, input, output, inputCount, toolLevel, anvilLevel, damage));
|
||||
EndRecipeManager.addRecipe(TYPE,
|
||||
new AnvilRecipe(id, input, output, inputCount, toolLevel, anvilLevel, damage));
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public static class Serializer implements RecipeSerializer<AnvilRecipe> {
|
||||
@Override
|
||||
public AnvilRecipe read(Identifier id, JsonObject json) {
|
||||
public AnvilRecipe read(ResourceLocation id, JsonObject json) {
|
||||
Ingredient input = Ingredient.fromJson(json.get("input"));
|
||||
JsonObject result = JsonHelper.getObject(json, "result");
|
||||
ItemStack output = ItemUtil.fromJsonRecipe(result);
|
||||
|
@ -279,19 +285,19 @@ public class AnvilRecipe implements Recipe<Inventory>, BetterEndRecipe {
|
|||
int toolLevel = JsonHelper.getInt(json, "toolLevel", 1);
|
||||
int anvilLevel = JsonHelper.getInt(json, "anvilLevel", 1);
|
||||
int damage = JsonHelper.getInt(json, "damage", 1);
|
||||
|
||||
|
||||
return new AnvilRecipe(id, input, output, inputCount, toolLevel, anvilLevel, damage);
|
||||
}
|
||||
|
||||
@Override
|
||||
public AnvilRecipe read(Identifier id, PacketByteBuf packetBuffer) {
|
||||
public AnvilRecipe read(ResourceLocation id, PacketByteBuf packetBuffer) {
|
||||
Ingredient input = Ingredient.fromPacket(packetBuffer);
|
||||
ItemStack output = packetBuffer.readItemStack();
|
||||
int inputCount = packetBuffer.readVarInt();
|
||||
int toolLevel = packetBuffer.readVarInt();
|
||||
int anvilLevel = packetBuffer.readVarInt();
|
||||
int damage = packetBuffer.readVarInt();
|
||||
|
||||
|
||||
return new AnvilRecipe(id, input, output, inputCount, toolLevel, anvilLevel, damage);
|
||||
}
|
||||
|
||||
|
|
|
@ -1,14 +1,14 @@
|
|||
package ru.betterend.recipe.builders;
|
||||
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.recipe.BlastingRecipe;
|
||||
import net.minecraft.recipe.CampfireCookingRecipe;
|
||||
import net.minecraft.recipe.Ingredient;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.recipe.SmeltingRecipe;
|
||||
import net.minecraft.recipe.SmokingRecipe;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.world.item.ItemConvertible;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.crafting.BlastingRecipe;
|
||||
import net.minecraft.world.item.crafting.CampfireCookingRecipe;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.world.item.crafting.SmeltingRecipe;
|
||||
import net.minecraft.world.item.crafting.SmokingRecipe;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
import ru.betterend.recipe.EndRecipeManager;
|
||||
|
@ -16,7 +16,7 @@ import ru.betterend.util.RecipeHelper;
|
|||
|
||||
public class FurnaceRecipe {
|
||||
private static final FurnaceRecipe INSTANCE = new FurnaceRecipe();
|
||||
|
||||
|
||||
private ItemConvertible input;
|
||||
private ItemConvertible output;
|
||||
private boolean exist;
|
||||
|
@ -25,9 +25,10 @@ public class FurnaceRecipe {
|
|||
private int count;
|
||||
private int time;
|
||||
private float xp;
|
||||
|
||||
private FurnaceRecipe() {}
|
||||
|
||||
|
||||
private FurnaceRecipe() {
|
||||
}
|
||||
|
||||
public static FurnaceRecipe make(String name, ItemConvertible input, ItemConvertible output) {
|
||||
INSTANCE.name = name;
|
||||
INSTANCE.group = "";
|
||||
|
@ -36,64 +37,68 @@ public class FurnaceRecipe {
|
|||
INSTANCE.count = 1;
|
||||
INSTANCE.time = 200;
|
||||
INSTANCE.xp = 0;
|
||||
INSTANCE.exist = Configs.RECIPE_CONFIG.getBoolean("furnace", name, true) && RecipeHelper.exists(output) && RecipeHelper.exists(input);
|
||||
INSTANCE.exist = Configs.RECIPE_CONFIG.getBoolean("furnace", name, true) && RecipeHelper.exists(output)
|
||||
&& RecipeHelper.exists(input);
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
|
||||
public FurnaceRecipe setGroup(String group) {
|
||||
this.group = group;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public FurnaceRecipe setOutputCount(int count) {
|
||||
this.count = count;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public FurnaceRecipe setXP(float xp) {
|
||||
this.xp = xp;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public FurnaceRecipe setCookTime(int time) {
|
||||
this.time = time;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public void build() {
|
||||
build(false, false, false);
|
||||
}
|
||||
|
||||
|
||||
public void buildWithBlasting() {
|
||||
build(true, false, false);
|
||||
}
|
||||
|
||||
|
||||
public void buildFoodlike() {
|
||||
build(false, true, true);
|
||||
}
|
||||
|
||||
|
||||
public void build(boolean blasting, boolean campfire, boolean smoker) {
|
||||
if (exist) {
|
||||
Identifier id = BetterEnd.makeID(name);
|
||||
SmeltingRecipe recipe = new SmeltingRecipe(id, group, Ingredient.ofItems(input), new ItemStack(output, count), xp, time);
|
||||
ResourceLocation id = BetterEnd.makeID(name);
|
||||
SmeltingRecipe recipe = new SmeltingRecipe(id, group, Ingredient.of(input), new ItemStack(output, count),
|
||||
xp, time);
|
||||
EndRecipeManager.addRecipe(RecipeType.SMELTING, recipe);
|
||||
|
||||
|
||||
if (blasting) {
|
||||
BlastingRecipe recipe2 = new BlastingRecipe(id, group, Ingredient.ofItems(input), new ItemStack(output, count), xp, time / 2);
|
||||
BlastingRecipe recipe2 = new BlastingRecipe(id, group, Ingredient.of(input),
|
||||
new ItemStack(output, count), xp, time / 2);
|
||||
EndRecipeManager.addRecipe(RecipeType.BLASTING, recipe2);
|
||||
}
|
||||
|
||||
|
||||
if (campfire) {
|
||||
CampfireCookingRecipe recipe2 = new CampfireCookingRecipe(id, group, Ingredient.ofItems(input), new ItemStack(output, count), xp, time * 3);
|
||||
CampfireCookingRecipe recipe2 = new CampfireCookingRecipe(id, group, Ingredient.of(input),
|
||||
new ItemStack(output, count), xp, time * 3);
|
||||
EndRecipeManager.addRecipe(RecipeType.CAMPFIRE_COOKING, recipe2);
|
||||
}
|
||||
|
||||
|
||||
if (smoker) {
|
||||
SmokingRecipe recipe2 = new SmokingRecipe(id, group, Ingredient.ofItems(input), new ItemStack(output, count), xp, time / 2);
|
||||
SmokingRecipe recipe2 = new SmokingRecipe(id, group, Ingredient.of(input), new ItemStack(output, count),
|
||||
xp, time / 2);
|
||||
EndRecipeManager.addRecipe(RecipeType.SMOKING, recipe2);
|
||||
}
|
||||
}
|
||||
else {
|
||||
} else {
|
||||
BetterEnd.LOGGER.debug("Furnace recipe {} couldn't be added", name);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -5,16 +5,16 @@ import java.util.Map;
|
|||
|
||||
import com.google.common.collect.Maps;
|
||||
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.recipe.CraftingRecipe;
|
||||
import net.minecraft.recipe.Ingredient;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.recipe.ShapedRecipe;
|
||||
import net.minecraft.recipe.ShapelessRecipe;
|
||||
import net.minecraft.tag.Tag;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemConvertible;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.crafting.CraftingRecipe;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.world.item.crafting.ShapedRecipe;
|
||||
import net.minecraft.world.item.crafting.ShapelessRecipe;
|
||||
import net.minecraft.tags.Tag;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.util.collection.DefaultedList;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
|
@ -23,10 +23,10 @@ import ru.betterend.util.RecipeHelper;
|
|||
|
||||
public class GridRecipe {
|
||||
private static final GridRecipe INSTANCE = new GridRecipe();
|
||||
|
||||
|
||||
private String name;
|
||||
private ItemConvertible output;
|
||||
|
||||
|
||||
private String group;
|
||||
private RecipeType<?> type;
|
||||
private boolean shaped;
|
||||
|
@ -34,22 +34,23 @@ public class GridRecipe {
|
|||
private Map<Character, Ingredient> materialKeys = Maps.newHashMap();
|
||||
private int count;
|
||||
private boolean exist = true;
|
||||
|
||||
private GridRecipe() {}
|
||||
|
||||
|
||||
private GridRecipe() {
|
||||
}
|
||||
|
||||
public static GridRecipe make(String name, ItemConvertible output) {
|
||||
INSTANCE.name = name;
|
||||
INSTANCE.output = output;
|
||||
|
||||
|
||||
INSTANCE.group = "";
|
||||
INSTANCE.type = RecipeType.CRAFTING;
|
||||
INSTANCE.shaped = true;
|
||||
INSTANCE.shape = new String[] {"#"};
|
||||
INSTANCE.shape = new String[] { "#" };
|
||||
INSTANCE.materialKeys.clear();
|
||||
INSTANCE.count = 1;
|
||||
|
||||
|
||||
INSTANCE.exist = Configs.RECIPE_CONFIG.getBoolean("grid", name, true) && RecipeHelper.exists(output);
|
||||
|
||||
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
|
@ -57,65 +58,66 @@ public class GridRecipe {
|
|||
this.group = group;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public GridRecipe setShape(String... shape) {
|
||||
this.shape = shape;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public GridRecipe setList(String shape) {
|
||||
this.shape = new String[] { shape };
|
||||
this.shaped = false;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public GridRecipe addMaterial(char key, Tag<Item> value) {
|
||||
return addMaterial(key, Ingredient.fromTag(value));
|
||||
}
|
||||
|
||||
|
||||
public GridRecipe addMaterial(char key, ItemStack... value) {
|
||||
return addMaterial(key, Ingredient.ofStacks(Arrays.stream(value)));
|
||||
}
|
||||
|
||||
|
||||
public GridRecipe addMaterial(char key, ItemConvertible... values) {
|
||||
for (ItemConvertible item: values) {
|
||||
for (ItemConvertible item : values) {
|
||||
exist &= RecipeHelper.exists(item);
|
||||
}
|
||||
return addMaterial(key, Ingredient.ofItems(values));
|
||||
return addMaterial(key, Ingredient.of(values));
|
||||
}
|
||||
|
||||
|
||||
private GridRecipe addMaterial(char key, Ingredient value) {
|
||||
materialKeys.put(key, value);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public GridRecipe setOutputCount(int count) {
|
||||
this.count = count;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
private DefaultedList<Ingredient> getMaterials(int width, int height) {
|
||||
DefaultedList<Ingredient> materials = DefaultedList.ofSize(width * height, Ingredient.EMPTY);
|
||||
int pos = 0;
|
||||
for (String line: shape) {
|
||||
for (String line : shape) {
|
||||
for (int i = 0; i < width; i++) {
|
||||
char c = line.charAt(i);
|
||||
Ingredient material = materialKeys.get(c);
|
||||
materials.set(pos ++, material == null ? Ingredient.EMPTY : material);
|
||||
materials.set(pos++, material == null ? Ingredient.EMPTY : material);
|
||||
}
|
||||
}
|
||||
return materials;
|
||||
}
|
||||
|
||||
|
||||
public void build() {
|
||||
if (exist) {
|
||||
int height = shape.length;
|
||||
int width = shape[0].length();
|
||||
ItemStack result = new ItemStack(output, count);
|
||||
Identifier id = BetterEnd.makeID(name);
|
||||
ResourceLocation id = BetterEnd.makeID(name);
|
||||
DefaultedList<Ingredient> materials = this.getMaterials(width, height);
|
||||
|
||||
CraftingRecipe recipe = shaped ? new ShapedRecipe(id, group, width, height, materials, result) : new ShapelessRecipe(id, group, result, materials);
|
||||
|
||||
CraftingRecipe recipe = shaped ? new ShapedRecipe(id, group, width, height, materials, result)
|
||||
: new ShapelessRecipe(id, group, result, materials);
|
||||
EndRecipeManager.addRecipe(type, recipe);
|
||||
} else {
|
||||
BetterEnd.LOGGER.debug("Recipe {} couldn't be added", name);
|
||||
|
|
|
@ -6,17 +6,17 @@ import com.google.gson.JsonObject;
|
|||
|
||||
import net.fabricmc.api.EnvType;
|
||||
import net.fabricmc.api.Environment;
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.world.item.ItemConvertible;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.network.PacketByteBuf;
|
||||
import net.minecraft.recipe.Ingredient;
|
||||
import net.minecraft.recipe.Recipe;
|
||||
import net.minecraft.recipe.RecipeSerializer;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.Recipe;
|
||||
import net.minecraft.world.item.crafting.RecipeSerializer;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import net.minecraft.util.JsonHelper;
|
||||
import net.minecraft.util.collection.DefaultedList;
|
||||
import net.minecraft.world.World;
|
||||
import net.minecraft.world.level.Level;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
import ru.betterend.interfaces.BetterEndRecipe;
|
||||
|
@ -25,38 +25,39 @@ import ru.betterend.rituals.InfusionRitual;
|
|||
import ru.betterend.util.ItemUtil;
|
||||
|
||||
public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
||||
|
||||
|
||||
public final static String GROUP = "infusion";
|
||||
public final static RecipeType<InfusionRecipe> TYPE = EndRecipeManager.registerType(GROUP);
|
||||
public final static Serializer SERIALIZER = EndRecipeManager.registerSerializer(GROUP, new Serializer());
|
||||
public final static Identifier ID = BetterEnd.makeID(GROUP);
|
||||
|
||||
private final Identifier id;
|
||||
public final static ResourceLocation ID = BetterEnd.makeID(GROUP);
|
||||
|
||||
private final ResourceLocation id;
|
||||
private Ingredient input;
|
||||
private ItemStack output;
|
||||
private int time = 1;
|
||||
private Ingredient[] catalysts = new Ingredient[8];
|
||||
private String group;
|
||||
|
||||
private InfusionRecipe(Identifier id) {
|
||||
|
||||
private InfusionRecipe(ResourceLocation id) {
|
||||
this(id, null, null);
|
||||
}
|
||||
|
||||
private InfusionRecipe(Identifier id, Ingredient input, ItemStack output) {
|
||||
|
||||
private InfusionRecipe(ResourceLocation id, Ingredient input, ItemStack output) {
|
||||
this.id = id;
|
||||
this.input = input;
|
||||
this.output = output;
|
||||
Arrays.fill(catalysts, Ingredient.EMPTY);
|
||||
}
|
||||
|
||||
|
||||
public int getInfusionTime() {
|
||||
return this.time;
|
||||
}
|
||||
|
||||
@Override
|
||||
public boolean matches(InfusionRitual inv, World world) {
|
||||
public boolean matches(InfusionRitual inv, Level world) {
|
||||
boolean valid = this.input.test(inv.getStack(0));
|
||||
if (!valid) return false;
|
||||
if (!valid)
|
||||
return false;
|
||||
for (int i = 0; i < 8; i++) {
|
||||
valid &= this.catalysts[i].test(inv.getStack(i + 1));
|
||||
}
|
||||
|
@ -72,7 +73,7 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
public boolean fits(int width, int height) {
|
||||
return true;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
public DefaultedList<Ingredient> getPreviewInputs() {
|
||||
DefaultedList<Ingredient> defaultedList = DefaultedList.of();
|
||||
|
@ -89,10 +90,10 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
}
|
||||
|
||||
@Override
|
||||
public Identifier getId() {
|
||||
public ResourceLocation getId() {
|
||||
return this.id;
|
||||
}
|
||||
|
||||
|
||||
@Override
|
||||
@Environment(EnvType.CLIENT)
|
||||
public String getGroup() {
|
||||
|
@ -108,79 +109,82 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
public RecipeType<?> getType() {
|
||||
return TYPE;
|
||||
}
|
||||
|
||||
|
||||
public static class Builder {
|
||||
private final static Builder INSTANCE = new Builder();
|
||||
private static boolean exist;
|
||||
|
||||
|
||||
public static Builder create(String id) {
|
||||
return create(BetterEnd.makeID(id));
|
||||
}
|
||||
|
||||
public static Builder create(Identifier id) {
|
||||
|
||||
public static Builder create(ResourceLocation id) {
|
||||
INSTANCE.id = id;
|
||||
INSTANCE.input = null;
|
||||
INSTANCE.output = null;
|
||||
INSTANCE.time = 1;
|
||||
exist = Configs.RECIPE_CONFIG.getBoolean("infusion", id.getPath(), true);
|
||||
|
||||
|
||||
Arrays.fill(INSTANCE.catalysts, Ingredient.EMPTY);
|
||||
|
||||
|
||||
return INSTANCE;
|
||||
}
|
||||
|
||||
private Identifier id;
|
||||
|
||||
private ResourceLocation id;
|
||||
private Ingredient input;
|
||||
private ItemStack output;
|
||||
private String group;
|
||||
private int time = 1;
|
||||
private Ingredient[] catalysts = new Ingredient[8];
|
||||
|
||||
|
||||
private Builder() {
|
||||
Arrays.fill(catalysts, Ingredient.EMPTY);
|
||||
}
|
||||
|
||||
|
||||
public Builder setGroup(String group) {
|
||||
this.group = group;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setInput(ItemConvertible input) {
|
||||
this.input = Ingredient.ofItems(input);
|
||||
this.input = Ingredient.of(input);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setOutput(ItemConvertible output) {
|
||||
this.output = new ItemStack(output);
|
||||
this.output.setCount(1);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setOutput(ItemStack output) {
|
||||
this.output = output;
|
||||
this.output.setCount(1);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder setTime(int time) {
|
||||
this.time = time;
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public Builder addCatalyst(int slot, ItemConvertible... items) {
|
||||
if (slot > 7) return this;
|
||||
this.catalysts[slot] = Ingredient.ofItems(items);
|
||||
if (slot > 7)
|
||||
return this;
|
||||
this.catalysts[slot] = Ingredient.of(items);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public void build() {
|
||||
if (exist) {
|
||||
if (input == null) {
|
||||
BetterEnd.LOGGER.warning("Input for Infusion recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
BetterEnd.LOGGER.warning("Input for Infusion recipe can't be 'null', recipe {} will be ignored!",
|
||||
id);
|
||||
return;
|
||||
}
|
||||
if (output == null) {
|
||||
BetterEnd.LOGGER.warning("Output for Infusion recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
BetterEnd.LOGGER.warning("Output for Infusion recipe can't be 'null', recipe {} will be ignored!",
|
||||
id);
|
||||
return;
|
||||
}
|
||||
InfusionRecipe recipe = new InfusionRecipe(id, input, output);
|
||||
|
@ -188,8 +192,10 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
recipe.time = time;
|
||||
int empty = 0;
|
||||
for (int i = 0; i < catalysts.length; i++) {
|
||||
if (catalysts[i].isEmpty()) empty++;
|
||||
else recipe.catalysts[i] = catalysts[i];
|
||||
if (catalysts[i].isEmpty())
|
||||
empty++;
|
||||
else
|
||||
recipe.catalysts[i] = catalysts[i];
|
||||
}
|
||||
if (empty == catalysts.length) {
|
||||
BetterEnd.LOGGER.warning("At least one catalyst must be non empty, recipe {} will be ignored!", id);
|
||||
|
@ -199,10 +205,10 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
public static class Serializer implements RecipeSerializer<InfusionRecipe> {
|
||||
@Override
|
||||
public InfusionRecipe read(Identifier id, JsonObject json) {
|
||||
public InfusionRecipe read(ResourceLocation id, JsonObject json) {
|
||||
InfusionRecipe recipe = new InfusionRecipe(id);
|
||||
recipe.input = Ingredient.fromJson(json.get("input"));
|
||||
JsonObject result = JsonHelper.getObject(json, "result");
|
||||
|
@ -212,7 +218,7 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
}
|
||||
recipe.group = JsonHelper.getString(json, "group", GROUP);
|
||||
recipe.time = JsonHelper.getInt(json, "time", 1);
|
||||
|
||||
|
||||
JsonObject catalysts = JsonHelper.asObject(json, "catalysts");
|
||||
ItemStack catalyst = ItemUtil.fromStackString(JsonHelper.getString(catalysts, "north", ""));
|
||||
recipe.catalysts[0] = Ingredient.ofStacks(Arrays.stream(new ItemStack[] { catalyst }));
|
||||
|
@ -230,12 +236,12 @@ public class InfusionRecipe implements Recipe<InfusionRitual>, BetterEndRecipe {
|
|||
recipe.catalysts[6] = Ingredient.ofStacks(Arrays.stream(new ItemStack[] { catalyst }));
|
||||
catalyst = ItemUtil.fromStackString(JsonHelper.getString(catalysts, "north_west", ""));
|
||||
recipe.catalysts[7] = Ingredient.ofStacks(Arrays.stream(new ItemStack[] { catalyst }));
|
||||
|
||||
|
||||
return recipe;
|
||||
}
|
||||
|
||||
@Override
|
||||
public InfusionRecipe read(Identifier id, PacketByteBuf buffer) {
|
||||
public InfusionRecipe read(ResourceLocation id, PacketByteBuf buffer) {
|
||||
InfusionRecipe recipe = new InfusionRecipe(id);
|
||||
recipe.input = Ingredient.fromPacket(buffer);
|
||||
recipe.output = buffer.readItemStack();
|
||||
|
|
|
@ -1,88 +1,91 @@
|
|||
package ru.betterend.recipe.builders;
|
||||
|
||||
import net.minecraft.item.Item;
|
||||
import net.minecraft.item.ItemConvertible;
|
||||
import net.minecraft.item.ItemStack;
|
||||
import net.minecraft.recipe.Ingredient;
|
||||
import net.minecraft.recipe.RecipeType;
|
||||
import net.minecraft.recipe.SmithingRecipe;
|
||||
import net.minecraft.tag.Tag;
|
||||
import net.minecraft.util.Identifier;
|
||||
import net.minecraft.world.item.Item;
|
||||
import net.minecraft.world.item.ItemConvertible;
|
||||
import net.minecraft.world.item.ItemStack;
|
||||
import net.minecraft.world.item.crafting.Ingredient;
|
||||
import net.minecraft.world.item.crafting.RecipeType;
|
||||
import net.minecraft.world.item.crafting.SmithingRecipe;
|
||||
import net.minecraft.tags.Tag;
|
||||
import net.minecraft.resources.ResourceLocation;
|
||||
import ru.betterend.BetterEnd;
|
||||
import ru.betterend.config.Configs;
|
||||
import ru.betterend.recipe.EndRecipeManager;
|
||||
import ru.betterend.util.RecipeHelper;
|
||||
|
||||
public class SmithingTableRecipe {
|
||||
|
||||
|
||||
private final static SmithingTableRecipe BUILDER = new SmithingTableRecipe();
|
||||
private final static RecipeType<SmithingRecipe> TYPE = RecipeType.SMITHING;
|
||||
|
||||
|
||||
public static SmithingTableRecipe create(String name) {
|
||||
return create(BetterEnd.makeID(name));
|
||||
}
|
||||
|
||||
public static SmithingTableRecipe create(Identifier id) {
|
||||
|
||||
public static SmithingTableRecipe create(ResourceLocation id) {
|
||||
BUILDER.id = id;
|
||||
BUILDER.base = null;
|
||||
BUILDER.addition = null;
|
||||
BUILDER.result = null;
|
||||
BUILDER.alright = true;
|
||||
|
||||
|
||||
return BUILDER;
|
||||
}
|
||||
|
||||
private Identifier id;
|
||||
|
||||
private ResourceLocation id;
|
||||
private Ingredient base;
|
||||
private Ingredient addition;
|
||||
private ItemStack result;
|
||||
private boolean alright;
|
||||
|
||||
private SmithingTableRecipe() {}
|
||||
|
||||
|
||||
private SmithingTableRecipe() {
|
||||
}
|
||||
|
||||
public SmithingTableRecipe setResult(ItemConvertible item) {
|
||||
return this.setResult(item, 1);
|
||||
}
|
||||
|
||||
|
||||
public SmithingTableRecipe setResult(ItemConvertible item, int count) {
|
||||
this.alright &= RecipeHelper.exists(item);
|
||||
this.result = new ItemStack(item, count);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public SmithingTableRecipe setBase(ItemConvertible... items) {
|
||||
this.alright &= RecipeHelper.exists(items);
|
||||
this.base = Ingredient.ofItems(items);
|
||||
this.base = Ingredient.of(items);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public SmithingTableRecipe setBase(Tag<Item> tag) {
|
||||
this.base = (Ingredient.fromTag(tag));
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public SmithingTableRecipe setAddition(ItemConvertible... items) {
|
||||
this.alright &= RecipeHelper.exists(items);
|
||||
this.addition = Ingredient.ofItems(items);
|
||||
this.addition = Ingredient.of(items);
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public SmithingTableRecipe setAddition(Tag<Item> tag) {
|
||||
this.addition = (Ingredient.fromTag(tag));
|
||||
return this;
|
||||
}
|
||||
|
||||
|
||||
public void build() {
|
||||
if (Configs.RECIPE_CONFIG.getBoolean("smithing", id.getPath(), true)) {
|
||||
if (base == null) {
|
||||
BetterEnd.LOGGER.warning("Base input for Smithing recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
BetterEnd.LOGGER.warning("Base input for Smithing recipe can't be 'null', recipe {} will be ignored!",
|
||||
id);
|
||||
return;
|
||||
}
|
||||
if (addition == null) {
|
||||
BetterEnd.LOGGER.warning("Addition input for Smithing recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
BetterEnd.LOGGER
|
||||
.warning("Addition input for Smithing recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
if(result == null) {
|
||||
if (result == null) {
|
||||
BetterEnd.LOGGER.warning("Result for Smithing recipe can't be 'null', recipe {} will be ignored!", id);
|
||||
return;
|
||||
}
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue