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

added some node checks and damage returns

This commit is contained in:
TenPlus1 2020-04-27 13:17:20 +01:00
parent f2cc0446b0
commit a934d80631
2 changed files with 78 additions and 30 deletions

105
api.lua
View File

@ -6,7 +6,7 @@ local use_cmi = minetest.global_exists("cmi")
mobs = {
mod = "redo",
version = "20200426",
version = "20200427",
intllib = S,
invis = minetest.global_exists("invisibility") and invisibility or {}
}
@ -835,6 +835,42 @@ function mob_class:check_for_death(cmi_cause)
end
-- get node but use fallback for nil or unknown
local node_ok = function(pos, fallback)
fallback = fallback or mobs.fallback_node
local node = minetest.get_node_or_nil(pos)
if node and minetest.registered_nodes[node.name] then
return node
end
return minetest.registered_nodes[fallback]
end
-- Returns true is node can deal damage to self
local is_node_dangerous = function(self, nodename)
if self.water_damage > 0
and minetest.get_item_group(nodename, "water") ~= 0 then
return true
end
if self.lava_damage > 0
and minetest.get_item_group(nodename, "igniter") ~= 0 then
return true
end
if minetest.registered_nodes[nodename].damage_per_second > 0 then
return true
end
return false
end
-- is mob facing a cliff
function mob_class:is_at_cliff()
@ -853,32 +889,29 @@ function mob_class:is_at_cliff()
local pos = self.object:get_pos()
local ypos = pos.y + self.collisionbox[2] -- just above floor
if minetest.line_of_sight(
local free_fall, blocker = minetest.line_of_sight(
{x = pos.x + dir_x, y = ypos, z = pos.z + dir_z},
{x = pos.x + dir_x, y = ypos - self.fear_height, z = pos.z + dir_z}, 1) then
{x = pos.x + dir_x, y = ypos - self.fear_height, z = pos.z + dir_z})
-- check for straight drop, drop onto danger or walkable node
if free_fall then
return true
else
local bnode = node_ok(blocker)
if is_node_dangerous(self, bnode.name) then
return true
else
local def = minetest.registered_nodes[bnode.name]
return (not def and def.walkable)
end
end
return false
end
-- get node but use fallback for nil or unknown
local node_ok = function(pos, fallback)
fallback = fallback or mobs.fallback_node
local node = minetest.get_node_or_nil(pos)
if node and minetest.registered_nodes[node.name] then
return node
end
return minetest.registered_nodes[fallback]
end
-- environmental damage (water, lava, fire, light etc.)
function mob_class:do_env_damage()
@ -1032,6 +1065,18 @@ function mob_class:do_jump()
z = pos.z + dir_z
})
-- what is above and in front?
local nodt = node_ok({
x = pos.x + dir_x,
y = pos.y + 1.5,
z = pos.z + dir_z
})
-- is there space to jump up?
if minetest.registered_nodes[nodt.name].walkable == true then
return false
end
-- thin blocks that do not need to be jumped
if nod.name == node_snow then
return false
@ -1043,7 +1088,8 @@ function mob_class:do_jump()
or minetest.registered_items[nod.name].walkable then
if not nod.name:find("fence")
and not nod.name:find("gate") then
and not nod.name:find("gate")
and not nod.name:find("wall") then
local v = self.object:get_velocity()
@ -1071,6 +1117,8 @@ function mob_class:do_jump()
end
else
self.facing_fence = true
return false
end
-- if we jumped against a block/wall 4 times then turn
@ -2060,7 +2108,7 @@ function mob_class:do_states(dtime)
if self.water_damage > 0
and self.lava_damage > 0 then
lp = minetest.find_node_near(s, 1, {"group:water", "group:lava"})
lp = minetest.find_node_near(s, 1, {"group:water", "group:igniter"})
elseif self.water_damage > 0 then
@ -2068,16 +2116,13 @@ function mob_class:do_states(dtime)
elseif self.lava_damage > 0 then
lp = minetest.find_node_near(s, 1, {"group:lava"})
lp = minetest.find_node_near(s, 1, {"group:igniter"})
end
if lp then
-- if mob in water or lava then look for land
if (self.lava_damage
and minetest.registered_nodes[self.standing_in].groups.lava)
or (self.water_damage
and minetest.registered_nodes[self.standing_in].groups.water) then
-- if mob in dangerous node then look for land
if is_node_dangerous(self, self.standing_in) then
lp = minetest.find_node_near(s, 5, {"group:soil", "group:stone",
"group:sand", node_ice, node_snowblock})
@ -2591,7 +2636,7 @@ function mob_class:falling(pos)
effect(pos, 5, "tnt_smoke.png", 1, 2, 2, nil)
if self:check_for_death({type = "fall"}) then
return
return true
end
end
@ -3173,8 +3218,10 @@ function mob_class:on_step(dtime)
self:mob_expire(pos, 0.25)
end
-- check if falling, flying, floating
self:falling(pos)
-- check if falling, flying, floating and return if player died
if self:falling(pos) then
return
end
-- smooth rotation by ThomasMonroe314

View File

@ -23,7 +23,8 @@ Lucky Blocks: 9
Changelog:
- 1.50 - Added new line_of_sight function that uses raycasting if mt5.0 is found (thanks Astrobe), dont spawn mobs if world anchor nearby (technic or simple_anchor mods), chinese local added
- 1.51 - Added some node checks for dangerous nodes, jumping and falling (thx for idea wuzzy)
- 1.50 - Added new line_of_sight function that uses raycasting if mt5.0 is found, (thanks Astrobe), dont spawn mobs if world anchor nearby (technic or simple_anchor mods), chinese local added
- 1.49- Added mobs:force_capture(self, player) function, api functions now use metatables thanks to bell07
- 1.48- Add mobs:set_velocity(self, velocity) global function
- 1.47- Mob damage changes, min and max light level for damage added, ignition sources checked for lava damage