mirror of
https://github.com/minetest-mods/technic.git
synced 2025-01-05 04:07:34 +01:00
Made radiation configurable
This commit is contained in:
parent
51be33deea
commit
b739ed6cb1
@ -9,6 +9,8 @@ local defaults = {
|
|||||||
enable_wind_mill = "false",
|
enable_wind_mill = "false",
|
||||||
enable_frames = "false",
|
enable_frames = "false",
|
||||||
enable_corium_griefing = "true",
|
enable_corium_griefing = "true",
|
||||||
|
enable_entity_radiation_damage = "true",
|
||||||
|
enable_longterm_radiation_damage = "true",
|
||||||
}
|
}
|
||||||
|
|
||||||
for k, v in pairs(defaults) do
|
for k, v in pairs(defaults) do
|
||||||
|
@ -242,6 +242,9 @@ local cache_scaled_shielding = {}
|
|||||||
local rad_dmg_cutoff = 0.2
|
local rad_dmg_cutoff = 0.2
|
||||||
local radiated_players = {}
|
local radiated_players = {}
|
||||||
|
|
||||||
|
local entity_damage = technic.config:get_bool("enable_entity_radiation_damage")
|
||||||
|
local longterm_damage = technic.config:get_bool("enable_longterm_radiation_damage")
|
||||||
|
|
||||||
local function apply_fractional_damage(o, dmg)
|
local function apply_fractional_damage(o, dmg)
|
||||||
local dmg_int = math.floor(dmg)
|
local dmg_int = math.floor(dmg)
|
||||||
-- The closer you are to getting one more damage point,
|
-- The closer you are to getting one more damage point,
|
||||||
@ -297,17 +300,17 @@ end
|
|||||||
|
|
||||||
local function dmg_object(pos, object, strength)
|
local function dmg_object(pos, object, strength)
|
||||||
local obj_pos = vector.add(object:getpos(), calculate_object_center(object))
|
local obj_pos = vector.add(object:getpos(), calculate_object_center(object))
|
||||||
local dmg = calculate_base_damage(pos, obj_pos, strength)
|
|
||||||
if not dmg then
|
|
||||||
return
|
|
||||||
end
|
|
||||||
local mul = calculate_damage_multiplier(object)
|
local mul = calculate_damage_multiplier(object)
|
||||||
if mul == 0 then
|
if mul == 0 then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
local dmg = calculate_base_damage(pos, obj_pos, strength)
|
||||||
|
if not dmg then
|
||||||
|
return
|
||||||
|
end
|
||||||
dmg = dmg * mul
|
dmg = dmg * mul
|
||||||
apply_fractional_damage(object, dmg)
|
apply_fractional_damage(object, dmg)
|
||||||
if object:is_player() then
|
if longterm_damage and object:is_player() then
|
||||||
local pn = object:get_player_name()
|
local pn = object:get_player_name()
|
||||||
radiated_players[pn] = (radiated_players[pn] or 0) + dmg
|
radiated_players[pn] = (radiated_players[pn] or 0) + dmg
|
||||||
end
|
end
|
||||||
@ -319,9 +322,11 @@ local function dmg_abm(pos, node)
|
|||||||
local max_dist = strength * rad_dmg_mult_sqrt
|
local max_dist = strength * rad_dmg_mult_sqrt
|
||||||
for _, o in pairs(minetest.get_objects_inside_radius(pos,
|
for _, o in pairs(minetest.get_objects_inside_radius(pos,
|
||||||
max_dist + abdomen_offset)) do
|
max_dist + abdomen_offset)) do
|
||||||
|
if entity_damage or o:is_player() then
|
||||||
dmg_object(pos, o, strength)
|
dmg_object(pos, o, strength)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
if minetest.setting_getbool("enable_damage") then
|
if minetest.setting_getbool("enable_damage") then
|
||||||
minetest.register_abm({
|
minetest.register_abm({
|
||||||
@ -331,6 +336,7 @@ if minetest.setting_getbool("enable_damage") then
|
|||||||
action = dmg_abm,
|
action = dmg_abm,
|
||||||
})
|
})
|
||||||
|
|
||||||
|
if longterm_damage then
|
||||||
minetest.register_globalstep(function(dtime)
|
minetest.register_globalstep(function(dtime)
|
||||||
for pn, dmg in pairs(radiated_players) do
|
for pn, dmg in pairs(radiated_players) do
|
||||||
dmg = dmg - (dtime / 8)
|
dmg = dmg - (dtime / 8)
|
||||||
@ -352,6 +358,7 @@ if minetest.setting_getbool("enable_damage") then
|
|||||||
radiated_players[player:get_player_name()] = nil
|
radiated_players[player:get_player_name()] = nil
|
||||||
end)
|
end)
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
-- Radioactive materials that can result from destroying a reactor
|
-- Radioactive materials that can result from destroying a reactor
|
||||||
local griefing = technic.config:get_bool("enable_corium_griefing")
|
local griefing = technic.config:get_bool("enable_corium_griefing")
|
||||||
|
Loading…
Reference in New Issue
Block a user