can now ride mobs redo mobs in mineclone2

This commit is contained in:
tenplus1 2023-07-27 12:54:46 +01:00
parent 07dce8208b
commit 8201c165e7

View File

@ -1,6 +1,6 @@
-- lib_mount by Blert2112 (edited by TenPlus1) -- lib_mount by Blert2112 (edited by TenPlus1)
-- one of these is needed (for now) to ride mobs, otherwise no riding for you --[[ one of these is needed (for now) to ride mobs, otherwise no riding for you
if not minetest.get_modpath("default") if not minetest.get_modpath("default")
or not minetest.get_modpath("player_api") then or not minetest.get_modpath("player_api") then
@ -11,9 +11,11 @@ or not minetest.get_modpath("player_api") then
return return
end end
]]
local is_50 = minetest.get_modpath("player_api") -- 5.x compatibility local is_50 = minetest.get_modpath("player_api") -- 5.x compatibility
local is_mc2 = minetest.get_modpath("mcl_mobs") -- MineClone2 compatibility
local abs, cos, floor, sin, sqrt, pi = local abs, cos, floor, sin, sqrt, pi =
math.abs, math.cos, math.floor, math.sin, math.sqrt, math.pi math.abs, math.cos, math.floor, math.sin, math.sqrt, math.pi
@ -87,9 +89,7 @@ end
local function force_detach(player) local function force_detach(player)
if not player then return end local attached_to = player and player:get_attach()
local attached_to = player:get_attach()
if not attached_to then if not attached_to then
return return
@ -97,8 +97,7 @@ local function force_detach(player)
local entity = attached_to:get_luaentity() local entity = attached_to:get_luaentity()
if entity and entity.driver if entity and entity.driver and entity.driver == player then
and entity.driver == player then
entity.driver = nil entity.driver = nil
end end
@ -109,6 +108,9 @@ local function force_detach(player)
if is_50 then if is_50 then
player_api.player_attached[name] = false player_api.player_attached[name] = false
player_api.set_animation(player, "stand", 30) player_api.set_animation(player, "stand", 30)
elseif is_mc2 then
mcl_player.player_attached[player:get_player_name()] = false
mcl_player.player_set_animation(player, "stand", 30)
else else
default.player_attached[name] = false default.player_attached[name] = false
default.player_set_animation(player, "stand", 30) default.player_set_animation(player, "stand", 30)
@ -163,8 +165,7 @@ local function find_free_pos(pos)
local def = minetest.registered_nodes[node.name] local def = minetest.registered_nodes[node.name]
if def and not def.walkable and if def and not def.walkable and def.liquidtype == "none" then
def.liquidtype == "none" then
return npos return npos
end end
end end
@ -205,6 +206,8 @@ function mobs.attach(entity, player)
if is_50 then if is_50 then
player_api.player_attached[player:get_player_name()] = true player_api.player_attached[player:get_player_name()] = true
elseif is_mc2 then
mcl_player.player_attached[player:get_player_name()] = true
else else
default.player_attached[player:get_player_name()] = true default.player_attached[player:get_player_name()] = true
end end
@ -225,6 +228,8 @@ function mobs.attach(entity, player)
if is_50 then if is_50 then
player_api.set_animation(player, "sit", 30) player_api.set_animation(player, "sit", 30)
elseif is_mc2 then
mcl_player.player_set_animation(player, "sit_mount" , 30)
else else
default.player_set_animation(player, "sit", 30) default.player_set_animation(player, "sit", 30)
end end
@ -272,13 +277,11 @@ function mobs.drive(entity, moving_anim, stand_anim, can_fly, dtime)
local ctrl = entity.driver:get_player_control() local ctrl = entity.driver:get_player_control()
-- move forwards if ctrl.up then -- move forwards
if ctrl.up then
entity.v = entity.v + entity.accel * dtime entity.v = entity.v + entity.accel * dtime
-- move backwards elseif ctrl.down then -- move backwards
elseif ctrl.down then
if entity.max_speed_reverse == 0 and entity.v == 0 then if entity.max_speed_reverse == 0 and entity.v == 0 then
return return
@ -308,8 +311,7 @@ function mobs.drive(entity, moving_anim, stand_anim, can_fly, dtime)
if can_fly then if can_fly then
-- fly up if ctrl.jump then -- fly up
if ctrl.jump then
velo.y = velo.y + 1 velo.y = velo.y + 1
@ -322,8 +324,7 @@ function mobs.drive(entity, moving_anim, stand_anim, can_fly, dtime)
if velo.y < 0 then velo.y = 0 end if velo.y < 0 then velo.y = 0 end
end end
-- fly down if ctrl.sneak then -- fly down
if ctrl.sneak then
velo.y = velo.y - 1 velo.y = velo.y - 1
@ -336,8 +337,7 @@ function mobs.drive(entity, moving_anim, stand_anim, can_fly, dtime)
if velo.y > 0 then velo.y = 0 end if velo.y > 0 then velo.y = 0 end
end end
else else
-- jump if ctrl.jump then -- jump
if ctrl.jump then
if velo.y == 0 then if velo.y == 0 then
velo.y = velo.y + entity.jump_height velo.y = velo.y + entity.jump_height
@ -470,12 +470,10 @@ end
function mobs.fly(entity, _, speed, shoots, arrow, moving_anim, stand_anim) function mobs.fly(entity, _, speed, shoots, arrow, moving_anim, stand_anim)
local ctrl = entity.driver:get_player_control() ; if not ctrl then return end local ctrl = entity.driver:get_player_control() ; if not ctrl then return end
local velo = entity.object:get_velocity() local velo = entity.object:get_velocity() ; if not velo then return end
local dir = entity.driver:get_look_dir() local dir = entity.driver:get_look_dir()
local yaw = entity.driver:get_look_horizontal() + 1.57 local yaw = entity.driver:get_look_horizontal() + 1.57
if not ctrl or not velo then return end
if ctrl.up then if ctrl.up then
entity.object:set_velocity({ entity.object:set_velocity({