mirror of
https://git.minetest.land/VoxeLibre/VoxeLibre.git
synced 2025-01-12 18:19:33 +01:00
Merge pull request 'smoother mob velocity+other mob improvments' (#2783) from fluid_mob_velocity into master
Reviewed-on: https://git.minetest.land/MineClone2/MineClone2/pulls/2783 Reviewed-by: cora <cora@noreply.git.minetest.land>
This commit is contained in:
commit
5eca209d95
1 changed files with 40 additions and 12 deletions
|
@ -336,18 +336,18 @@ local set_velocity = function(self, v)
|
||||||
|
|
||||||
-- halt mob if it has been ordered to stay
|
-- halt mob if it has been ordered to stay
|
||||||
if self.order == "stand" or self.order == "sit" then
|
if self.order == "stand" or self.order == "sit" then
|
||||||
self.object:set_velocity({x = 0, y = 0, z = 0})
|
self.acc=vector.new(0,0,0)
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
local yaw = (self.object:get_yaw() or 0) + self.rotate
|
local yaw = (self.object:get_yaw() or 0) + self.rotate
|
||||||
local vv = self.object:get_velocity()
|
local vv = self.object:get_velocity()
|
||||||
if vv then
|
if vv then
|
||||||
self.object:set_velocity({
|
self.acc={
|
||||||
x = (sin(yaw) * -v) + c_x,
|
x = ((sin(yaw) * -v) + c_x)*.27,
|
||||||
y = vv.y,
|
y = 0,
|
||||||
z = (cos(yaw) * v) + c_y,
|
z = ((cos(yaw) * v) + c_y)*.27,
|
||||||
})
|
}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -536,6 +536,7 @@ local set_animation = function(self, anim, fixed_frame)
|
||||||
anim = "jockey"
|
anim = "jockey"
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
if flight_check(self) and self.fly and anim == "walk" then anim = "fly" end
|
if flight_check(self) and self.fly and anim == "walk" then anim = "fly" end
|
||||||
|
|
||||||
self._current_animation = self._current_animation or ""
|
self._current_animation = self._current_animation or ""
|
||||||
|
@ -1013,9 +1014,6 @@ local check_for_death = function(self, cause, cmi_cause)
|
||||||
length = max(frames / speed, 0) + DEATH_DELAY
|
length = max(frames / speed, 0) + DEATH_DELAY
|
||||||
set_animation(self, "die")
|
set_animation(self, "die")
|
||||||
else
|
else
|
||||||
local rot = self.object:get_rotation()
|
|
||||||
rot.z = pi/2
|
|
||||||
self.object:set_rotation(rot)
|
|
||||||
length = 1 + DEATH_DELAY
|
length = 1 + DEATH_DELAY
|
||||||
set_animation(self, "stand", true)
|
set_animation(self, "stand", true)
|
||||||
end
|
end
|
||||||
|
@ -1411,9 +1409,16 @@ local do_jump = function(self)
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local v = self.object:get_velocity()
|
||||||
|
local v2 = abs(v.x)+abs(v.z)*.833
|
||||||
|
local jump_c_multiplier = 1
|
||||||
|
if v2/self.walk_velocity/2>1 then
|
||||||
|
jump_c_multiplier = v2/self.walk_velocity/2
|
||||||
|
end
|
||||||
|
|
||||||
-- where is front
|
-- where is front
|
||||||
local dir_x = -sin(yaw) * (self.collisionbox[4] + 0.5)
|
local dir_x = -sin(yaw) * (self.collisionbox[4] + 0.5)*jump_c_multiplier+.4
|
||||||
local dir_z = cos(yaw) * (self.collisionbox[4] + 0.5)
|
local dir_z = cos(yaw) * (self.collisionbox[4] + 0.5)*jump_c_multiplier+.4
|
||||||
|
|
||||||
-- what is in front of mob?
|
-- what is in front of mob?
|
||||||
nod = node_ok({
|
nod = node_ok({
|
||||||
|
@ -3849,6 +3854,12 @@ local mob_step = function(self, dtime)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if self.state and self.state=="die" or check_for_death(self) then
|
||||||
|
local rot = self.object:get_rotation()
|
||||||
|
rot.z = ((pi/2-rot.z)*.2)+rot.z
|
||||||
|
self.object:set_rotation(rot)
|
||||||
|
end
|
||||||
|
|
||||||
if not player_in_active_range(self) then
|
if not player_in_active_range(self) then
|
||||||
set_animation(self, "stand", true)
|
set_animation(self, "stand", true)
|
||||||
self.object:set_velocity(vector.new(0,0,0))
|
self.object:set_velocity(vector.new(0,0,0))
|
||||||
|
@ -3887,6 +3898,23 @@ local mob_step = function(self, dtime)
|
||||||
--Mob following code.
|
--Mob following code.
|
||||||
follow_flop(self)
|
follow_flop(self)
|
||||||
|
|
||||||
|
--set animation speed relitive to velocity
|
||||||
|
local v = self.object:get_velocity()
|
||||||
|
if v then
|
||||||
|
local v2 = abs(v.x)+abs(v.z)*.833
|
||||||
|
self.object:set_animation_frame_speed((v2/self.walk_velocity)*25)
|
||||||
|
|
||||||
|
|
||||||
|
--diffuse object velocity
|
||||||
|
self.object:set_velocity({x = v.x*.85, y = v.y, z = v.z*.85})
|
||||||
|
|
||||||
|
--set_speed
|
||||||
|
if self.acc then
|
||||||
|
self.object:add_velocity(self.acc)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
-- smooth rotation by ThomasMonroe314
|
-- smooth rotation by ThomasMonroe314
|
||||||
if self._turn_to then
|
if self._turn_to then
|
||||||
set_yaw(self, self._turn_to, .1)
|
set_yaw(self, self._turn_to, .1)
|
||||||
|
|
Loading…
Reference in a new issue