mirror of
https://asciireactor.com/factorio/adamo-physics.git
synced 2024-11-23 09:25:05 +00:00
init
This commit is contained in:
commit
ba7fc9dbe0
67
changelog.txt
Normal file
67
changelog.txt
Normal file
@ -0,0 +1,67 @@
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.9
|
||||
Date: 2020-02-22
|
||||
|
||||
Graphics:
|
||||
- Changed glow color of chemical-fueled
|
||||
entities to be more physical.
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.8
|
||||
Date: 2020-02-03
|
||||
|
||||
Changes:
|
||||
- Moved mod to version 18.
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.7
|
||||
Date: 2019-10-02
|
||||
|
||||
Entities:
|
||||
- Reset base_area to vanilla values
|
||||
and doubled height on fluid boxes
|
||||
to improve megareactor throughput.
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.6
|
||||
Date: 2019-09-28
|
||||
|
||||
Balancing:
|
||||
- Drain reduced by factor of 24 on all
|
||||
electric-turret entities, e.g. laser-
|
||||
turret.
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.5
|
||||
Date: 2019-09-15
|
||||
|
||||
Changes:
|
||||
- Added support for fluid-powered furnaces.
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.4
|
||||
Date: 2019-08-31
|
||||
|
||||
Balancing:
|
||||
- Increased solar panel power to 6kW and
|
||||
decreased accumulator power to 30kW.
|
||||
Panel:accumulator ratio now matches vanilla,
|
||||
with vanilla energy capacity but 1/10 power.
|
||||
Thanks for pointing that out, mmmPi.
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.3
|
||||
Date: 2019-08-29
|
||||
|
||||
Balancing:
|
||||
- Increased slightly the efficiency of burner-powered
|
||||
assembling-machine prototypes, to match furnaces.
|
||||
(Removed the "mechanical cost", metaphorically.)
|
||||
|
||||
---------------------------------------------------------------------------------------------------
|
||||
Version: 0.0.2
|
||||
Date: 2019-08-26
|
||||
|
||||
Changes:
|
||||
- Mod display name changed.
|
||||
- Some refactoring and fortification of fluid fuel compatibility.
|
245
data-final-fixes.lua
Normal file
245
data-final-fixes.lua
Normal file
@ -0,0 +1,245 @@
|
||||
require("factsheet")
|
||||
|
||||
-- Updates to rocket physics.
|
||||
data.raw.ammo["rocket"].ammo_type.action.action_delivery.starting_speed = 0.95
|
||||
data.raw.ammo["explosive-rocket"].ammo_type.action.action_delivery.starting_speed = .95
|
||||
data.raw.projectile["rocket"].acceleration=0.8
|
||||
data.raw.projectile["explosive-rocket"].acceleration=0.8
|
||||
if data.raw.gun["rocket-launcher"] then
|
||||
data.raw.gun["rocket-launcher"].attack_parameters.range=38
|
||||
end
|
||||
|
||||
-- Reduce electric-turret drain by factor of 24.
|
||||
for _,turret in pairs(data.raw["electric-turret"]) do
|
||||
if turret.energy_source
|
||||
and turret.energy_source.type
|
||||
and turret.energy_source.type == "electric" then
|
||||
turret.energy_source.drain =
|
||||
energy_div(
|
||||
(turret.energy_source.drain or "24kW"),
|
||||
24
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
-- Pre rocket launcher
|
||||
if data.raw["ammo-turret"]["pre-rocket-turret"] then
|
||||
data.raw["ammo-turret"]["pre-rocket-turret"].attack_parameters.range=60
|
||||
data.raw["ammo-turret"]["pre-rocket-turret"].attack_parameters.min_range=25
|
||||
end
|
||||
|
||||
-- Aircraft mod launcher.
|
||||
if data.raw.gun["aircraft-rocket-launcher"] then
|
||||
data.raw.gun["aircraft-rocket-launcher"].
|
||||
attack_parameters.range=60
|
||||
end
|
||||
|
||||
-- Helicopter mod launcher
|
||||
if data.raw.gun["heli-rocket-launcher-item"] then
|
||||
data.raw.gun["heli-rocket-launcher-item"].attack_parameters.range=60
|
||||
end
|
||||
|
||||
-- Predictabowl's vehicle rocket launcher
|
||||
if data.raw.gun["vehicle-rocket-launcher"] then
|
||||
data.raw.gun["vehicle-rocket-launcher"].attack_parameters.range=50
|
||||
end
|
||||
|
||||
if data.raw.gun["vehicle-rocket-launcher-2"] then
|
||||
data.raw.gun["vehicle-rocket-launcher-2"].attack_parameters.range=60
|
||||
end
|
||||
|
||||
for _,heatpipe in pairs(data.raw["heat-pipe"]) do
|
||||
heatpipe.heat_buffer.specific_heat =
|
||||
energy_div(
|
||||
heatpipe.heat_buffer.specific_heat,
|
||||
nuke_fuel_quotient
|
||||
)
|
||||
heatpipe.heat_buffer.max_transfer =
|
||||
energy_div(
|
||||
heatpipe.heat_buffer.max_transfer,
|
||||
gen_eff
|
||||
)
|
||||
end
|
||||
|
||||
local set_burner_colors = function(entity)
|
||||
local entity = entity_or_bust(entity)
|
||||
if not entity then return end
|
||||
local burner = table_or_bust(get_energy_source(entity))
|
||||
if not burner then return end
|
||||
local color
|
||||
if burner.type == "fluid" and burner.burns_fluid then
|
||||
color = colors.gas_fire_glow
|
||||
elseif uses_fuel_type("chemical",entity) then
|
||||
color = colors.chemical_fire_glow
|
||||
elseif burner.type == "heat" then
|
||||
color = colors.chemical_fire_glow
|
||||
else return end
|
||||
local min_size = 0.05*get_collision_hypotenuse(entity)
|
||||
local glow_num = 0.3*get_collision_hypotenuse(entity)
|
||||
burner.light_flicker = {
|
||||
color = color,
|
||||
minimum_light_size = min_size,
|
||||
light_intensity_to_size_coefficient = glow_num
|
||||
}
|
||||
local viz = table_or_bust(entity.working_visualisations)
|
||||
if viz then
|
||||
for _,subtab in pairs(viz) do
|
||||
if type(subtab.light) == "table" then
|
||||
subtab.light.color = color
|
||||
end
|
||||
end
|
||||
end
|
||||
log("Made physical burner colors for "
|
||||
..entity.name
|
||||
.." ("
|
||||
..tostring(color.r)
|
||||
.." "
|
||||
..tostring(color.g)
|
||||
.." "
|
||||
..tostring(color.b)
|
||||
..")"
|
||||
)
|
||||
end
|
||||
|
||||
for _,boiler in pairs(data.raw.boiler) do
|
||||
boiler.target_temperature = chem_temp_max
|
||||
boiler.fluid_box.height =
|
||||
(boiler.fluid_box.height or 1)/gen_eff
|
||||
boiler.output_fluid_box.height =
|
||||
(boiler.output_fluid_box.height or 1)/gen_eff
|
||||
boiler.energy_consumption = energy_div(
|
||||
boiler.energy_consumption,gen_eff
|
||||
)
|
||||
if boiler.burner
|
||||
and type(boiler.burner) == "table" then
|
||||
boiler.burner.effectivity =
|
||||
(boiler.burner.effectivity or 1)
|
||||
*boiler_eff
|
||||
end
|
||||
if boiler.energy_source
|
||||
and type(boiler.energy_source) == "table" then
|
||||
boiler.energy_source.effectivity =
|
||||
(boiler.energy_source.effectivity or 1)
|
||||
*boiler_eff
|
||||
if boiler.energy_source.type == "heat" then
|
||||
boiler.target_temperature = nuke_temp_max
|
||||
elseif boiler.energy_source.type == "electric" then
|
||||
boiler.target_temperature = 100
|
||||
else
|
||||
set_burner_colors(boiler)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
for _,generator in pairs(data.raw.generator) do
|
||||
generator.effectivity =
|
||||
(generator.effectivity or 1)
|
||||
*gen_eff
|
||||
if generator.fluid_box then
|
||||
generator.fluid_box.height =
|
||||
(generator.fluid_box.height or 1)/gen_eff
|
||||
end
|
||||
if generator.name:find "steam" then
|
||||
if generator.name:find "turbine" then
|
||||
generator.maximum_temperature = nuke_temp_max
|
||||
else
|
||||
generator.maximum_temperature = chem_temp_max
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
for _,item in pairs(data.raw.item) do
|
||||
if item.fuel_value then
|
||||
if item.fuel_category == "chemical" then
|
||||
item.fuel_value = energy_div(
|
||||
item.fuel_value,chem_fuel_quotient
|
||||
)
|
||||
elseif item.fuel_category == "nuclear"
|
||||
or item.fuel_category
|
||||
== "adamo-nuclear-thermal-reaction" then
|
||||
item.fuel_value = energy_div(
|
||||
item.fuel_value,nuke_fuel_quotient
|
||||
)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
for _,fluid in pairs(data.raw.fluid) do
|
||||
if fluid.fuel_value then
|
||||
fluid.fuel_value = energy_div(
|
||||
fluid.fuel_value,chem_fuel_quotient
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
for _,furnace in pairs(data.raw.furnace) do
|
||||
set_burner_colors(furnace)
|
||||
if furnace.energy_source
|
||||
and (
|
||||
furnace.energy_source.type == "burner"
|
||||
or furnace.energy_source.type == "fluid"
|
||||
) then
|
||||
|
||||
furnace.energy_source.effectivity =
|
||||
(furnace.energy_source.effectivity or 1)
|
||||
*furnace_eff
|
||||
elseif furnace.burner then
|
||||
furnace.burner.effectivity =
|
||||
(furnace.burner.effectivity or 1)
|
||||
*furnace_eff
|
||||
end
|
||||
end
|
||||
|
||||
for _,machine in pairs(data.raw["assembling-machine"]) do
|
||||
if machine.energy_source.type == "burner" then
|
||||
set_burner_colors(machine)
|
||||
machine.energy_source.effectivity =
|
||||
(machine.energy_source.effectivity or 1)
|
||||
*(furnace_eff)
|
||||
elseif machine.burner then
|
||||
set_burner_colors(machine)
|
||||
machine.burner.effectivity =
|
||||
(machine.burner.effectivity or 1)
|
||||
*(furnace_eff)
|
||||
end
|
||||
end
|
||||
|
||||
-- nuclear fuel items must have their fuel_values
|
||||
-- adjusted elsewhere to compenstate for this increase
|
||||
for _,reactor in pairs(data.raw.reactor) do
|
||||
reactor.consumption =
|
||||
energy_mult(reactor.consumption,reactor_consump_mult)
|
||||
reactor.energy_source.effectivity = reactor_eff
|
||||
reactor.heat_buffer.max_transfer = energy_div(
|
||||
reactor.heat_buffer.max_transfer,gen_eff
|
||||
)
|
||||
end
|
||||
|
||||
for _,panel in pairs(data.raw["solar-panel"]) do
|
||||
panel.production =
|
||||
energy_mult(
|
||||
panel.production,
|
||||
solar_panel_eff
|
||||
)
|
||||
end
|
||||
|
||||
for _,battery in pairs(data.raw["accumulator"]) do
|
||||
local energy_source = get_energy_source(battery)
|
||||
if energy_source then
|
||||
energy_source.input_flow_limit =
|
||||
energy_mult(
|
||||
energy_source.input_flow_limit,
|
||||
solar_panel_eff
|
||||
)
|
||||
energy_source.output_flow_limit =
|
||||
energy_mult(
|
||||
energy_source.output_flow_limit,
|
||||
solar_panel_eff
|
||||
)
|
||||
end
|
||||
end
|
||||
|
||||
-- This should only set colors on burner inserters.
|
||||
for _,inserter in pairs(data.raw["inserter"]) do
|
||||
set_burner_colors(inserter)
|
||||
end
|
45
data-updates.lua
Normal file
45
data-updates.lua
Normal file
@ -0,0 +1,45 @@
|
||||
require("factsheet")
|
||||
|
||||
local heu_fuel_recipe = data.raw.recipe["uranium-fuel-cell"]
|
||||
local heu_fuel_item = data.raw.item["uranium-fuel-cell"]
|
||||
local heu_fuel_reproc = data.raw.recipe["nuclear-fuel-reprocessing"]
|
||||
heu_fuel_recipe.ingredients = {
|
||||
{"uranium-235",1},
|
||||
{"uranium-238",5},
|
||||
{"iron-plate",3}
|
||||
}
|
||||
heu_fuel_recipe.result = "uranium-fuel-cell"
|
||||
heu_fuel_recipe.result_count = 3
|
||||
heu_fuel_recipe.results = nil
|
||||
heu_fuel_reproc.results = {{"uranium-238",5}}
|
||||
heu_fuel_item.fuel_value = "100GJ"
|
||||
|
||||
|
||||
-- Increasing height of plumbing entities
|
||||
-- improves megareactor performance.
|
||||
|
||||
-- water pump
|
||||
data.raw["offshore-pump"]["offshore-pump"]
|
||||
.fluid_box.height =
|
||||
(data.raw["offshore-pump"]["offshore-pump"]
|
||||
.fluid_box.height or 1)/gen_eff
|
||||
|
||||
-- powered pump
|
||||
data.raw.pump["pump"]
|
||||
.fluid_box.height =
|
||||
(data.raw.pump["pump"]
|
||||
.fluid_box.height or 1)/gen_eff
|
||||
data.raw.pump["pump"]
|
||||
.pumping_speed =
|
||||
data.raw.pump["pump"].pumping_speed/gen_eff
|
||||
|
||||
-- iron pipes
|
||||
data.raw.pipe.pipe
|
||||
.fluid_box.height =
|
||||
(data.raw.pipe.pipe
|
||||
.fluid_box.height or 1)/gen_eff
|
||||
data.raw["pipe-to-ground"]["pipe-to-ground"]
|
||||
.fluid_box.height =
|
||||
(data.raw["pipe-to-ground"]["pipe-to-ground"]
|
||||
.fluid_box.height or 1)/gen_eff
|
||||
|
1
factsheet.lua
Symbolic link
1
factsheet.lua
Symbolic link
@ -0,0 +1 @@
|
||||
../factsheet.lua
|
11
info.json
Normal file
11
info.json
Normal file
@ -0,0 +1,11 @@
|
||||
{
|
||||
"name": "adamo-physics",
|
||||
"version": "1.0.0",
|
||||
"title": "Physics",
|
||||
"author": "adamo",
|
||||
"dependencies": [
|
||||
"base"
|
||||
],
|
||||
"description": "All power is not created equal.",
|
||||
"factorio_version": "0.18"
|
||||
}
|
BIN
thumbnail.png
Normal file
BIN
thumbnail.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 35 KiB |
Loading…
Reference in New Issue
Block a user