forked from mtcontrib/mobs_redo
tweak mob damage function, add {fire=1} weapon damage check
This commit is contained in:
parent
082bf0cf86
commit
9737bde6fb
85
api.lua
85
api.lua
@ -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()
|
||||||
|
1
api.txt
1
api.txt
@ -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
|
||||||
|
Loading…
Reference in New Issue
Block a user