mirror of
https://github.com/minetest-mods/throwing.git
synced 2025-01-25 01:20:21 +01:00
Add a sound a delay to the bow
This commit is contained in:
parent
000c16d292
commit
094613eb29
@ -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:
|
||||||
|
37
init.lua
37
init.lua
@ -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)
|
||||||
|
Loading…
Reference in New Issue
Block a user