mirror of
https://codeberg.org/tenplus1/mobs_redo.git
synced 2025-01-09 09:20:21 +01:00
wee tidy
This commit is contained in:
parent
c8e91d1958
commit
219d477c2a
46
api.lua
46
api.lua
@ -19,7 +19,7 @@ end
|
|||||||
|
|
||||||
mobs = {
|
mobs = {
|
||||||
mod = "redo",
|
mod = "redo",
|
||||||
version = "20241219",
|
version = "20241220",
|
||||||
spawning_mobs = {},
|
spawning_mobs = {},
|
||||||
translate = S,
|
translate = S,
|
||||||
node_snow = has(minetest.registered_aliases["mapgen_snow"])
|
node_snow = has(minetest.registered_aliases["mapgen_snow"])
|
||||||
@ -233,8 +233,7 @@ function mob_class:do_attack(player, force)
|
|||||||
|
|
||||||
if self.state == "attack" and not force then return end
|
if self.state == "attack" and not force then return end
|
||||||
|
|
||||||
self.attack = player
|
self.attack = player ; self.state = "attack"
|
||||||
self.state = "attack"
|
|
||||||
|
|
||||||
if random(100) < 90 then self:mob_sound(self.sounds.war_cry) end
|
if random(100) < 90 then self:mob_sound(self.sounds.war_cry) end
|
||||||
end
|
end
|
||||||
@ -528,24 +527,21 @@ function mobs:yaw_to_pos(self, target, rot) -- [deprecated]
|
|||||||
return self:yaw_to_pos(target, rot)
|
return self:yaw_to_pos(target, rot)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- if stay near set then periodically check for nodes and turn towards them
|
-- if stay near set then periodically check for nodes and move towards them
|
||||||
|
|
||||||
function mob_class:do_stay_near()
|
function mob_class:do_stay_near()
|
||||||
|
|
||||||
if not self.stay_near then return false end
|
if not self.stay_near then return false end
|
||||||
|
|
||||||
local pos = self.object:get_pos()
|
local pos = self.object:get_pos()
|
||||||
local searchnodes = self.stay_near[1]
|
|
||||||
local chance = self.stay_near[2] or 10
|
local chance = self.stay_near[2] or 10
|
||||||
|
|
||||||
if not pos or random(chance) > 1 then return false end
|
if not pos or random(chance) > 1 then return false end
|
||||||
|
|
||||||
if type(searchnodes) == "string" then searchnodes = {self.stay_near[1]} end
|
|
||||||
|
|
||||||
local r = self.view_range
|
local r = self.view_range
|
||||||
local nearby_nodes = minetest.find_nodes_in_area(
|
local nearby_nodes = minetest.find_nodes_in_area(
|
||||||
{x = pos.x - r, y = pos.y - 1, z = pos.z - r},
|
{x = pos.x - r, y = pos.y - 1, z = pos.z - r},
|
||||||
{x = pos.x + r, y = pos.y + 1, z = pos.z + r}, searchnodes)
|
{x = pos.x + r, y = pos.y + 1, z = pos.z + r}, self.stay_near[1])
|
||||||
|
|
||||||
if #nearby_nodes < 1 then return false end
|
if #nearby_nodes < 1 then return false end
|
||||||
|
|
||||||
@ -601,8 +597,7 @@ function mob_class:update_tag(newname)
|
|||||||
|
|
||||||
-- backwards compatibility
|
-- backwards compatibility
|
||||||
if self.nametag and self.nametag ~= "" then
|
if self.nametag and self.nametag ~= "" then
|
||||||
newname = self.nametag
|
newname = self.nametag ; self.nametag = nil
|
||||||
self.nametag = nil
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if newname or (self._nametag and self._nametag ~= "") then
|
if newname or (self._nametag and self._nametag ~= "") then
|
||||||
@ -610,18 +605,12 @@ function mob_class:update_tag(newname)
|
|||||||
self._nametag = newname or self._nametag -- adopt new name if one found
|
self._nametag = newname or self._nametag -- adopt new name if one found
|
||||||
|
|
||||||
-- choose tag colour depending on mob health
|
-- choose tag colour depending on mob health
|
||||||
if self.health <= qua then
|
if self.health <= qua then self.nametag_col = "#FF0000"
|
||||||
self.nametag_col = "#FF0000"
|
elseif self.health <= (qua * 2) then self.nametag_col = "#FF7A00"
|
||||||
elseif self.health <= (qua * 2) then
|
elseif self.health <= (qua * 3) then self.nametag_col = "#FFB500"
|
||||||
self.nametag_col = "#FF7A00"
|
elseif self.health <= (qua * 4) then self.nametag_col = "#FFFF00"
|
||||||
elseif self.health <= (qua * 3) then
|
elseif self.health <= (qua * 5) then self.nametag_col = "#B4FF00"
|
||||||
self.nametag_col = "#FFB500"
|
elseif self.health > (qua * 5) then self.nametag_col = "#00FF00"
|
||||||
elseif self.health <= (qua * 4) then
|
|
||||||
self.nametag_col = "#FFFF00"
|
|
||||||
elseif self.health <= (qua * 5) then
|
|
||||||
self.nametag_col = "#B4FF00"
|
|
||||||
elseif self.health > (qua * 5) then
|
|
||||||
self.nametag_col = "#00FF00"
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if self._nametag ~= old_nametag or self.nametag_col ~= old_nametag_color then
|
if self._nametag ~= old_nametag or self.nametag_col ~= old_nametag_color then
|
||||||
@ -1818,8 +1807,7 @@ function mob_class:general_attack()
|
|||||||
dist = get_distance(p, s)
|
dist = get_distance(p, s)
|
||||||
|
|
||||||
-- aim higher to make looking up hills more realistic
|
-- aim higher to make looking up hills more realistic
|
||||||
p.y = p.y + 1
|
p.y = p.y + 1 ; sp.y = sp.y + 1
|
||||||
sp.y = sp.y + 1
|
|
||||||
|
|
||||||
-- choose closest player to attack that isnt self
|
-- choose closest player to attack that isnt self
|
||||||
if dist ~= 0 and dist < min_dist
|
if dist ~= 0 and dist < min_dist
|
||||||
@ -1877,8 +1865,7 @@ function mob_class:do_runaway_from()
|
|||||||
p = player and player:get_pos() or s
|
p = player and player:get_pos() or s
|
||||||
|
|
||||||
-- aim higher to make looking up hills more realistic
|
-- aim higher to make looking up hills more realistic
|
||||||
p.y = p.y + 1
|
p.y = p.y + 1 ; sp.y = sp.y + 1
|
||||||
sp.y = sp.y + 1
|
|
||||||
|
|
||||||
dist = get_distance(p, s)
|
dist = get_distance(p, s)
|
||||||
|
|
||||||
@ -2060,7 +2047,7 @@ function mob_class:do_states(dtime)
|
|||||||
{x = s.x + 7, y = s.y + 1.0, z = s.z + 7},
|
{x = s.x + 7, y = s.y + 1.0, z = s.z + 7},
|
||||||
{"group:cracky", "group:crumbly", "group:choppy", "group:solid"})
|
{"group:cracky", "group:crumbly", "group:choppy", "group:solid"})
|
||||||
|
|
||||||
-- did we find land ? if so face random block to climb onto
|
-- did we find land ? if so move towards random block to climb onto
|
||||||
if #lp > 0 then
|
if #lp > 0 then
|
||||||
|
|
||||||
yaw = self:yaw_to_pos( lp[random(#lp)] )
|
yaw = self:yaw_to_pos( lp[random(#lp)] )
|
||||||
@ -4615,10 +4602,7 @@ function mobs:alias_mob(old_name, new_name)
|
|||||||
-- entity
|
-- entity
|
||||||
minetest.register_entity(":" .. old_name, {
|
minetest.register_entity(":" .. old_name, {
|
||||||
|
|
||||||
initial_properties = {
|
initial_properties = {physical = false, static_save = false},
|
||||||
physical = false,
|
|
||||||
static_save = false,
|
|
||||||
},
|
|
||||||
|
|
||||||
on_activate = function(self, staticdata)
|
on_activate = function(self, staticdata)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user