diff --git a/api.lua b/api.lua index eacfc43..84d37f6 100644 --- a/api.lua +++ b/api.lua @@ -90,7 +90,7 @@ lifetimer = def.lifetimer or 600, end, set_velocity = function(self, v) - if not v then v = 0 end -- added + if not v then v = 0 end if def.drawtype and def.drawtype == "side" then self.rotate = 1.5 end local yaw = self.object:getyaw() + self.rotate local x = math.sin(yaw) * -v @@ -272,12 +272,22 @@ lifetimer = def.lifetimer or 600, local nod = minetest.get_node(pos) if not nod or not minetest.registered_nodes[nod.name] or minetest.registered_nodes[nod.name].walkable == false then return end - local v = self.object:getvelocity() - v.y = self.jump_height - if self.following then v.y = v.y + 1 end - self.object:setvelocity(v) - if self.sounds.jump then - minetest.sound_play(self.sounds.jump, {object = self.object}) + + if self.direction then + local nod = minetest.get_node_or_nil({x=pos.x + self.direction.x,y=pos.y+1,z=pos.z + self.direction.z}) + if nod and nod.name and (nod.name ~= "air" or self.walk_chance == 0) then + local def = minetest.registered_items[nod.name] + if (def and def.walkable and not nod.name:find("fence")) or self.walk_chance == 0 then + local v = self.object:getvelocity() + v.y = self.jump_height + 1 + v.x = v.x * 2.2 + v.z = v.z * 2.2 + self.object:setvelocity(v) + if self.sounds.jump then + minetest.sound_play(self.sounds.jump, {object = self.object}) + end + end + end end end @@ -458,6 +468,7 @@ lifetimer = def.lifetimer or 600, if dist > 2 and self.order ~= "stand" then if (self.jump and self.get_velocity(self) <= 0.5 and self.object:getvelocity().y == 0) or (self.object:getvelocity().y == 0 and self.jump_chance > 0) then + self.direction = {x = math.sin(yaw)*-1, y = -20, z = math.cos(yaw)} do_jump(self) end self.set_velocity(self, self.walk_velocity) @@ -521,6 +532,7 @@ lifetimer = def.lifetimer or 600, -- jumping mobs only if self.jump_chance ~= 0 and math.random(1, 100) <= self.jump_chance then + self.direction = {x=0, y=0, z=0} do_jump(self) self.set_velocity(self, self.walk_velocity) end @@ -532,6 +544,7 @@ lifetimer = def.lifetimer or 600, self.object:setyaw(self.object:getyaw()+((math.random(0,360)-180)/180*math.pi)) end if self.jump and self.get_velocity(self) <= 0.5 and self.object:getvelocity().y == 0 then + self.direction = {x = math.sin(yaw)*-1, y = -20, z = math.cos(yaw)} do_jump(self) end @@ -574,6 +587,7 @@ lifetimer = def.lifetimer or 600, -- jump attack if (self.jump and self.get_velocity(self) <= 0.5 and self.object:getvelocity().y == 0) or (self.object:getvelocity().y == 0 and self.jump_chance > 0) then + self.direction = {x = math.sin(yaw)*-1, y = -20, z = math.cos(yaw)} do_jump(self) end self.set_velocity(self, self.run_velocity) @@ -670,14 +684,12 @@ lifetimer = def.lifetimer or 600, if self.type == "monster" and peaceful_only then self.object:remove() end --- if self.type ~= "npc" then --- self.lifetimer = self.lifetimer - dtime_s --- end + if staticdata then local tmp = minetest.deserialize(staticdata) if tmp then if tmp.lifetimer then - self.lifetimer = tmp.lifetimer -- - dtime_s + self.lifetimer = tmp.lifetimer end if tmp.tamed then self.tamed = tmp.tamed @@ -712,9 +724,6 @@ lifetimer = def.lifetimer or 600, if self.type == "monster" and self.tamed == true then self.type = "npc" end --- if self.lifetimer <= 0 and not self.tamed and self.type ~= "npc" then --- self.object:remove() --- end end, get_staticdata = function(self) @@ -805,9 +814,7 @@ lifetimer = def.lifetimer or 600, end end end - end, - }) end