mirror of
https://github.com/technix/ham_radio.git
synced 2024-12-04 12:53:43 +01:00
better formula for signal power; hud update
This commit is contained in:
parent
a05da6469e
commit
064a4d3cb8
31
hud.lua
31
hud.lua
@ -7,10 +7,10 @@ function ham_radio.toggle_hud(player)
|
|||||||
if item:get_name() ~= "ham_radio:receiver" then
|
if item:get_name() ~= "ham_radio:receiver" then
|
||||||
if ham_radio.is_receiver_wielded[name] then
|
if ham_radio.is_receiver_wielded[name] then
|
||||||
player:hud_remove(ham_radio.playerhuds[name].background)
|
player:hud_remove(ham_radio.playerhuds[name].background)
|
||||||
player:hud_remove(ham_radio.playerhuds[name].frequency)
|
player:hud_remove(ham_radio.playerhuds[name].frequency)
|
||||||
player:hud_remove(ham_radio.playerhuds[name].signal_meter)
|
player:hud_remove(ham_radio.playerhuds[name].signal_meter)
|
||||||
player:hud_remove(ham_radio.playerhuds[name].signal_level)
|
player:hud_remove(ham_radio.playerhuds[name].signal_level)
|
||||||
ham_radio.is_receiver_wielded[name] = false
|
ham_radio.is_receiver_wielded[name] = false
|
||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
@ -31,14 +31,14 @@ function ham_radio.toggle_hud(player)
|
|||||||
position = hud_pos,
|
position = hud_pos,
|
||||||
offset = { x = -250, y = 20 },
|
offset = { x = -250, y = 20 },
|
||||||
text = "ham_radio_hud_bg.png",
|
text = "ham_radio_hud_bg.png",
|
||||||
scale = { x = 2, y = 3 },
|
scale = { x = 2, y = 2 },
|
||||||
alignment = { x = 1, y = 0 },
|
alignment = { x = 1, y = 0 },
|
||||||
}),
|
}),
|
||||||
frequency = player:hud_add({
|
frequency = player:hud_add({
|
||||||
hud_elem_type = "text",
|
hud_elem_type = "text",
|
||||||
text = "",
|
text = "",
|
||||||
position = hud_pos,
|
position = hud_pos,
|
||||||
offset = { x = 0, y = 0 },
|
offset = { x = 0, y = 5 },
|
||||||
alignment = 0,
|
alignment = 0,
|
||||||
number = 0xFFFFFF,
|
number = 0xFFFFFF,
|
||||||
scale= { x = 100, y = 20 },
|
scale= { x = 100, y = 20 },
|
||||||
@ -46,17 +46,17 @@ function ham_radio.toggle_hud(player)
|
|||||||
signal_meter = player:hud_add({
|
signal_meter = player:hud_add({
|
||||||
hud_elem_type = "image",
|
hud_elem_type = "image",
|
||||||
position = hud_pos,
|
position = hud_pos,
|
||||||
offset = { x = -220, y = 30 },
|
offset = { x = -220, y = 35 },
|
||||||
text = "ham_radio_hud_indicator_empty.png",
|
text = "ham_radio_hud_indicator_empty.png",
|
||||||
scale = { x = 2, y = 2 },
|
scale = { x = 2, y = 1 },
|
||||||
alignment = { x = 1, y = 0 },
|
alignment = { x = 1, y = 0 },
|
||||||
}),
|
}),
|
||||||
signal_level = player:hud_add({
|
signal_level = player:hud_add({
|
||||||
hud_elem_type = "image",
|
hud_elem_type = "image",
|
||||||
position = hud_pos,
|
position = hud_pos,
|
||||||
offset = { x = -220, y = 30 },
|
offset = { x = -220, y = 35 },
|
||||||
text = "ham_radio_hud_indicator_full.png",
|
text = "ham_radio_hud_indicator_full.png",
|
||||||
scale = { x = 0, y = 2 },
|
scale = { x = 0, y = 1 },
|
||||||
alignment = { x = 1, y = 0 },
|
alignment = { x = 1, y = 0 },
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
@ -77,20 +77,17 @@ function ham_radio:update_hud_display(player)
|
|||||||
|
|
||||||
if frequency ~= nil and frequency ~= "" then
|
if frequency ~= nil and frequency ~= "" then
|
||||||
local transmitter = self.read_transmitter(frequency)
|
local transmitter = self.read_transmitter(frequency)
|
||||||
-- minetest.chat_send_player(player:get_player_name(), "Found transmitter:"..minetest.serialize(transmitter))
|
|
||||||
if transmitter.pos then
|
if transmitter.pos then
|
||||||
transmitter_signal = self:locate_transmitter(player, transmitter.pos)
|
transmitter_signal = self:locate_transmitter(player, transmitter.pos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- local target_pos = {x=-407, y = 59, z = 70}
|
local text = "FQ "..tostring(meta:get_string("frequency"))
|
||||||
|
|
||||||
--local indicator = string.rep('|', transmitter.distance)..string.rep('|', transmitter.signal)..string.rep(':', 25-(transmitter.distance + transmitter.signal))
|
|
||||||
local indicator = string.rep('|', transmitter_signal)..string.rep(':', 20 - transmitter_signal)
|
|
||||||
|
|
||||||
--local text = "[ Frequency: "..tostring(meta:get_string("frequency")).." ]"..indicator
|
|
||||||
local text = "[ Frequency: "..tostring(meta:get_string("frequency")).." ]"
|
|
||||||
player:hud_change(self.playerhuds[name].frequency, "text", text)
|
player:hud_change(self.playerhuds[name].frequency, "text", text)
|
||||||
player:hud_change(self.playerhuds[name].signal_level, "scale", { x = (transmitter_signal * 20) / 200 or 0.1, y = 2 })
|
player:hud_change(
|
||||||
|
self.playerhuds[name].signal_level,
|
||||||
|
"scale",
|
||||||
|
{ x = transmitter_signal/50 or 0.1, y = 1 } -- x scale should be 0-2
|
||||||
|
)
|
||||||
end
|
end
|
||||||
|
|
||||||
minetest.register_on_newplayer(ham_radio.toggle_hud)
|
minetest.register_on_newplayer(ham_radio.toggle_hud)
|
||||||
|
25
receiver.lua
25
receiver.lua
@ -38,18 +38,23 @@ function ham_radio:locate_transmitter(player, transmitter_pos)
|
|||||||
local player_look_vector = player:get_look_dir()
|
local player_look_vector = player:get_look_dir()
|
||||||
local player_direction = vector.add(player_pos, player_look_vector)
|
local player_direction = vector.add(player_pos, player_look_vector)
|
||||||
|
|
||||||
local distance = vector.distance(player_pos, transmitter_pos)
|
local coeff = 0.9
|
||||||
|
local distance_to_target = 0
|
||||||
|
|
||||||
-- local distance_to_target = 13 - math.floor(math.log(distance*30))
|
local distance = vector.distance(player_pos, transmitter_pos)
|
||||||
local distance_to_target = 24 - math.floor(2 * math.log(distance*10))
|
if distance < 3 then
|
||||||
|
distance_to_target = 100
|
||||||
|
coeff = 0.99
|
||||||
|
else
|
||||||
|
distance_to_target = -0.0000000001*math.pow(distance,3)+0.00000145*math.pow(distance,2)-0.03*distance+100
|
||||||
|
if distance_to_target < 3 then
|
||||||
|
distance_to_target = 3
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
local distance2 = vector.distance(player_direction, transmitter_pos)
|
local distance2 = vector.distance(player_direction, transmitter_pos)
|
||||||
local signal_power = 1 - ((1 + distance2 - distance) / 2)
|
local signal_power = distance - distance2;
|
||||||
|
|
||||||
return math.floor(distance_to_target * signal_power);
|
-- 0-100
|
||||||
|
return distance_to_target * coeff + distance_to_target * (1 - coeff) * signal_power;
|
||||||
--return {
|
|
||||||
-- distance = distance_to_target,
|
|
||||||
-- signal = signal_power
|
|
||||||
-- }
|
|
||||||
end
|
end
|
||||||
|
Loading…
Reference in New Issue
Block a user