Prototype/Recipe: Difference between revisions
(Set prototype parent) |
(Converted to SMW format) |
||
Line 1: | Line 1: | ||
{{Prototype parent|PrototypeBase}} | {{Prototype parent|PrototypeBase}} | ||
A recipe. It can be a crafting recipe, a smelting recipe, or a custom type of recipe (see [[Prototype/RecipeCategory]]). | |||
{{Prototype TOC|recipe}} | |||
Prototype | |||
== General properties == | == General properties == | ||
Inherits all properties from [[PrototypeBase]]. | Inherits all properties from [[PrototypeBase]]. | ||
{{Prototype property|category|[[Types/string|string]]|"crafting"|optional=true}} | |||
Optional. The category of this recipe. The built-in categories can be found [[Data.raw#recipe-category|here]]. See also [[Prototype/RecipeCategory]]. | Optional. The category of this recipe. The built-in categories can be found [[Data.raw#recipe-category|here]]. See also [[Prototype/RecipeCategory]]. | ||
{{Prototype property|subgroup|[[Types/string|string]]||optional=true}} | |||
Optional. The subgroup of this recipe. If not specified, defaults to the subgroup of the product if there is only 1, or main_product if multiple products exist. If multiple products exit and no main_product is specified, the subgroup is required. | Optional. The subgroup of this recipe. If not specified, defaults to the subgroup of the product if there is only 1, or main_product if multiple products exist. If multiple products exit and no main_product is specified, the subgroup is required. | ||
{{Prototype property|icons, icon, icon_size (IconSpecification)|[[Types/IconSpecification|IconSpecification]]|optional=true}} | |||
An icon is mandatory for recipe with more than 1 product and no main_product. Otherwise defaults to the icon of main_product/1 product. | An icon is mandatory for recipe with more than 1 product and no main_product. Otherwise defaults to the icon of main_product/1 product. | ||
If given, it overwrites the icon of the main_product/1 product. | If given, it overwrites the icon of the main_product/1 product. | ||
{{Prototype property|crafting_machine_tint|[[Types/table|table]] of [[Types/Color|Color]]|optional=true}} | |||
Optional. | Optional. | ||
Line 41: | Line 29: | ||
If the recipe does not have a difficulty, this is located directly in the prototype. Otherwise, if the "'''normal'''" or "'''expensive'''" property exists, the recipe has difficulty. Then, the recipe data has to be specified for each difficulty instead of directly in the prototype. If at least one difficulty has recipe data defined, the other difficulty can be set to <code>false</code>. This will disable the recipe for the difficulty, same as setting it <code>enabled = false</code>. If it is enabled (by technologies etc), it will use the data from the other difficulty. Not setting a difficulty, e.g. <code>normal = nil</code>, is possible and gives that difficulty the exact same properties as the difficulty that is defined. See below for examples. | If the recipe does not have a difficulty, this is located directly in the prototype. Otherwise, if the "'''normal'''" or "'''expensive'''" property exists, the recipe has difficulty. Then, the recipe data has to be specified for each difficulty instead of directly in the prototype. If at least one difficulty has recipe data defined, the other difficulty can be set to <code>false</code>. This will disable the recipe for the difficulty, same as setting it <code>enabled = false</code>. If it is enabled (by technologies etc), it will use the data from the other difficulty. Not setting a difficulty, e.g. <code>normal = nil</code>, is possible and gives that difficulty the exact same properties as the difficulty that is defined. See below for examples. | ||
{{Prototype property|ingredients|[[Types/table|table]] of [[Types/IngredientPrototype|IngredientPrototype]]}} | |||
A table containing ingredient names and counts. Can also contain information about fluid temperature and catalyst amounts. | A table containing ingredient names and counts. Can also contain information about fluid temperature and catalyst amounts. | ||
<syntaxhighlight lang="lua"> | <syntaxhighlight lang="lua"> | ||
Line 58: | Line 44: | ||
Maximal ingredient amount is 65535. The catalyst amounts are automatically calculated from the recipe, or can be set manually.[https://factorio.com/blog/post/fff-256] | Maximal ingredient amount is 65535. The catalyst amounts are automatically calculated from the recipe, or can be set manually.[https://factorio.com/blog/post/fff-256] | ||
{{Prototype property|result|[[Types/string|string]]|optional=true}} | |||
Can be replaced with the results parameter. The item created by this recipe. Must be the name of an item, such as "iron-gear-wheel". | Can be replaced with the results parameter. The item created by this recipe. Must be the name of an item, such as "iron-gear-wheel". | ||
{{Prototype property|result_count|[[Types/uint32|uint32]]|optional=true}} | |||
Optional. The number of items created by this recipe. The default is 1. | Optional. The number of items created by this recipe. The default is 1. | ||
{{Prototype property|results|[[Types/table|table]] of [[Types/ProductPrototype|ProductPrototype]]|optional=true}} | |||
A table containing result names and counts. Can also contain information about fluid temperature and catalyst amounts. The catalyst amounts are automatically calculated from the recipe, or can be set manually.[https://factorio.com/blog/post/fff-256] | A table containing result names and counts. Can also contain information about fluid temperature and catalyst amounts. The catalyst amounts are automatically calculated from the recipe, or can be set manually.[https://factorio.com/blog/post/fff-256] | ||
Line 89: | Line 69: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
{{Prototype property|energy_required|[[Types/double|double]]|0.5|optional=true}} | |||
Optional. The amount of time it takes to make this recipe. | Optional. The amount of time it takes to make this recipe. | ||
This is the number of seconds it takes to craft at crafting speed 1. | This is the number of seconds it takes to craft at crafting speed 1. | ||
{{Prototype property|emissions_multiplier|[[Types/double|double]]|1.0|optional=true}} | |||
{{Prototype property|requester_paste_multiplier|[[Types/uint32|uint32]]|30|optional=true}} | |||
{{Prototype property|overload_multiplier|[[Types/uint32|uint32]]|0|optional=true}} | |||
{{Prototype property|enabled|[[Types/bool|bool]]|true|optional=true}} | |||
Optional. This can be false to disable the recipe at the start of the game, or "true" to leave it enabled. | Optional. This can be false to disable the recipe at the start of the game, or "true" to leave it enabled. | ||
If your recipe is unlocked by a technology, you should set this to "false". | If your recipe is unlocked by a technology, you should set this to "false". | ||
{{Prototype property|hidden|[[Types/bool|bool]]|false|optional=true}} | |||
Optional. Hides the recipe from crafting menus. | Optional. Hides the recipe from crafting menus. | ||
{{Prototype property|hide_from_stats|[[Types/bool|bool]]|false|optional=true}} | |||
Optional. Hides the recipe from flow stats (production statistics). | Optional. Hides the recipe from flow stats (production statistics). | ||
{{Prototype property|hide_from_player_crafting|[[Types/bool|bool]]|false|optional=true}} | |||
Optional. Hides the recipe from the player's crafting screen. | Optional. Hides the recipe from the player's crafting screen. | ||
{{Prototype property|allow_decomposition|[[Types/bool|bool]]|true|optional=true}} | |||
Optional. Whether the recipe can be broken down for "total-raw" calculations. | Optional. Whether the recipe can be broken down for "total-raw" calculations. | ||
{{Prototype property|allow_as_intermediate|[[Types/bool|bool]]|true|optional=true}} | |||
Optional. Whether the recipe can be used as an intermediate recipe in hand-crafting. | Optional. Whether the recipe can be used as an intermediate recipe in hand-crafting. | ||
{{Prototype property|allow_intermediates|[[Types/bool|bool]]|true|optional=true}} | |||
Optional. Whether the recipe is allowed to use intermediate recipes when hand-crafting. | Optional. Whether the recipe is allowed to use intermediate recipes when hand-crafting. | ||
{{Prototype property|always_show_made_in|[[Types/bool|bool]]|false|optional=true}} | |||
Optional. Whether the "Made in: {Machine}" part of the tool-tip should always be present, not only when the recipe can not be hand-crafted. | Optional. Whether the "Made in: {Machine}" part of the tool-tip should always be present, not only when the recipe can not be hand-crafted. | ||
{{Prototype property|show_amount_in_title|[[Types/bool|bool]]|true|optional=true}} | |||
Optional. Whether the recipe name should have the product amount in front of it, e.g. "2 [[transport belt]]" | Optional. Whether the recipe name should have the product amount in front of it, e.g. "2 [[transport belt]]" | ||
{{Prototype property|always_show_products|[[Types/bool|bool]]|false|optional=true}} | |||
Optional. Whether the products are always shown in the recipe tool-tip. | Optional. Whether the products are always shown in the recipe tool-tip. | ||
{{Prototype property|main_product|[[Types/string|string]]|optional=true}} | |||
Optional. | Optional. | ||
Revision as of 19:17, 6 August 2019
Prototype definitions » PrototypeBase » Prototype/Recipe
A recipe. It can be a crafting recipe, a smelting recipe, or a custom type of recipe (see Prototype/RecipeCategory).
General properties
Inherits all properties from PrototypeBase.
category
Type: string
Default: "crafting"
Optional. The category of this recipe. The built-in categories can be found here. See also Prototype/RecipeCategory.
subgroup
Type: string
Optional. The subgroup of this recipe. If not specified, defaults to the subgroup of the product if there is only 1, or main_product if multiple products exist. If multiple products exit and no main_product is specified, the subgroup is required.
icons, icon, icon_size (IconSpecification)
Type: IconSpecification
An icon is mandatory for recipe with more than 1 product and no main_product. Otherwise defaults to the icon of main_product/1 product.
If given, it overwrites the icon of the main_product/1 product.
crafting_machine_tint
Type: table of Color
Optional.
Format:
crafting_machine_tint = { primary = {r=0,g=0,b=0,a=0}, secondary = {r=0,g=0,b=0,a=0}, tertiary = {r=0,g=0,b=0,a=0}}
Each key/value pair is optional and defaults to the above value.
Recipe data
If the recipe does not have a difficulty, this is located directly in the prototype. Otherwise, if the "normal" or "expensive" property exists, the recipe has difficulty. Then, the recipe data has to be specified for each difficulty instead of directly in the prototype. If at least one difficulty has recipe data defined, the other difficulty can be set to false
. This will disable the recipe for the difficulty, same as setting it enabled = false
. If it is enabled (by technologies etc), it will use the data from the other difficulty. Not setting a difficulty, e.g. normal = nil
, is possible and gives that difficulty the exact same properties as the difficulty that is defined. See below for examples.
ingredients
Type: table of IngredientPrototype
A table containing ingredient names and counts. Can also contain information about fluid temperature and catalyst amounts.
ingredients = {{"iron-stick", 2}, {"iron-plate", 3}}
The same with full format:
ingredients = {{type = "item", name = "iron-stick", amount = 2}, {type = "item", name = "iron-plate", amount = 3}}
For fluids, the full format always has to be used:
ingredients = {{type="fluid", name="water", amount=50}, {type="fluid", name="crude-oil", amount=100}}
Maximal ingredient amount is 65535. The catalyst amounts are automatically calculated from the recipe, or can be set manually.[1]
result
Type: string
Can be replaced with the results parameter. The item created by this recipe. Must be the name of an item, such as "iron-gear-wheel".
result_count
Type: uint32
Optional. The number of items created by this recipe. The default is 1.
results
Type: table of ProductPrototype
A table containing result names and counts. Can also contain information about fluid temperature and catalyst amounts. The catalyst amounts are automatically calculated from the recipe, or can be set manually.[2]
results=
{
{type="fluid", name="heavy-oil", amount=3},
{type="fluid", name="light-oil", amount=3},
{type="fluid", name="petroleum-gas", amount=4}
},
results =
{
{type = "item", name = "iron-nuggets", amount = 9},
{type = "item", name = "gold-nuggets", amount = 1}
},
energy_required
Type: double
Default: 0.5
Optional. The amount of time it takes to make this recipe.
This is the number of seconds it takes to craft at crafting speed 1.
emissions_multiplier
Type: double
Default: 1.0
requester_paste_multiplier
Type: uint32
Default: 30
overload_multiplier
Type: uint32
Default: 0
enabled
Type: bool
Default: true
Optional. This can be false to disable the recipe at the start of the game, or "true" to leave it enabled.
If your recipe is unlocked by a technology, you should set this to "false".
Type: bool
Default: false
Optional. Hides the recipe from crafting menus.
hide_from_stats
Type: bool
Default: false
Optional. Hides the recipe from flow stats (production statistics).
hide_from_player_crafting
Type: bool
Default: false
Optional. Hides the recipe from the player's crafting screen.
allow_decomposition
Type: bool
Default: true
Optional. Whether the recipe can be broken down for "total-raw" calculations.
allow_as_intermediate
Type: bool
Default: true
Optional. Whether the recipe can be used as an intermediate recipe in hand-crafting.
allow_intermediates
Type: bool
Default: true
Optional. Whether the recipe is allowed to use intermediate recipes when hand-crafting.
always_show_made_in
Type: bool
Default: false
Optional. Whether the "Made in: {Machine}" part of the tool-tip should always be present, not only when the recipe can not be hand-crafted.
show_amount_in_title
Type: bool
Default: true
Optional. Whether the recipe name should have the product amount in front of it, e.g. "2 transport belt"
always_show_products
Type: bool
Default: false
Optional. Whether the products are always shown in the recipe tool-tip.
main_product
Type: string
Optional.
For recipes with more than one product: This defines of which result the icon, subgroup and name is used. If it is not set and the recipe has more than 1 result the recipe will use the recipe-name and recipe-description locale and its own subgroup and icon.
For recipes with 1 result: The recipe uses the icon, subgroup and name of the result by default. If set this property is set to an empty string, the recipe will use the properties of the recipe instead of the result.
Examples
"iron-plate"
{
type = "recipe",
name = "iron-plate",
category = "smelting",
energy_required = 3.5,
ingredients = {{"iron-ore", 1}},
result = "iron-plate"
}
"coal-liquefaction"
{
type = "recipe",
name = "coal-liquefaction",
category = "oil-processing",
subgroup = "fluid-recipes",
order = "a[oil-processing]-c[coal-liquefaction]",
enabled = false,
energy_required = 5,
icon = "__base__/graphics/icons/fluid/coal-liquefaction.png",
icon_size = 32,
ingredients =
{
{type="item", name="coal", amount=10},
{type="fluid", name="heavy-oil", amount=25},
{type="fluid", name="steam", amount=50}
},
results=
{
{type="fluid", name="heavy-oil", amount=35},
{type="fluid", name="light-oil", amount=15},
{type="fluid", name="petroleum-gas", amount=20}
},
allow_decomposition = false
}
"iron-gear-wheel" — recipe with difficulty
{
type = "recipe",
name = "iron-gear-wheel",
normal =
{
ingredients = {{"iron-plate", 2}},
result = "iron-gear-wheel"
},
expensive =
{
ingredients = {{"iron-plate", 4}},
result = "iron-gear-wheel"
}
},
Modified so that it cannot be crafted in normal mode, unless unlocked via command/research
{
type = "recipe",
name = "iron-gear-wheel",
normal = false,
expensive =
{
ingredients = {{"iron-plate", 4}},
result = "iron-gear-wheel"
}
},
Modified so that the expensive recipe is always used, even in normal mode
{
type = "recipe",
name = "iron-gear-wheel",
normal = nil, --this line can be omitted
expensive =
{
ingredients = {{"iron-plate", 4}},
result = "iron-gear-wheel"
}
},