fixed the following issues
- stuck inside the hook bug - check for free space bug - added a recipe - added crane sound
This commit is contained in:
parent
fe827f0cef
commit
d3112a7445
77
init.lua
77
init.lua
@ -17,6 +17,8 @@
|
|||||||
|
|
||||||
towercrane = {}
|
towercrane = {}
|
||||||
|
|
||||||
|
dofile(minetest.get_modpath("towercrane") .. "/config.lua")
|
||||||
|
|
||||||
--##################################################################################################
|
--##################################################################################################
|
||||||
--## Tower Crane Hook
|
--## Tower Crane Hook
|
||||||
--##################################################################################################
|
--##################################################################################################
|
||||||
@ -25,7 +27,7 @@ local hook = {
|
|||||||
collisionbox = {-0.2, -0.2, -0.2, 0.2, 0.2, 0.2},
|
collisionbox = {-0.2, -0.2, -0.2, 0.2, 0.2, 0.2},
|
||||||
collide_with_objects = false,
|
collide_with_objects = false,
|
||||||
visual = "cube",
|
visual = "cube",
|
||||||
visual_size = {x=0.4, y=0.4},
|
visual_size = {x=0.6, y=0.6},
|
||||||
textures = {
|
textures = {
|
||||||
"towercrane_hook.png",
|
"towercrane_hook.png",
|
||||||
"towercrane_hook.png",
|
"towercrane_hook.png",
|
||||||
@ -40,17 +42,27 @@ local hook = {
|
|||||||
speed_forward=0,
|
speed_forward=0,
|
||||||
speed_right=0,
|
speed_right=0,
|
||||||
speed_up=0,
|
speed_up=0,
|
||||||
|
sound=nil,
|
||||||
}
|
}
|
||||||
----------------------------------------------------------------------------------------------------
|
----------------------------------------------------------------------------------------------------
|
||||||
-- Enter/leave the Hook
|
-- Enter/leave the Hook
|
||||||
----------------------------------------------------------------------------------------------------
|
----------------------------------------------------------------------------------------------------
|
||||||
function hook:on_rightclick(clicker)
|
function hook:on_rightclick(clicker)
|
||||||
|
local name = clicker:get_player_name()
|
||||||
if self.driver and clicker == self.driver then -- leave?
|
if self.driver and clicker == self.driver then -- leave?
|
||||||
clicker:set_detach()
|
clicker:set_detach()
|
||||||
|
default.player_attached[name] = false
|
||||||
|
default.player_set_animation(clicker, "stand" , 10)
|
||||||
self.driver = nil
|
self.driver = nil
|
||||||
|
if self.sound ~= nil then
|
||||||
|
minetest.sound_stop(self.sound)
|
||||||
|
self.sound = nil
|
||||||
|
end
|
||||||
elseif not self.driver then -- enter?
|
elseif not self.driver then -- enter?
|
||||||
self.driver = clicker
|
self.driver = clicker
|
||||||
clicker:set_attach(self.object, "", {x=0,y=0,z=0}, {x=0,y=0,z=0})
|
clicker:set_attach(self.object, "", {x=0,y=15,z=-3}, {x=0,y=0,z=0})
|
||||||
|
default.player_attached[name] = true
|
||||||
|
default.player_set_animation(clicker, "sit" , 10)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -112,6 +124,17 @@ function hook:on_step(dtime)
|
|||||||
if pos.z < self.pos1.z then vz= velocity end
|
if pos.z < self.pos1.z then vz= velocity end
|
||||||
if pos.z > self.pos2.z then vz= -velocity end
|
if pos.z > self.pos2.z then vz= -velocity end
|
||||||
|
|
||||||
|
if vx ~= 0 or vz ~= 0 or self.speed_up ~= 0 then
|
||||||
|
if self.sound == nil then
|
||||||
|
self.sound = minetest.sound_play({name="crane"},{object=self.object,
|
||||||
|
gain=towercrane.gain, max_hear_distance=20,
|
||||||
|
loop=true})
|
||||||
|
end
|
||||||
|
elseif self.sound ~= nil then
|
||||||
|
minetest.sound_stop(self.sound)
|
||||||
|
self.sound = nil
|
||||||
|
end
|
||||||
|
|
||||||
self.object:setvelocity({x=vx, y=self.speed_up,z=vz})
|
self.object:setvelocity({x=vx, y=self.speed_up,z=vz})
|
||||||
else
|
else
|
||||||
self.object:setvelocity({x=0, y=0,z=0})
|
self.object:setvelocity({x=0, y=0,z=0})
|
||||||
@ -139,6 +162,34 @@ local function turnleft(dir)
|
|||||||
return minetest.facedir_to_dir((facedir + 3) % 4)
|
return minetest.facedir_to_dir((facedir + 3) % 4)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
if minetest.get_node_or_nil(pos) ~= nil then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
----------------------------------------------------------------------------------------------------
|
||||||
|
-- Check space for mast and arm
|
||||||
|
----------------------------------------------------------------------------------------------------
|
||||||
|
local function check_space(pos, dir, height, width)
|
||||||
|
for i = 1,height+2 do
|
||||||
|
pos.y = pos.y + 1
|
||||||
|
if minetest.get_node_or_nil(pos).name ~= "air" then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
pos.x = pos.x + dir.x*2
|
||||||
|
pos.z = pos.z + dir.z*2
|
||||||
|
for i = 1,width+3 do
|
||||||
|
pos.x = pos.x + dir.x
|
||||||
|
pos.z = pos.z + dir.z
|
||||||
|
if minetest.get_node_or_nil(pos).name ~= "air" then
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
|
||||||
----------------------------------------------------------------------------------------------------
|
----------------------------------------------------------------------------------------------------
|
||||||
-- Constuct mast and arm
|
-- Constuct mast and arm
|
||||||
----------------------------------------------------------------------------------------------------
|
----------------------------------------------------------------------------------------------------
|
||||||
@ -177,7 +228,6 @@ local function construct_crane(pos, dir, height, width, owner)
|
|||||||
else
|
else
|
||||||
minetest.env:add_node(pos, {name="towercrane:arm"})
|
minetest.env:add_node(pos, {name="towercrane:arm"})
|
||||||
end
|
end
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -243,7 +293,7 @@ minetest.register_node("towercrane:base", {
|
|||||||
},
|
},
|
||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
is_ground_content = false,
|
is_ground_content = false,
|
||||||
groups = {cracky=3},
|
groups = {cracky=2},
|
||||||
formspec = set_formspec,
|
formspec = set_formspec,
|
||||||
|
|
||||||
-- set meta data (form for crane height and width, dir of the arm)
|
-- set meta data (form for crane height and width, dir of the arm)
|
||||||
@ -281,7 +331,6 @@ minetest.register_node("towercrane:base", {
|
|||||||
local dir = minetest.string_to_pos(meta:get_string("dir"))
|
local dir = minetest.string_to_pos(meta:get_string("dir"))
|
||||||
local height = meta:get_int("height")
|
local height = meta:get_int("height")
|
||||||
local width = meta:get_int("width")
|
local width = meta:get_int("width")
|
||||||
local org_pos = table.copy(pos)
|
|
||||||
if dir ~= nil and height ~= nil and width ~= nil then
|
if dir ~= nil and height ~= nil and width ~= nil then
|
||||||
dig_crane(pos, dir, height, width)
|
dig_crane(pos, dir, height, width)
|
||||||
end
|
end
|
||||||
@ -292,14 +341,18 @@ minetest.register_node("towercrane:base", {
|
|||||||
local width = tonumber(size[2])
|
local width = tonumber(size[2])
|
||||||
if height ~= nil and width ~= nil then
|
if height ~= nil and width ~= nil then
|
||||||
height = math.max(height, 8)
|
height = math.max(height, 8)
|
||||||
height = math.min(height, 24)
|
height = math.min(height, towercrane.max_height)
|
||||||
width = math.max(width, 8)
|
width = math.max(width, 8)
|
||||||
width = math.min(width, 24)
|
width = math.min(width, towercrane.max_width)
|
||||||
meta:set_int("height", height)
|
meta:set_int("height", height)
|
||||||
meta:set_int("width", width)
|
meta:set_int("width", width)
|
||||||
meta:set_string("infotext", "Crane size: " .. height .. "," .. width)
|
meta:set_string("infotext", "Crane size: " .. height .. "," .. width)
|
||||||
if dir ~= nil then
|
if dir ~= nil then
|
||||||
construct_crane(org_pos, dir, height, width, owner)
|
if check_space(table.copy(pos), dir, height, width) then
|
||||||
|
construct_crane(table.copy(pos), dir, height, width, owner)
|
||||||
|
else
|
||||||
|
minetest.chat_send_player(owner, "Too less space to raise up the tower crane!")
|
||||||
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -447,18 +500,18 @@ minetest.register_node("towercrane:mast_ctrl_off", {
|
|||||||
local height = meta:get_int("height")
|
local height = meta:get_int("height")
|
||||||
local width = meta:get_int("width")
|
local width = meta:get_int("width")
|
||||||
|
|
||||||
-- pos1 = close/right
|
-- pos1 = close/right/below
|
||||||
dir = turnright(dir)
|
dir = turnright(dir)
|
||||||
local pos1 = vector.add(pos, vector.multiply(dir, width/2))
|
local pos1 = vector.add(pos, vector.multiply(dir, width/2))
|
||||||
dir = turnleft(dir)
|
dir = turnleft(dir)
|
||||||
local pos1 = vector.add(pos1, vector.multiply(dir, 1))
|
local pos1 = vector.add(pos1, vector.multiply(dir, 1))
|
||||||
pos1.y = pos.y - 1
|
pos1.y = pos.y - 2 - height
|
||||||
|
|
||||||
-- pos2 = far/left
|
-- pos2 = far/left/above
|
||||||
local pos2 = vector.add(pos1, vector.multiply(dir, width-1))
|
local pos2 = vector.add(pos1, vector.multiply(dir, width-1))
|
||||||
dir = turnleft(dir)
|
dir = turnleft(dir)
|
||||||
pos2 = vector.add(pos2, vector.multiply(dir, width))
|
pos2 = vector.add(pos2, vector.multiply(dir, width))
|
||||||
pos2.y = pos.y - 4 + height
|
pos2.y = pos.y - 3 + height
|
||||||
|
|
||||||
-- normalize x/z so that pos2 > pos1
|
-- normalize x/z so that pos2 > pos1
|
||||||
if pos2.x < pos1.x then
|
if pos2.x < pos1.x then
|
||||||
|
Loading…
x
Reference in New Issue
Block a user