Class GridRecipe
- Namespace
- Vintagestory.API.Common
- Assembly
- VintagestoryAPI.dll
Represents a crafting recipe to be made on the crafting grid.
public class GridRecipe : IByteSerializable
- Inheritance
-
GridRecipe
- Implements
- Inherited Members
- Extension Methods
Examples
{
"ingredientPattern": "GS,S_",
"ingredients": {
"G": {
"type": "item",
"code": "drygrass"
},
"S": {
"type": "item",
"code": "stick"
}
},
"width": 2,
"height": 2,
"output": {
"type": "item",
"code": "firestarter"
}
}
Fields
Attributes
Optional attribute data that you can attach any data to. Useful for code mods, but also required when using liquid ingredients.
See dough.json grid recipe file for example.
[JsonConverter(typeof(JsonAttributesConverter))]
public JsonObject Attributes
Field Value
AverageDurability
If true, the output item will have its durability averaged over the input items
public bool AverageDurability
Field Value
CopyAttributesFrom
If set, it will copy over the itemstack attributes from given ingredient code
public string CopyAttributesFrom
Field Value
Enabled
If set to false, the recipe will never be loaded. If loaded, you can use this field to disable recipes during runtime.
public bool Enabled
Field Value
Height
Required grid height for crafting this recipe
public int Height
Field Value
IngredientPattern
The pattern of the ingredient. Order for a 3x3 recipe:
1 2 3
4 5 6
7 8 9
Order for a 2x2 recipe:
1 2
3 4
Commas seperate each horizontal row, and an underscore ( _ ) marks a space as empty.
public string IngredientPattern
Field Value
Ingredients
The recipes ingredients in any order, including the code used in the ingredient pattern.
public Dictionary<string, CraftingRecipeIngredient> Ingredients
Field Value
Name
Name of the recipe. Used for logging, and some specific uses. Recipes for repairing objects must contain 'repair' in the name.
public AssetLocation Name
Field Value
Output
The resulting stack when the recipe is created.
public CraftingRecipeIngredient Output
Field Value
RecipeGroup
Info used by the handbook. By default, all recipes for an object will appear in a single preview. This allows you to split grid recipe previews into multiple.
public int RecipeGroup
Field Value
RequiresTrait
If set, only players with given trait can use this recipe. See config/traits.json for a list of traits.
public string RequiresTrait
Field Value
Shapeless
Whether the order of input items should be respected
public bool Shapeless
Field Value
ShowInCreatedBy
Used by the handbook. If false, will not appear in the "Created by" section
public bool ShowInCreatedBy
Field Value
Width
Required grid width for crafting this recipe
public int Width
Field Value
resolvedIngredients
A set of ingredients with their pattern codes resolved into a single object.
public GridRecipeIngredient[] resolvedIngredients
Field Value
Methods
Clone()
Creates a deep copy
public GridRecipe Clone()
Returns
ConsumeInput(IPlayer, ItemSlot[], int)
Puts the crafted itemstack into the output slot and consumes the required items from the input slots
public bool ConsumeInput(IPlayer byPlayer, ItemSlot[] inputSlots, int gridWidth)
Parameters
Returns
FromBytes(BinaryReader, IWorldAccessor)
Deserializes the recipe
public void FromBytes(BinaryReader reader, IWorldAccessor resolver)
Parameters
reader
BinaryReaderresolver
IWorldAccessor
GenerateOutputStack(ItemSlot[], ItemSlot)
public void GenerateOutputStack(ItemSlot[] inputSlots, ItemSlot outputSlot)
Parameters
GetElementInGrid<T>(int, int, T[], int)
public T GetElementInGrid<T>(int row, int col, T[] stacks, int gridwidth)
Parameters
Returns
- T
Type Parameters
T
GetGridIndex<T>(int, int, T[], int)
public int GetGridIndex<T>(int row, int col, T[] stacks, int gridwidth)
Parameters
Returns
Type Parameters
T
GetInputStackForPatternCode(string, ItemSlot[])
Returns only the first matching itemstack, there may be multiple
public ItemStack GetInputStackForPatternCode(string patternCode, ItemSlot[] inputSlots)
Parameters
Returns
GetNameToCodeMapping(IWorldAccessor)
Resolves Wildcards in the ingredients
public Dictionary<string, string[]> GetNameToCodeMapping(IWorldAccessor world)
Parameters
world
IWorldAccessor
Returns
- Dictionary<string, string[]>
Matches(IPlayer, ItemSlot[], int)
Check if this recipe matches given ingredients
public bool Matches(IPlayer forPlayer, ItemSlot[] ingredients, int gridWidth)
Parameters
Returns
MatchesAtPosition(int, int, ItemSlot[], int)
public bool MatchesAtPosition(int colStart, int rowStart, ItemSlot[] inputSlots, int gridWidth)
Parameters
Returns
ResolveIngredients(IWorldAccessor)
Turns Ingredients into IItemStacks
public bool ResolveIngredients(IWorldAccessor world)
Parameters
world
IWorldAccessor
Returns
- bool
True on successful resolve
ToBytes(BinaryWriter)
Serialized the recipe
public void ToBytes(BinaryWriter writer)
Parameters
writer
BinaryWriter