1
0
mirror of https://codeberg.org/tenplus1/mobs_redo.git synced 2025-01-11 18:30:21 +01:00

tweak mob damage function, add {fire=1} weapon damage check

This commit is contained in:
TenPlus1 2018-09-05 10:33:17 +01:00
parent 082bf0cf86
commit 9737bde6fb
2 changed files with 75 additions and 95 deletions

85
api.lua
View File

@ -6,7 +6,7 @@ local use_cmi = minetest.global_exists("cmi")
mobs = { mobs = {
mod = "redo", mod = "redo",
version = "20180904", version = "20180905",
intllib = S, intllib = S,
invis = minetest.global_exists("invisibility") and invisibility or {}, invis = minetest.global_exists("invisibility") and invisibility or {},
} }
@ -2292,19 +2292,16 @@ local tr = minetest.get_modpath("toolranks")
-- deal damage and effects when mob punched -- deal damage and effects when mob punched
local mob_punch = function(self, hitter, tflp, tool_capabilities, dir) local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
-- custom punch function -- mob health check
if self.do_punch then if self.health <= 0 then
-- when false skip going any further
if self.do_punch(self, hitter, tflp, tool_capabilities, dir) == false then
return return
end end
end
-- mob health check -- custom punch function
-- if self.health <= 0 then if self.do_punch
-- return and self.do_punch(self, hitter, tflp, tool_capabilities, dir) == false then
-- end return
end
-- error checking when mod profiling is enabled -- error checking when mod profiling is enabled
if not tool_capabilities then if not tool_capabilities then
@ -2319,9 +2316,8 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
return return
end end
-- weapon wear
local weapon = hitter:get_wielded_item() local weapon = hitter:get_wielded_item()
local weapon_def = weapon:get_definition() or {}
local punch_interval = 1.4 local punch_interval = 1.4
-- calculate mob damage -- calculate mob damage
@ -2356,7 +2352,7 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
-- check for tool immunity or special damage -- check for tool immunity or special damage
for n = 1, #self.immune_to do for n = 1, #self.immune_to do
if self.immune_to[n][1] == weapon:get_name() then if self.immune_to[n][1] == weapon_def.name then
damage = self.immune_to[n][2] or 0 damage = self.immune_to[n][2] or 0
break break
@ -2375,20 +2371,13 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
-- print ("Mob Damage is", damage) -- print ("Mob Damage is", damage)
if use_cmi then if use_cmi
and cmi.notify_punch(self.object, hitter, tflp, tool_capabilities, dir, damage) then
local cancel = cmi.notify_punch(self.object, hitter, tflp, tool_capabilities, dir, damage) return
if cancel then return end
end end
-- add weapon wear -- add weapon wear
if tool_capabilities then
punch_interval = tool_capabilities.full_punch_interval or 1.4 punch_interval = tool_capabilities.full_punch_interval or 1.4
end
if weapon:get_definition()
and weapon:get_definition().tool_capabilities then
-- toolrank support -- toolrank support
local wear = floor((punch_interval / 75) * 9000) local wear = floor((punch_interval / 75) * 9000)
@ -2403,8 +2392,7 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
end end
if tr then if tr then
if weapon:get_definition() if weapon_def.original_description then
and weapon:get_definition().original_description then
weapon:add_wear(toolranks.new_afteruse(weapon, hitter, nil, {wear = wear})) weapon:add_wear(toolranks.new_afteruse(weapon, hitter, nil, {wear = wear}))
end end
else else
@ -2412,30 +2400,28 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
end end
hitter:set_wielded_item(weapon) hitter:set_wielded_item(weapon)
end
-- only play hit sound and show blood effects if damage is 1 or over -- only play hit sound and show blood effects if damage is 1 or over
if damage >= 1 then if damage >= 1 then
-- weapon sounds -- weapon sounds
if weapon:get_definition().sounds ~= nil then if weapon_def.sounds then
local s = random(0, #weapon:get_definition().sounds) local s = random(0, #weapon_def.sounds)
minetest.sound_play(weapon:get_definition().sounds[s], { minetest.sound_play(weapon_def.sounds[s], {
object = self.object, --hitter, object = self.object,
max_hear_distance = 8 max_hear_distance = 8
}) })
else else
minetest.sound_play("default_punch", { minetest.sound_play("default_punch", {
object = self.object, --hitter, object = self.object,
max_hear_distance = 5 max_hear_distance = 5
}) })
end end
-- blood_particles -- blood_particles
if self.blood_amount > 0 if not disable_blood and self.blood_amount > 0 then
and not disable_blood then
local pos = self.object:get_pos() local pos = self.object:get_pos()
@ -2455,18 +2441,14 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
-- do damage -- do damage
self.health = self.health - floor(damage) self.health = self.health - floor(damage)
-- exit here if dead, special item check -- exit here if dead, check for tools with fire damage
if weapon:get_name() == "mobs:pick_lava" then local hot = tool_capabilities and tool_capabilities.damage_groups
and tool_capabilities.damage_groups.fire
if check_for_death(self, "hit", {type = "punch", if check_for_death(self, "hit", {type = "punch",
puncher = hitter, hot = true}) then puncher = hitter, hot = hot}) then
return return
end end
else
if check_for_death(self, "hit", {type = "punch",
puncher = hitter}) then
return
end
end
--[[ add healthy afterglow when hit (can cause hit lag with larger textures) --[[ add healthy afterglow when hit (can cause hit lag with larger textures)
minetest.after(0.1, function() minetest.after(0.1, function()
@ -2480,13 +2462,14 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
end) end)
end) ]] end) ]]
end -- END if damage
-- knock back effect (only on full punch) -- knock back effect (only on full punch)
if self.knock_back if self.knock_back
and tflp >= punch_interval then and tflp >= punch_interval then
local v = self.object:get_velocity() local v = self.object:get_velocity()
local r = 1.4 - min(punch_interval, 1.4) local kb = damage or 1
local kb = r * 5
local up = 2 local up = 2
-- if already in air then dont go up anymore when hit -- if already in air then dont go up anymore when hit
@ -2498,12 +2481,8 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
-- direction error check -- direction error check
dir = dir or {x = 0, y = 0, z = 0} dir = dir or {x = 0, y = 0, z = 0}
-- check if tool already has specific knockback value -- use tool knockback value or default
if tool_capabilities.damage_groups["knockback"] then kb = tool_capabilities.damage_groups["knockback"] or (kb * 1.5)
kb = tool_capabilities.damage_groups["knockback"]
else
kb = kb * 1.5
end
self.object:set_velocity({ self.object:set_velocity({
x = dir.x * kb, x = dir.x * kb,
@ -2513,10 +2492,10 @@ local mob_punch = function(self, hitter, tflp, tool_capabilities, dir)
self.pause_timer = 0.25 self.pause_timer = 0.25
end end
end -- END if damage
-- if skittish then run away -- if skittish then run away
if self.runaway == true then if self.runaway == true
and self.order ~= "stand" then
local lp = hitter:get_pos() local lp = hitter:get_pos()
local s = self.object:get_pos() local s = self.object:get_pos()

View File

@ -148,6 +148,7 @@ functions needed for the mob to work properly which contains the following:
'chance' chance of drop, 1 for always, 2 for 1-in-2 chance etc. 'chance' chance of drop, 1 for always, 2 for 1-in-2 chance etc.
'min' minimum number of items dropped, set to 0 for rare drops. 'min' minimum number of items dropped, set to 0 for rare drops.
'max' maximum number of items dropped. 'max' maximum number of items dropped.
Note: If weapon has {fire=1} damage group set then cooked items will drop.
'visual' holds the look of the mob you wish to create: 'visual' holds the look of the mob you wish to create:
'cube' looks like a normal node 'cube' looks like a normal node