Add a sound a delay to the bow

This commit is contained in:
upsilon 2017-06-21 17:29:20 +02:00
parent 000c16d292
commit 094613eb29
No known key found for this signature in database
GPG Key ID: A80DAE1F266E1C3C
2 changed files with 24 additions and 15 deletions

View File

@ -50,6 +50,8 @@ Definition: definition table, containing:
Default is false. Default is false.
* cooldown: bow cooldown. Default is setting throwing.bow_cooldown * cooldown: bow cooldown. Default is setting throwing.bow_cooldown
* function spawn_arrow_entity(position, arrow, player): defaults to throwing.spawn_arrow_entity * function spawn_arrow_entity(position, arrow, player): defaults to throwing.spawn_arrow_entity
* sound: sound to be played when the bow is used
* delay: delay before throwing the arrow
]] ]]
-- Example: -- Example:

View File

@ -340,28 +340,35 @@ function throwing.register_bow(name, def)
local index = (def.throw_itself and user:get_wield_index()) or user:get_wield_index()+1 local index = (def.throw_itself and user:get_wield_index()) or user:get_wield_index()+1
local res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", index), index) local res, new_stack = def.allow_shot(user, user:get_inventory():get_stack("main", index), index)
-- Throw itself?
if not res then if not res then
return new_stack or itemstack return new_stack or itemstack
end end
-- Shoot arrow -- Sound
if shoot_arrow(itemstack, user, def.throw_itself, new_stack) then if def.sound then
if not minetest.setting_getbool("creative_mode") then minetest.sound_play(def.sound, {to_player=user:get_player_name()})
itemstack:add_wear(65535 / (def.uses or 50)) end
minetest.after(def.delay or 0, function()
-- Shoot arrow
if shoot_arrow(itemstack, user, def.throw_itself, new_stack) then
if not minetest.setting_getbool("creative_mode") then
itemstack:add_wear(65535 / (def.uses or 50))
end
end end
end
if def.throw_itself then if def.throw_itself then
-- This is a bug. If we return ItemStack(nil), the player punches the entity, -- This is a bug. If we return ItemStack(nil), the player punches the entity,
-- and if the entity if a __builtin:item, it gets back to his inventory. -- and if the entity if a __builtin:item, it gets back to his inventory.
minetest.after(0.1, function() minetest.after(0.1, function()
user:get_inventory():remove_item("main", itemstack) user:get_inventory():remove_item("main", itemstack)
end) end)
elseif cooldown > 0 then elseif cooldown > 0 then
meta:set_int("cooldown", os.time() + cooldown) meta:set_int("cooldown", os.time() + cooldown)
end end
user:get_inventory():set_stack("main", user:get_wield_index(), itemstack)
end)
return itemstack return itemstack
end end
minetest.register_tool(name, def) minetest.register_tool(name, def)