mirror of
https://github.com/PHIDIAS0303/factorio-mod-PHI.git
synced 2025-12-27 11:05:22 +09:00
Update data.lua
This commit is contained in:
152
PHI-MB/data.lua
152
PHI-MB/data.lua
@@ -1,60 +1,81 @@
|
|||||||
local alpha_order = {'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm'}
|
local alpha_order = {'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm'}
|
||||||
local graphics_location = '__PHI-MB__/graphics/'
|
local graphics_location = '__PHI-MB__/graphics/'
|
||||||
|
|
||||||
local items = {'assembling-machine', 'electric-furnace', 'oil-refinery', 'chemical-plant', 'centrifuge', 'lab'}
|
local items = {
|
||||||
|
['assembling-machine'] = {
|
||||||
local item_min = {
|
enabled = true,
|
||||||
['assembling-machine'] = 4,
|
type = 'assembling-machine',
|
||||||
['electric-furnace'] = 2,
|
name = 'assembling-machine',
|
||||||
['oil-refinery'] = 2,
|
tech = 'automation-3',
|
||||||
['chemical-plant'] = 2,
|
min = 4,
|
||||||
['centrifuge'] = 2,
|
max = 5
|
||||||
['lab'] = 2
|
},
|
||||||
}
|
['electric-furnace'] = {
|
||||||
|
enabled = true,
|
||||||
local item_max = {
|
type = 'furnace',
|
||||||
['assembling-machine'] = 5,
|
name = 'electric-furnace',
|
||||||
['electric-furnace'] = 3,
|
tech = 'advanced-material-processing-2',
|
||||||
['oil-refinery'] = 3,
|
min = 2,
|
||||||
['chemical-plant'] = 3,
|
max = 3
|
||||||
['centrifuge'] = 3,
|
},
|
||||||
['lab'] = 3
|
['oil-refinery'] = {
|
||||||
|
enabled = true,
|
||||||
|
type = 'assembling-machine',
|
||||||
|
name = 'oil-refinery',
|
||||||
|
tech = 'oil-processing',
|
||||||
|
min = 2,
|
||||||
|
max = 3
|
||||||
|
},
|
||||||
|
['chemical-plant'] = {
|
||||||
|
enabled = true,
|
||||||
|
type = 'assembling-machine',
|
||||||
|
name = 'chemical-plant',
|
||||||
|
tech = 'oil-processing',
|
||||||
|
min = 2,
|
||||||
|
max = 3
|
||||||
|
},
|
||||||
|
['centrifuge'] = {
|
||||||
|
enabled = true,
|
||||||
|
type = 'electric-furnace',
|
||||||
|
name = 'centrifuge',
|
||||||
|
tech = 'uranium-processing',
|
||||||
|
min = 2,
|
||||||
|
max = 3
|
||||||
|
},
|
||||||
|
['lab'] = {
|
||||||
|
enabled = true,
|
||||||
|
type = 'lab',
|
||||||
|
name = 'lab',
|
||||||
|
tech = 'automation',
|
||||||
|
min = 2,
|
||||||
|
max = 3
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
-- entity
|
-- entity
|
||||||
local function EE(source, tier)
|
local function EE(source, tier)
|
||||||
local item
|
local item = table.deepcopy(data.raw[source.type][source.name])
|
||||||
|
|
||||||
if source == 'assembling-machine' then
|
|
||||||
item = table.deepcopy(data.raw['assembling-machine']['assembling-machine-3'])
|
|
||||||
elseif source == 'electric-furnace' then
|
|
||||||
item = table.deepcopy(data.raw['furnace']['electric-furnace'])
|
|
||||||
elseif source == 'lab' then
|
|
||||||
item = table.deepcopy(data.raw['lab']['lab'])
|
|
||||||
else
|
|
||||||
item = table.deepcopy(data.raw['assembling-machine'][source])
|
|
||||||
end
|
|
||||||
|
|
||||||
item.name = source .. '-' .. tier
|
item.name = source.name .. '-' .. tier
|
||||||
item.minable.result = source .. '-' .. tier
|
item.minable.result = source.name .. '-' .. tier
|
||||||
item.max_health = item.max_health * (2 ^ (tier - item_min[source] + 1))
|
item.max_health = item.max_health * (2 ^ (tier - source.min + 1))
|
||||||
|
|
||||||
if source == 'lab' then
|
if source.type == 'lab' then
|
||||||
item.researching_speed = item.researching_speed * (2 ^ (tier - item_min[source] + 1))
|
item.researching_speed = item.researching_speed * (2 ^ (tier - source.min + 1))
|
||||||
else
|
else
|
||||||
item.crafting_speed = item.crafting_speed * (2 ^ (tier - item_min[source] + 1))
|
item.crafting_speed = item.crafting_speed * (2 ^ (tier - source.min + 1))
|
||||||
item.energy_source.emissions_per_minute = item.energy_source.emissions_per_minute * (2 ^ (tier - item_min[source] + 1))
|
item.energy_source.emissions_per_minute = item.energy_source.emissions_per_minute * (2 ^ (tier - source.min + 1))
|
||||||
end
|
end
|
||||||
|
|
||||||
item.energy_usage = tonumber(string.match(item.energy_usage, '%d+')) * (2 ^ (tier - item_min[source] + 1)) .. 'kW'
|
item.energy_usage = tonumber(string.match(item.energy_usage, '%d+')) * (2 ^ (tier - source.min + 1)) .. 'kW'
|
||||||
-- item.animation.layers[1].filename = graphics_location .. source .. '-e.png'
|
-- item.animation.layers[1].filename = graphics_location .. source .. '-e.png'
|
||||||
-- item.animation.layers[1].hr_version.filename = graphics_location .. source ..'-eh.png'
|
-- item.animation.layers[1].hr_version.filename = graphics_location .. source ..'-eh.png'
|
||||||
-- item.icon = graphics_location .. source .. '-i.png'
|
-- item.icon = graphics_location .. source .. '-i.png'
|
||||||
-- item.icon_size = 64
|
-- item.icon_size = 64
|
||||||
-- item.icon_mipmaps = 4
|
-- item.icon_mipmaps = 4
|
||||||
|
|
||||||
if (tier <= item_max[source] - 1) then
|
if (tier <= source.max - 1) then
|
||||||
item.next_upgrade = source .. '-' .. (tier + 1)
|
item.next_upgrade = source.name .. '-' .. (tier + 1)
|
||||||
end
|
end
|
||||||
|
|
||||||
data:extend({item})
|
data:extend({item})
|
||||||
@@ -64,14 +85,14 @@ end
|
|||||||
local function EI(source, tier)
|
local function EI(source, tier)
|
||||||
local item
|
local item
|
||||||
|
|
||||||
if source == 'assembling-machine' then
|
if source.name == 'assembling-machine' then
|
||||||
item = table.deepcopy(data.raw.item['assembling-machine-3'])
|
item = table.deepcopy(data.raw.item['assembling-machine-3'])
|
||||||
else
|
else
|
||||||
item = table.deepcopy(data.raw.item[source])
|
item = table.deepcopy(data.raw.item[source.name])
|
||||||
end
|
end
|
||||||
|
|
||||||
item.name = source .. '-' .. tier
|
item.name = source.name .. '-' .. tier
|
||||||
item.place_result = source .. '-' .. tier
|
item.place_result = source.name .. '-' .. tier
|
||||||
-- item.icons = {{icon = graphics_location .. source .. '-i.png', icon_mipmaps = 4, icon_size = 64}}
|
-- item.icons = {{icon = graphics_location .. source .. '-i.png', icon_mipmaps = 4, icon_size = 64}}
|
||||||
item.order = item.order .. tier
|
item.order = item.order .. tier
|
||||||
data:extend({item})
|
data:extend({item})
|
||||||
@@ -79,43 +100,36 @@ end
|
|||||||
|
|
||||||
-- recipe
|
-- recipe
|
||||||
local function ER(source, tier)
|
local function ER(source, tier)
|
||||||
local na = source
|
local na = source.name
|
||||||
|
|
||||||
if (tier >= 3) then
|
if source.min == tier then
|
||||||
|
na = source.name
|
||||||
|
elseif (tier >= 2) then
|
||||||
na = na .. '-' .. (tier - 1)
|
na = na .. '-' .. (tier - 1)
|
||||||
end
|
end
|
||||||
|
|
||||||
data:extend({{
|
data:extend({{
|
||||||
type = 'recipe',
|
type = 'recipe',
|
||||||
name = source .. '-' .. tier,
|
name = source.name .. '-' .. tier,
|
||||||
energy_required = 2,
|
energy_required = 2,
|
||||||
enabled = false,
|
enabled = false,
|
||||||
ingredients = {{na, 2}},
|
ingredients = {{na, 2}},
|
||||||
result = source .. '-' .. tier,
|
result = source.name .. '-' .. tier,
|
||||||
}})
|
}})
|
||||||
end
|
end
|
||||||
|
|
||||||
for i=1, #items, 1 do
|
-- tech
|
||||||
for j=item_min[items[i]], item_max[items[i]], 1 do
|
local function ET(source, tier)
|
||||||
EE(items[i], j)
|
table.insert(data.raw.technology[source.tech].effects, {type='unlock-recipe', recipe=source.name .. '-' .. tier})
|
||||||
EI(items[i], j)
|
|
||||||
ER(items[i], j)
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
table.insert(data.raw.technology['automation-3'].effects, {type='unlock-recipe', recipe='assembling-machine-4'})
|
for _, v in pairs(items) do
|
||||||
table.insert(data.raw.technology['automation-3'].effects, {type='unlock-recipe', recipe='assembling-machine-5'})
|
if v.enabled then
|
||||||
|
for j=v.min, v.max, 1 do
|
||||||
table.insert(data.raw.technology['advanced-material-processing-2'].effects, {type='unlock-recipe', recipe='electric-furnace-2'})
|
EE(v, j)
|
||||||
table.insert(data.raw.technology['advanced-material-processing-2'].effects, {type='unlock-recipe', recipe='electric-furnace-3'})
|
EI(v, j)
|
||||||
|
ER(v, j)
|
||||||
table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='oil-refinery-2'})
|
ET(v, j)
|
||||||
table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='oil-refinery-3'})
|
end
|
||||||
table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='chemical-plant-2'})
|
end
|
||||||
table.insert(data.raw.technology['oil-processing'].effects, {type='unlock-recipe', recipe='chemical-plant-3'})
|
end
|
||||||
|
|
||||||
table.insert(data.raw.technology['uranium-processing'].effects, {type='unlock-recipe', recipe='centrifuge-2'})
|
|
||||||
table.insert(data.raw.technology['uranium-processing'].effects, {type='unlock-recipe', recipe='centrifuge-3'})
|
|
||||||
|
|
||||||
table.insert(data.raw.technology['automation'].effects, {type='unlock-recipe', recipe='lab-2'})
|
|
||||||
table.insert(data.raw.technology['automation'].effects, {type='unlock-recipe', recipe='lab-3'})
|
|
||||||
Reference in New Issue
Block a user