forked from mtcontrib/minetest-mod-snow
play sound when the snowball hurts an object and make damage depend on velocity differrence
This commit is contained in:
parent
d8d79655af
commit
8d78cb6867
@ -8,11 +8,19 @@
|
|||||||
|
|
||||||
local creative_mode = minetest.setting_getbool("creative_mode")
|
local creative_mode = minetest.setting_getbool("creative_mode")
|
||||||
|
|
||||||
local snowball_velocity = snow.snowball_velocity
|
|
||||||
|
local snowball_velocity, entity_attack_delay
|
||||||
|
local function update_snowball_vel(v)
|
||||||
|
snowball_velocity = v
|
||||||
|
local walkspeed = tonumber(minetest.setting_get("movement_speed_walk")) or 4
|
||||||
|
entity_attack_delay = (walkspeed+1)/v
|
||||||
|
end
|
||||||
|
update_snowball_vel(snow.snowball_velocity)
|
||||||
|
|
||||||
local snowball_gravity = snow.snowball_gravity
|
local snowball_gravity = snow.snowball_gravity
|
||||||
snow.register_on_configuring(function(name, v)
|
snow.register_on_configuring(function(name, v)
|
||||||
if name == "snowball_velocity" then
|
if name == "snowball_velocity" then
|
||||||
snowball_velocity = v
|
update_snowball_vel(v)
|
||||||
elseif name == "snowball_gravity" then
|
elseif name == "snowball_gravity" then
|
||||||
snowball_gravity = v
|
snowball_gravity = v
|
||||||
end
|
end
|
||||||
@ -153,34 +161,41 @@ function snow_snowball_ENTITY.on_step(self, dtime)
|
|||||||
--self.object:setvelocity({x=0, y=0, z=0})
|
--self.object:setvelocity({x=0, y=0, z=0})
|
||||||
pos = self.lastpos
|
pos = self.lastpos
|
||||||
self.object:setpos(pos)
|
self.object:setpos(pos)
|
||||||
local gain = vector.length(self.object:getvelocity())/30
|
minetest.sound_play("default_snow_footstep", {pos=pos, gain=vector.length(self.object:getvelocity())/30})
|
||||||
minetest.sound_play("default_snow_footstep", {pos=pos, gain=gain})
|
|
||||||
self.object:set_properties({physical = true})
|
self.object:set_properties({physical = true})
|
||||||
self.physical = true
|
self.physical = true
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
self.lastpos = vector.new(pos)
|
self.lastpos = vector.new(pos)
|
||||||
|
|
||||||
if self.timer > 0.15 then
|
if self.timer < entity_attack_delay then
|
||||||
|
return
|
||||||
|
end
|
||||||
for _,v in pairs(minetest.get_objects_inside_radius(pos, 1.73)) do
|
for _,v in pairs(minetest.get_objects_inside_radius(pos, 1.73)) do
|
||||||
if v ~= self.object then
|
if v ~= self.object then
|
||||||
local entity_name = v:get_entity_name()
|
local entity_name = v:get_entity_name()
|
||||||
if entity_name ~= "snow:snowball_entity"
|
if entity_name ~= "snow:snowball_entity"
|
||||||
and entity_name ~= "__builtin:item"
|
and entity_name ~= "__builtin:item"
|
||||||
and entity_name ~= "gauges:hp_bar" then
|
and entity_name ~= "gauges:hp_bar" then
|
||||||
|
local vvel = v:getvelocity() or v:get_player_velocity()
|
||||||
|
local veldif = self.object:getvelocity()
|
||||||
|
if vvel then
|
||||||
|
veldif = vector.subtract(veldif, vvel)
|
||||||
|
end
|
||||||
|
local gain = vector.length(veldif)/20
|
||||||
v:punch(
|
v:punch(
|
||||||
(self.thrower and minetest.get_player_by_name(self.thrower))
|
(self.thrower and minetest.get_player_by_name(self.thrower))
|
||||||
or self.object,
|
or self.object,
|
||||||
1,
|
1,
|
||||||
{full_punch_interval=1, damage_groups = {fleshy=1}}
|
{full_punch_interval=1, damage_groups = {fleshy=math.ceil(gain)}}
|
||||||
)
|
)
|
||||||
|
minetest.sound_play("default_snow_footstep", {pos=pos, gain=gain})
|
||||||
spawn_falling_node(pos, {name = "default:snow"})
|
spawn_falling_node(pos, {name = "default:snow"})
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user