mirror of
https://codeberg.org/tenplus1/mobs_redo.git
synced 2025-01-23 16:00:16 +01:00
tweak loudness calculation for mod hearing
This commit is contained in:
parent
1f6867bf25
commit
57d6859b93
42
api.lua
42
api.lua
@ -21,7 +21,7 @@ end
|
|||||||
-- Global
|
-- Global
|
||||||
mobs = {
|
mobs = {
|
||||||
mod = "redo",
|
mod = "redo",
|
||||||
version = "20240803",
|
version = "20240804",
|
||||||
translate = S,
|
translate = S,
|
||||||
invis = minetest.global_exists("invisibility") and invisibility or {},
|
invis = minetest.global_exists("invisibility") and invisibility or {},
|
||||||
node_snow = has(minetest.registered_aliases["mapgen_snow"])
|
node_snow = has(minetest.registered_aliases["mapgen_snow"])
|
||||||
@ -5055,41 +5055,42 @@ local old_sound_play = minetest.sound_play
|
|||||||
|
|
||||||
minetest.sound_play = function(spec, param, eph)
|
minetest.sound_play = function(spec, param, eph)
|
||||||
|
|
||||||
local op_params = {type = "sound"} ; param = param or {}
|
local def = {} ; param = param or {}
|
||||||
|
|
||||||
-- store sound position
|
-- store sound position
|
||||||
if param.pos then
|
if param.pos then
|
||||||
op_params.pos = param.pos
|
def.pos = param.pos
|
||||||
elseif param.object then
|
elseif param.object then
|
||||||
op_params.pos = param.object:get_pos()
|
def.pos = param.object:get_pos()
|
||||||
elseif param.to_player then
|
elseif param.to_player then
|
||||||
op_params.pos = minetest.get_player_by_name(param.to_player):get_pos()
|
def.pos = minetest.get_player_by_name(param.to_player):get_pos()
|
||||||
end
|
end
|
||||||
|
|
||||||
-- if no position found use default function
|
-- if no position found use default function
|
||||||
if not op_params.pos then
|
if not def.pos then
|
||||||
return old_sound_play(spec, param, eph)
|
return old_sound_play(spec, param, eph)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- store sound name and gain
|
-- store sound name and gain
|
||||||
if type(spec) == "string" then
|
if type(spec) == "string" then
|
||||||
op_params.sound = spec
|
def.sound = spec
|
||||||
op_params.gain = param.gain or 1.0
|
def.gain = param.gain or 1.0
|
||||||
elseif type(spec) == "table" then
|
elseif type(spec) == "table" then
|
||||||
op_params.sound = spec.name
|
def.sound = spec.name
|
||||||
op_params.gain = spec.gain or param.gain or 1.0
|
def.gain = spec.gain or param.gain or 1.0
|
||||||
end
|
end
|
||||||
|
|
||||||
-- store player name or object reference
|
-- store player name or object reference
|
||||||
if param.to_player then
|
if param.to_player then
|
||||||
op_params.player = param.to_player
|
def.player = param.to_player
|
||||||
elseif param.object then
|
elseif param.object then
|
||||||
op_params.object = param.object
|
def.object = param.object
|
||||||
end
|
end
|
||||||
|
|
||||||
-- find mobs within sounds max_hear_distance
|
def.max_hear_distance = param.max_hear_distance or 32
|
||||||
local objs = minetest.get_objects_inside_radius(op_params.pos,
|
|
||||||
param.max_hear_distance or 32)
|
-- find mobs within sounds hearing range
|
||||||
|
local objs = minetest.get_objects_inside_radius(def.pos, def.max_hear_distance)
|
||||||
|
|
||||||
for n = 1, #objs do
|
for n = 1, #objs do
|
||||||
|
|
||||||
@ -5102,11 +5103,16 @@ minetest.sound_play = function(spec, param, eph)
|
|||||||
if ent and ent._cmi_is_mob and ent.on_sound then
|
if ent and ent._cmi_is_mob and ent.on_sound then
|
||||||
|
|
||||||
-- calculate loudness of sound to mob
|
-- calculate loudness of sound to mob
|
||||||
op_params.distance = get_distance(op_params.pos, obj:get_pos())
|
def.distance = get_distance(def.pos, obj:get_pos())
|
||||||
op_params.loudness = op_params.gain / op_params.distance
|
|
||||||
|
local bit = def.gain / def.max_hear_distance
|
||||||
|
local rem = def.max_hear_distance - def.distance
|
||||||
|
|
||||||
|
-- loudness ranges from 0 (cannot hear) to 1.0 (close to source)
|
||||||
|
def.loudness = (bit * rem) / def.gain
|
||||||
|
|
||||||
-- run custom on_sound function
|
-- run custom on_sound function
|
||||||
ent.on_sound(ent, op_params)
|
ent.on_sound(ent, def)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
8
api.txt
8
api.txt
@ -348,12 +348,14 @@ enhance mob functionality and have them do many interesting things:
|
|||||||
'on_sound' (self, def) called when mob is inside the hearing distance of
|
'on_sound' (self, def) called when mob is inside the hearing distance of
|
||||||
a sound, passes a def table containing:
|
a sound, passes a def table containing:
|
||||||
'sound' the sound being played,
|
'sound' the sound being played,
|
||||||
'pos' position sound originated,
|
'pos' position the sound originated,
|
||||||
'gain' original gain of sound,
|
'gain' original gain of sound,
|
||||||
'distance' distance of mob from sound source,
|
'distance' distance of mob from sound source,
|
||||||
'loudness' how loud sound is to mob when calculating gain / distance,
|
'loudness' how loud sound is to mob (0 = cant hear, 1.0 = near sound), this
|
||||||
|
would be used as the main value inside on_sound function,
|
||||||
'player' player name sound originated,
|
'player' player name sound originated,
|
||||||
'object' object reference sound originated
|
'object' object reference sound originated,
|
||||||
|
'max_hear_distance' max distance sound can be heard from source.
|
||||||
|
|
||||||
|
|
||||||
Internal Variables
|
Internal Variables
|
||||||
|
Loading…
Reference in New Issue
Block a user