Tutorial:Advanced Recipes 164
So far we have learned about how to add or remove simple recipes. But what if the inputs and outputs also involve damage values or NBT tags?
NBT Tag in output
It is possible to define both damage or an NBT tag as output. Let's take a pickaxe as our toy for this tutorial:
val stick = <item.stick>; val pick = <item.pickaxeStone>; val damagedPick = pick.withDamage(10); val stickedPick = pick.withTag({display: {Name: "Sticked pick", Lore: ["This pick", "Has been sticked"]}}); recipes.addShaped(damagedPick, pick, stick); recipes.addShaped(stickedPick, [[pick, stick], [stick, stick]]);
Crafting the pick with 1 or 3 sticks as in the recipe will give you an item with the appropriate damage and name/lore on it, respectively.
Input conditions
You can also require the input to contain certain NBT tags. Say, you make a recipe that requires our sticked pick. Let's modify our file:
val stick = <item.stick>; val pick = <item.pickaxeStone>; val damagedPick = pick.withDamage(10); val stickedPick = pick.withTag({display: {Name: "Sticked pick", Lore: ["This pick", "Has been sticked"]}}); recipes.addShaped(damagedPick, pick, stick); recipes.addShaped(stickedPick, [[pick, stick], [stick, stick]]); val stonedPick = pick.withTag({display: {Name: "Stoned pick", Lore: ["This pick", "Has been experimenting too much"]}}); val onlyStickedPick = pick.onlyWithTag({display: {Name: "Sticked pick"}}); val cobble = <tile.stonebrick>; recipes.addShaped(stonedPick, [[onlyStickedPick, cobble], [cobble, cobble]]);
What about the lore part in our sticked pick? Since your condition only contains the name, the lore part is ignored - when setting a condition on the data tag, MineTweaker only cares about the contents that you specified and ignores everything else.
Note the difference between withTag and onlyWithTag. withTag is for an output and is the exact tag that will be output. onlyWithTag is for input and sets a condition. Applying withTag on an input has no effect on the recipe.
Other conditions exist too:
myItem.onlyDamaged(); // only accepts damaged items myItem.onlyDamageAtLeast(15); // only accepts items with a damage of at least 15 myItem.onlyDamageAtMost(100); // only accepts items with a damage of at most 100 myItem.onlyDamageBetween(15, 100); // only accepts items with a damage between 15 and 100
Multiple conditions can be added to a single ingredient, too:
myItem.onlyDamaged().onlyWithTag({display: {Name: "Sticked pick"}});
Output reuse and transformations
Since MineTweaker 3.0.2, it is now possible to reuse items, return empty buckets to the crafting grid (or whatever item you want) or damage items upon crafting.
We could for instance make a recipe to get more sticks out of wood by using an axe:
recipes.addShapeless(<item.stick> * 3, [<item.hatchetStone>, <ore:woodPlanks>]);
Nice. But the stone axe gets consumed, and that is sort of annoying. We can fix this with the reuse modifier:
recipes.addShapeless(<item.stick> * 3, [<item.hatchetStone>.reuse(), <ore:plankWood>]);
Great! We can reuse the axe. Now what if we also wanted the axe to be damaged when you use it?
recipes.addShapeless(<item.stick> * 3, [<item.hatchetStone>.transformDamage(), <ore:plankWood>]);
We can also deal more than 1 damage upon crafting:
recipes.addShapeless(<item.stick> * 3, [<item.hatchetStone>.transformDamage(4), <ore:plankWood>]);
Imagine we'd want to make a recipe to turn dirt into grass by combining dirt, a water bucket and wheat. We could make this recipe:
recipes.addShapeless(<tile.grass>, [<tile.dirt>, <item.bucketWater>, <item.wheat>]);
However, crafting this will consume the bucket. We can tell MineTweaker to return the empty bucket afterwards:
recipes.addShaped(<tile.grass>, [[ <tile.dirt>, <item.bucketWater>.transformReplace(<item.bucket>), <item.wheat> ]]);
Now, crafting a grass block will return the empty crafting bucket in the crafting grid.
Sometimes mods define their own behavior when you use their items while crafting. Likewise, Minecraft will return you an empty bucket when you use it in a crafting recipe. If you don't want that, you can tell the item to not return anything at all:
recipes.addShaped(<minecraft:grass>, [[ <tile.dirt>, <item.bucketWater>.noReturn(), <item.wheat> ]]);
If you want to give something back, but not in the crafting inventory, you can also use giveBack. GiveBack can be used without arguments, in which case it will return the original item, or it can be used with an item, in which case that item will be given back into the player inventory:
recipes.addShaped(<minecraft:grass>, [[ <tile.dirt>, <item.bucketWater>.giveBack(<item.ingotIron> * 3), <item.wheat> ]]);
GiveBack will usually also have the side-effect of suppressing mod item return behavior. It may thus be a handy alternative to the transformReplace modifier in those cases.