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

Tweaked mob arrows

This commit is contained in:
TenPlus1 2016-10-08 10:29:32 +01:00
parent 47abff26ae
commit d2806eccf2
2 changed files with 51 additions and 19 deletions

69
api.lua
View File

@ -1,5 +1,5 @@
-- Mobs Api (4th October 2016) -- Mobs Api (8th October 2016)
mobs = {} mobs = {}
mobs.mod = "redo" mobs.mod = "redo"
@ -1770,6 +1770,7 @@ local do_states = function(self, dtime)
local amount = (vec.x * vec.x + vec.y * vec.y + vec.z * vec.z) ^ 0.5 local amount = (vec.x * vec.x + vec.y * vec.y + vec.z * vec.z) ^ 0.5
local v = ent.velocity or 1 -- or set to default local v = ent.velocity or 1 -- or set to default
ent.switch = 1 ent.switch = 1
ent.owner_id = tostring(self.object) -- add unique owner id to arrow
-- offset makes shoot aim accurate -- offset makes shoot aim accurate
vec.y = vec.y + self.shoot_offset vec.y = vec.y + self.shoot_offset
@ -2442,7 +2443,7 @@ function mobs:spawn_specific(name, nodes, neighbors, min_light, max_light,
-- do not spawn if too many active entities in area -- do not spawn if too many active entities in area
if active_object_count_wider >= aoc if active_object_count_wider >= aoc
or not mobs.spawning_mobs[name] then or not mobs.spawning_mobs[name] then
--print ("--- too many entities", name, aoc)
return return
end end
@ -2454,11 +2455,13 @@ function mobs:spawn_specific(name, nodes, neighbors, min_light, max_light,
if tod > 4500 and tod < 19500 then if tod > 4500 and tod < 19500 then
-- daylight, but mob wants night -- daylight, but mob wants night
if day_toggle == false then if day_toggle == false then
--print ("--- mob needs night", name)
return return
end end
else else
-- night time but mob wants day -- night time but mob wants day
if day_toggle == true then if day_toggle == true then
--print ("--- mob needs day", name)
return return
end end
end end
@ -2473,6 +2476,7 @@ function mobs:spawn_specific(name, nodes, neighbors, min_light, max_light,
for n = 1, #objs do for n = 1, #objs do
if objs[n]:is_player() then if objs[n]:is_player() then
--print ("--- player too close", name)
return return
end end
end end
@ -2480,27 +2484,36 @@ function mobs:spawn_specific(name, nodes, neighbors, min_light, max_light,
-- mobs cannot spawn in protected areas when enabled -- mobs cannot spawn in protected areas when enabled
if spawn_protected == 1 if spawn_protected == 1
and minetest.is_protected(pos, "") then and minetest.is_protected(pos, "") then
--print ("--- inside protected area", name)
return return
end end
-- check if light and height levels are ok to spawn -- are light levels ok?
local light = minetest.get_node_light(pos) local light = minetest.get_node_light(pos)
if not light if not light
or light > max_light or light > max_light
or light < min_light or light < min_light then
or pos.y > max_height --print ("--- light limits not met", name, light)
return
end
-- are we spawning within height limits?
if pos.y > max_height
or pos.y < min_height then or pos.y < min_height then
--print ("--- height limits not met", name, pos.y)
return return
end end
-- are we spawning inside solid nodes? -- are we spawning inside solid nodes?
if minetest.registered_nodes[node_ok(pos).name].walkable == true then if minetest.registered_nodes[node_ok(pos).name].walkable == true then
--print ("--- feet in block", name, node_ok(pos).name)
return return
end end
pos.y = pos.y + 1 pos.y = pos.y + 1
if minetest.registered_nodes[node_ok(pos).name].walkable == true then if minetest.registered_nodes[node_ok(pos).name].walkable == true then
--print ("--- head in block", name, node_ok(pos).name)
return return
end end
@ -2652,6 +2665,7 @@ function mobs:register_arrow(name, def)
collisionbox = {0, 0, 0, 0, 0, 0}, -- remove box around arrows collisionbox = {0, 0, 0, 0, 0, 0}, -- remove box around arrows
timer = 0, timer = 0,
switch = 0, switch = 0,
owner_id = def.owner_id,
on_step = def.on_step or function(self, dtime) on_step = def.on_step or function(self, dtime)
@ -2672,15 +2686,31 @@ function mobs:register_arrow(name, def)
if def.tail if def.tail
and def.tail == 1 and def.tail == 1
and def.tail_texture then and def.tail_texture then
effect(pos, 1, def.tail_texture, 10, 0) -- effect(pos, 1, def.tail_texture, 10, 0)
minetest.add_particlespawner({
amount = 1,
time = 0.25,
minpos = pos,
maxpos = pos,
minvel = {x = 0, y = 0, z = 0},
maxvel = {x = 0, y = 0, z = 0},
minacc = {x = 0, y = 0, z = 0},
maxacc = {x = 0, y = 0, z = 0},
minexptime = 0.1,
maxexptime = 1,
minsize = def.tail_size or 5,
maxsize = def.tail_size or 10,
texture = def.tail_texture,
})
end end
if self.hit_node then if self.hit_node then
local node = node_ok(pos).name local node = node_ok(pos).name
--if minetest.registered_nodes[node].walkable then if minetest.registered_nodes[node].walkable then
if node ~= "air" then --if node ~= "air" then
self.hit_node(self, pos, node) self.hit_node(self, pos, node)
@ -2699,9 +2729,7 @@ function mobs:register_arrow(name, def)
end end
end end
if (self.hit_player or self.hit_mob) if self.hit_player or self.hit_mob then
-- clear mob entity before arrow becomes active
and self.timer > (10 - (self.velocity / 2)) then
for _,player in pairs(minetest.get_objects_inside_radius(pos, 1.0)) do for _,player in pairs(minetest.get_objects_inside_radius(pos, 1.0)) do
@ -2713,18 +2741,21 @@ function mobs:register_arrow(name, def)
return return
end end
local entity = player:get_luaentity()
and player:get_luaentity().name or ""
if self.hit_mob if self.hit_mob
and player:get_luaentity() and tostring(player) ~= self.owner_id
and player:get_luaentity().name ~= self.object:get_luaentity().name and entity ~= self.object:get_luaentity().name
and player:get_luaentity().name ~= "__builtin:item" and entity ~= "__builtin:item"
and player:get_luaentity().name ~= "__builtin:falling_node" and entity ~= "__builtin:falling_node"
and player:get_luaentity().name ~= "gauges:hp_bar" and entity ~= "gauges:hp_bar"
and player:get_luaentity().name ~= "signs:text" and entity ~= "signs:text"
and player:get_luaentity().name ~= "itemframes:item" then and entity ~= "itemframes:item" then
self.hit_mob(self, player) self.hit_mob(self, player)
self.object:remove() ; -- print ("hit mob") self.object:remove() ; --print ("hit mob")
return return
end end

View File

@ -189,6 +189,7 @@ This function registers a arrow for mobs with the attack type shoot.
the parameters are (self, pos, node) the parameters are (self, pos, node)
'tail' when set to 1 adds a trail or tail to mob arrows 'tail' when set to 1 adds a trail or tail to mob arrows
'tail_texture' texture string used for above effect 'tail_texture' texture string used for above effect
'tail_size' has size for above texture (defaults to between 5 and 10)
'on_step' is a custom function when arrow is active, nil for default. 'on_step' is a custom function when arrow is active, nil for default.