This commit is contained in:
echoes91 2015-03-17 12:05:11 +01:00
parent 79a546378e
commit d1ab5dd697
6 changed files with 132 additions and 101 deletions

124
bows.lua
View File

@ -1,3 +1,7 @@
--~
--~ Shot and reload system
--~
local stiffness= 0 local stiffness= 0
local reload = 0 local reload = 0
@ -69,14 +73,18 @@ local function reloading (player)
minetest.after(reload, reloaded, player, throwing_hud) minetest.after(reload, reloaded, player, throwing_hud)
end end
if not disable_wooden_bow then --~
--~ Bows
--~
if not DISABLE_WOODEN_BOW then
minetest.register_tool("throwing:bow_wood", { minetest.register_tool("throwing:bow_wood", {
description = "Wooden Bow", description = "Wooden Bow",
inventory_image = "throwing_bow_wood.png", inventory_image = "throwing_bow_wood.png",
wield_scale = {x=1, y=1, z=0.5}, wield_scale = {x=1, y=1, z=0.5},
stack_max = 1, stack_max = 1,
on_use = function(itemstack, user, pointed_thing) on_use = function(itemstack, user, pointed_thing)
stiffness = 13 stiffness = 11
reload = 1.2 reload = 1.2
if throwing_shoot_arrow(itemstack, user, pointed_thing) then if throwing_shoot_arrow(itemstack, user, pointed_thing) then
reloading(user) reloading(user)
@ -91,69 +99,31 @@ if not disable_wooden_bow then
minetest.register_craft({ minetest.register_craft({
output = 'throwing:bow_wood', output = 'throwing:bow_wood',
recipe = { recipe = {
{'farming:string', 'group:wood', ''}, {'', 'default:stick', ''},
{'farming:string', '', 'group:wood'}, {'farming:string', '', 'default:stick'},
{'farming:string', 'group:wood', ''}, {'', 'default:stick', ''},
} }
}) })
minetest.register_craft({ minetest.register_craft({
output = 'throwing:bow_wood', output = 'throwing:bow_wood',
recipe = { recipe = {
{'', 'group:wood', 'farming:string'}, {'', 'default:stick', ''},
{'group:wood', '', 'farming:string'}, {'default:stick', '', 'farming:string'},
{'', 'group:wood', 'farming:string'}, {'', 'default:stick', ''},
} }
}) })
end end
if not disable_golden_bow then -- To be changed soon if not DISABLE_LONGBOW then
minetest.register_tool("throwing:bow_gold", { minetest.register_tool("throwing:longbow", {
description = "Golden Bow", description = "Longbow",
inventory_image = "throwing_bow_gold.png", inventory_image = "throwing_longbow.png",
wield_scale = {x=1, y=1, z=0.5}, wield_scale = {x=1, y=2.5, z=0.5},
stack_max = 1,
on_use = function(itemstack, user, pointed_thing)
stiffness = 16
reload = 1.6
if throwing_shoot_arrow(itemstack, user, pointed_thing) then
reloading(user)
if not minetest.setting_getbool("creative_mode") then
itemstack:add_wear(65535/400)
end
end
return itemstack
end,
})
minetest.register_craft({
output = 'throwing:bow_gold',
recipe = {
{'farming:string', 'default:gold_ingot', ''},
{'farming:string', '', 'default:gold_ingot'},
{'farming:string', 'default:gold_ingot', ''},
}
})
minetest.register_craft({
output = 'throwing:bow_gold',
recipe = {
{'', 'default:gold_ingot', 'farming:string'},
{'default:gold_ingot', '', 'farming:string'},
{'', 'default:gold_ingot', 'farming:string'},
}
})
end
if not disable_composite_bow then
minetest.register_tool("throwing:bow_composite", {
description = "Composite Bow",
inventory_image = "throwing_bow_composite.png",
wield_scale = {x=1, y=1, z=0.5},
stack_max = 1, stack_max = 1,
on_use = function(itemstack, user, pointed_thing) on_use = function(itemstack, user, pointed_thing)
stiffness = 18 stiffness = 18
reload = 1.4 reload = 2.5
if throwing_shoot_arrow(itemstack, user, pointed_thing) then if throwing_shoot_arrow(itemstack, user, pointed_thing) then
reloading(user) reloading(user)
if not minetest.setting_getbool("creative_mode") then if not minetest.setting_getbool("creative_mode") then
@ -164,11 +134,49 @@ if not disable_composite_bow then
end, end,
}) })
minetest.register_craft({
output = 'throwing:longbow',
recipe = {
{'farming:string', 'group:wood', ''},
{'farming:string', '', 'group:wood'},
{'farming:string', 'group:wood', ''},
}
})
minetest.register_craft({
output = 'throwing:longbow',
recipe = {
{'', 'group:wood', 'farming:string'},
{'group:wood', '', 'farming:string'},
{'', 'group:wood', 'farming:string'},
}
})
end
if not DISABLE_COMPOSITE_BOW then
minetest.register_tool("throwing:bow_composite", {
description = "Composite Bow",
inventory_image = "throwing_bow_composite.png",
wield_scale = {x=1, y=1.4, z=0.5},
stack_max = 1,
on_use = function(itemstack, user, pointed_thing)
stiffness = 18
reload = 1.5
if throwing_shoot_arrow(itemstack, user, pointed_thing) then
reloading(user)
if not minetest.setting_getbool("creative_mode") then
itemstack:add_wear(65535/150)
end
end
return itemstack
end,
})
minetest.register_craft({ minetest.register_craft({
output = 'throwing:bow_composite', output = 'throwing:bow_composite',
recipe = { recipe = {
{'farming:string', 'group:wood', ''}, {'farming:string', 'group:wood', ''},
{'farming:string', 'default:steel_ingot', 'default:steel_ingot'}, {'farming:string', '', 'default:steel_ingot'},
{'farming:string', 'group:wood', ''}, {'farming:string', 'group:wood', ''},
} }
}) })
@ -177,25 +185,25 @@ if not disable_composite_bow then
output = 'throwing:bow_composite', output = 'throwing:bow_composite',
recipe = { recipe = {
{'', 'group:wood', 'farming:string'}, {'', 'group:wood', 'farming:string'},
{'default:steel_ingot', 'default:steel_ingot', 'farming:string'}, {'default:steel_ingot', '', 'farming:string'},
{'', 'group:wood', 'farming:string'}, {'', 'group:wood', 'farming:string'},
} }
}) })
end end
if not disable_steel_bow then if not DISABLE_STEEL_BOW then
minetest.register_tool("throwing:bow_steel", { minetest.register_tool("throwing:bow_steel", {
description = "Steel Bow", description = "Steel Bow",
inventory_image = "throwing_bow_steel.png", inventory_image = "throwing_bow_steel.png",
wield_scale = {x=1, y=1, z=0.5}, wield_scale = {x=1, y=1.4, z=0.5},
stack_max = 1, stack_max = 1,
on_use = function(itemstack, user, pointed_thing) on_use = function(itemstack, user, pointed_thing)
stiffness = 20 stiffness = 20
reload = 1.6 reload = 1.7
if throwing_shoot_arrow(itemstack, user, pointed_thing) then if throwing_shoot_arrow(itemstack, user, pointed_thing) then
reloading(user) reloading(user)
if not minetest.setting_getbool("creative_mode") then if not minetest.setting_getbool("creative_mode") then
itemstack:add_wear(65535/200) itemstack:add_wear(65535/250)
end end
end end
return itemstack return itemstack

View File

@ -13,42 +13,58 @@ arrows = {
{"throwing:arrow_fireworks_blue", "throwing:arrow_fireworks_blue_entity"}, {"throwing:arrow_fireworks_blue", "throwing:arrow_fireworks_blue_entity"},
} }
dofile(minetest.get_modpath("throwing").."/config.lua") local input = io.open(minetest.get_modpath("throwing").."/throwing.conf", "r")
dofile(minetest.get_modpath("throwing").."/bows.lua") if input then
if not disable_steel_arrow then dofile(minetest.get_modpath("throwing").."/throwing.conf")
dofile(minetest.get_modpath("throwing").."/steel_arrow.lua") input:close()
end input = nil
if not disable_stone_arrow then
dofile(minetest.get_modpath("throwing").."/stone_arrow.lua")
end
if not disable_stone_arrow then
dofile(minetest.get_modpath("throwing").."/obsidian_arrow.lua")
end
if not disable_fire_arrow then
dofile(minetest.get_modpath("throwing").."/fire_arrow.lua")
end
if not disable_teleport_arrow then
dofile(minetest.get_modpath("throwing").."/teleport_arrow.lua")
end
if not disable_dig_arrow then
dofile(minetest.get_modpath("throwing").."/dig_arrow.lua")
end
if not disable_build_arrow then
dofile(minetest.get_modpath("throwing").."/build_arrow.lua")
end
if not disable_tnt_arrow then
dofile(minetest.get_modpath("throwing").."/tnt_arrow.lua")
end
if not disable_torch_arrow then
dofile(minetest.get_modpath("throwing").."/torch_arrow.lua")
end
if not disable_diamond_arrow then
dofile(minetest.get_modpath("throwing").."/diamond_arrow.lua")
end
if not disable_shell_arrow then
dofile(minetest.get_modpath("throwing").."/shell_arrow.lua")
end end
dofile(minetest.get_modpath("throwing").."/bows.lua")
if not DISABLE_STEEL_ARROW then
dofile(minetest.get_modpath("throwing").."/steel_arrow.lua")
end
if not DISABLE_STONE_ARROW then
dofile(minetest.get_modpath("throwing").."/stone_arrow.lua")
end
if not DISABLE_STONE_ARROW then
dofile(minetest.get_modpath("throwing").."/obsidian_arrow.lua")
end
if not DISABLE_FIRE_ARROW then
dofile(minetest.get_modpath("throwing").."/fire_arrow.lua")
end
if not DISABLE_TELEPORT_ARROW then
dofile(minetest.get_modpath("throwing").."/teleport_arrow.lua")
end
if not DISABLE_DIG_ARROW then
dofile(minetest.get_modpath("throwing").."/dig_arrow.lua")
end
if not DISABLE_BUILD_ARROW then
dofile(minetest.get_modpath("throwing").."/build_arrow.lua")
end
if not DISABLE_TNT_ARROW then
dofile(minetest.get_modpath("throwing").."/tnt_arrow.lua")
end
if not DISABLE_TORCH_ARROW then
dofile(minetest.get_modpath("throwing").."/torch_arrow.lua")
end
if not DISABLE_DIAMOND_ARROW then
dofile(minetest.get_modpath("throwing").."/diamond_arrow.lua")
end
if not DISABLE_SHELL_ARROW then
dofile(minetest.get_modpath("throwing").."/shell_arrow.lua")
end
if minetest.setting_get("log_mods") then if minetest.setting_get("log_mods") then
minetest.log("action", "throwing loaded") minetest.log("action", "throwing loaded")

Binary file not shown.

Before

Width:  |  Height:  |  Size: 584 B

After

Width:  |  Height:  |  Size: 581 B

Binary file not shown.

After

Width:  |  Height:  |  Size: 661 B

1
throwing.conf Normal file
View File

@ -0,0 +1 @@
DISABLE_TNT_ARROW = true

6
throwing.conf.example Normal file
View File

@ -0,0 +1,6 @@
# You can disable any bow and arrow by writing lines like these inside throwing.conf
#
# DISABLE_WOODEN_BOW = true
#
# DISABLE_TNT_ARROW = true