From 40898101be246b834cec6e813010e41b54031b4b Mon Sep 17 00:00:00 2001 From: wsor4035 <24964441+wsor4035@users.noreply.github.com> Date: Wed, 30 Oct 2024 22:57:08 -0400 Subject: [PATCH] replace physics hell with hopefully better entity hell (#81) * replace physics hell with hopefully better entity hell * toss worthless optional depend * no need to save entity if we dont remove it for some reason - crashes, etc * fix sofas * handle the rest of chairs * catch malformed seating, since lua tables are 1 indexed * niklp suggestion --- homedecor_seating/init.lua | 96 +++++++++++++++++++++++++++----------- homedecor_seating/mod.conf | 2 +- 2 files changed, 69 insertions(+), 29 deletions(-) diff --git a/homedecor_seating/init.lua b/homedecor_seating/init.lua index ab145573..4725e4ee 100644 --- a/homedecor_seating/init.lua +++ b/homedecor_seating/init.lua @@ -3,7 +3,6 @@ local S = minetest.get_translator("homedecor_seating") local modpath = minetest.get_modpath("homedecor_seating") -local has_player_monoids = minetest.get_modpath("player_monoids") lrfurn = {} @@ -79,7 +78,54 @@ function lrfurn.fix_sofa_rotation_nsew(pos, placer, itemstack, pointed_thing) minetest.swap_node(pos, { name = node.name, param2 = fdir+colorbits }) end -local physics_cache = {} +local seated_cache = {} + +minetest.register_entity("homedecor_seating:seat", { + initial_properties = { + visual = "cube", + --comment out the following when testing so you can see it + textures = {"blank.png", "blank.png", "blank.png", "blank.png", "blank.png", "blank.png"}, + collisionbox = { -0.01, -0.01, -0.01, 0.01, 0.01, 0.01 }, + selectionbox = { -0.01, -0.01, -0.01, 0.01, 0.01, 0.01, rotate = false }, + static_save = false, + }, + on_punch = function(self) + self.object:remove() + end, +}) + +--we only care about 4 rotations, but just in case someone worldedits, etc - do something other than crash +--radians are stupid, using degrees and then converting +local p2r = { + 0*math.pi/180, + 0*math.pi/180, --correct + 180*math.pi/180, --correct + 90*math.pi/180, --correct + 270*math.pi/180, --correct + 0*math.pi/180, + 0*math.pi/180, + 0*math.pi/180, +} +p2r[0] = p2r[1] + +local p2r_sofa = { + 0*math.pi/180, + 90*math.pi/180, --correct + 270*math.pi/180, --correct + 180*math.pi/180, --correct + 0*math.pi/180, --correct + 0*math.pi/180, + 0*math.pi/180, + 0*math.pi/180, +} +p2r_sofa[0] = p2r_sofa[1] + +local p2r_facedir = { + [0] = 180*math.pi/180, + [1] = 90*math.pi/180, + [2] = 0*math.pi/180, + [3] = 270*math.pi/180, +} function lrfurn.sit(pos, node, clicker, itemstack, pointed_thing, seats) if not clicker:is_player() then @@ -87,7 +133,7 @@ function lrfurn.sit(pos, node, clicker, itemstack, pointed_thing, seats) end local name = clicker:get_player_name() - if physics_cache[name] then --already sitting + if seated_cache[name] then --already sitting lrfurn.stand(clicker) return itemstack end @@ -132,17 +178,22 @@ function lrfurn.sit(pos, node, clicker, itemstack, pointed_thing, seats) --seat the player clicker:set_pos(sit_pos) + local entity = minetest.add_entity(sit_pos, "homedecor_seating:seat") + if not entity then return itemstack end --catch for when the entity fails to spawn just in case + + clicker:set_attach(entity, "", {x = 0, y = 0, z = 0}, {x = 0, y = 0, z = 0}, true) + local nodedef = minetest.registered_nodes[node.name] + if nodedef.paramtype2 == "facedir" then + entity:set_rotation({x = 0, y = p2r_facedir[node.param2 % 4], z = 0}) + elseif string.find(node.name, "sofa") then + entity:set_rotation({x = 0, y = p2r_sofa[node.param2 % 8], z = 0}) + else + entity:set_rotation({x = 0, y = p2r[node.param2 % 8], z = 0}) + end + xcompat.player.player_attached[name] = true xcompat.player.set_animation(clicker, "sit", 0) - if has_player_monoids then - physics_cache[name] = true - player_monoids.speed:add_change(clicker, 0, "homedecor_seating:sit") - player_monoids.jump:add_change(clicker, 0, "homedecor_seating:sit") - player_monoids.gravity:add_change(clicker, 0, "homedecor_seating:sit") - else - physics_cache[name] = table.copy(clicker:get_physics_override()) - clicker:set_physics_override({speed = 0, jump = 0, gravity = 0}) - end + seated_cache[name] = true return itemstack end @@ -150,23 +201,12 @@ end function lrfurn.stand(clicker) local name = clicker:get_player_name() xcompat.player.player_attached[name] = false - if physics_cache[name] then - if has_player_monoids then - player_monoids.speed:del_change(clicker, "homedecor_seating:sit") - player_monoids.jump:del_change(clicker, "homedecor_seating:sit") - player_monoids.gravity:del_change(clicker, "homedecor_seating:sit") - else - clicker:set_physics_override(physics_cache[name]) - end - physics_cache[name] = nil - else --in case this is called and the cache is empty - if has_player_monoids then - player_monoids.speed:del_change(clicker, "homedecor_seating:sit") - player_monoids.jump:del_change(clicker, "homedecor_seating:sit") - player_monoids.gravity:del_change(clicker, "homedecor_seating:sit") - else - clicker:set_physics_override({speed = 1, jump = 1, gravity = 1}) + if seated_cache[name] then + local attached_to = clicker:get_attach() + if attached_to then --check, a stupid clearobjects might have been called, etc + attached_to:remove() --removing also detaches end + seated_cache[name] = nil end end diff --git a/homedecor_seating/mod.conf b/homedecor_seating/mod.conf index d0b057fe..5d17db39 100644 --- a/homedecor_seating/mod.conf +++ b/homedecor_seating/mod.conf @@ -1,4 +1,4 @@ name = homedecor_seating description = Homedecor mod: seating depends = homedecor_common -optional_depends = screwdriver, wool, default, unifieddyes, basic_materials, player_monoids +optional_depends = screwdriver, wool, default, unifieddyes, basic_materials