mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-01-26 09:40:28 +01:00
137 lines
4.7 KiB
Lua
137 lines
4.7 KiB
Lua
function throwing_register_spear_standard (kind, desc, eq, toughness, craft)
|
|
minetest.register_tool("throwing:spear_" .. kind, {
|
|
description = desc .. " spear",
|
|
inventory_image = "throwing_spear_" .. kind .. ".png",
|
|
wield_scale= {x=2,y=1.5,z=1.5};
|
|
on_use = function(itemstack, user, pointed_thing)
|
|
if pointed_thing.type == "object" then
|
|
local damage = eq --((eq + 20)^1.2)/10 --MFF crabman(28/09/2015) damage valeur equal eq
|
|
pointed_thing.ref:punch(user, 1.0, {
|
|
full_punch_interval=1.0,
|
|
damage_groups={fleshy=damage},
|
|
}, nil)
|
|
if not minetest.setting_getbool("creative_mode") then
|
|
itemstack:add_wear(65535/toughness)
|
|
end
|
|
else
|
|
throwing_shoot_spear(itemstack, user)
|
|
if not minetest.setting_getbool("creative_mode") then
|
|
itemstack:take_item()
|
|
end
|
|
end
|
|
return itemstack
|
|
end,
|
|
})
|
|
|
|
minetest.register_node("throwing:spear_" .. kind .. "_box", {
|
|
drawtype = "nodebox",
|
|
node_box = {
|
|
type = "fixed",
|
|
fixed = {
|
|
-- Shaft
|
|
{-60/16, -2/16, 2/16, 4, 1/16, -1/16},
|
|
--Spitze
|
|
{-4, -1/16, 1/16, -62/16, 0, 0},
|
|
{-62/16, -1.5/16, 1.5/16, -60/16, 0.5/16, -0.5/16},
|
|
}
|
|
},
|
|
tiles = {"throwing_spear_box.png"},
|
|
groups = {not_in_creative_inventory=1},
|
|
})
|
|
|
|
local THROWING_SPEAR_ENTITY={
|
|
physical = false,
|
|
visual = "wielditem",
|
|
visual_size = {x=0.1, y=0.1},
|
|
textures = {"throwing:spear_" .. kind .. "_box"},
|
|
lastpos={},
|
|
collisionbox = {0,0,0,0,0,0},
|
|
player = "",
|
|
wear = 0,
|
|
}
|
|
|
|
THROWING_SPEAR_ENTITY.on_step = function(self, dtime)
|
|
if not self.wear then
|
|
self.object:remove()
|
|
return
|
|
end
|
|
local newpos = self.object:getpos()
|
|
if self.lastpos.x ~= nil then
|
|
for _, pos in pairs(throwing_get_trajectoire(self, newpos)) do
|
|
local node = minetest.get_node(pos)
|
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
|
for k, obj in pairs(objs) do
|
|
local objpos = obj:getpos()
|
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
|
if (pos.x - objpos.x < 0.5 and pos.x - objpos.x > -0.5) and (pos.z - objpos.z < 0.5 and pos.z - objpos.z > -0.5) then
|
|
--local speed = vector.length(self.object:getvelocity()) --MFF crabman(28/09/2015) damage valeur equal eq
|
|
local damage = eq --((speed + eq +5)^1.2)/10 --MFF crabman(28/09/2015) damage valeur equal eq
|
|
obj:punch(self.object, 1.0, {
|
|
full_punch_interval=1.0,
|
|
damage_groups={fleshy=damage},
|
|
}, nil)
|
|
minetest.add_item(self.lastpos, {name='throwing:spear_' .. kind, count=1, wear=self.wear+65535/toughness, metadata=""})
|
|
--if math.random() < toughness then
|
|
--minetest.add_item(self.lastpos, 'throwing:spear_' .. kind)
|
|
--else
|
|
--minetest.add_item(self.lastpos, 'default:stick')
|
|
--end
|
|
self.object:remove()
|
|
return
|
|
end
|
|
end
|
|
end
|
|
if node.name ~= "air" and not string.find(node.name, 'water_') and not string.find(node.name, 'grass') and not string.find(node.name, 'flowers:') and not string.find(node.name, 'farming:') and not string.find(node.name, 'fire:') then
|
|
minetest.add_item(self.lastpos, {name='throwing:spear_' .. kind, count=1, wear=self.wear+65535/toughness, metadata=""})
|
|
--if math.random() < toughness then
|
|
--minetest.add_item(self.lastpos, 'throwing:spear_' .. kind)
|
|
--else
|
|
--minetest.add_item(self.lastpos, 'default:stick')
|
|
--end
|
|
self.object:remove()
|
|
return
|
|
end
|
|
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
|
end
|
|
end
|
|
self.lastpos={x=newpos.x, y=newpos.y, z=newpos.z}
|
|
end
|
|
|
|
minetest.register_entity("throwing:spear_" .. kind .. "_entity", THROWING_SPEAR_ENTITY)
|
|
|
|
minetest.register_craft({
|
|
output = 'throwing:spear_' .. kind,
|
|
recipe = {
|
|
{'group:wood', 'group:wood', craft},
|
|
}
|
|
})
|
|
|
|
minetest.register_craft({
|
|
output = 'throwing:spear_' .. kind,
|
|
recipe = {
|
|
{craft, 'group:wood', 'group:wood'},
|
|
}
|
|
})
|
|
end
|
|
|
|
if not DISABLE_STONE_SPEAR then
|
|
throwing_register_spear_standard ('stone', 'Stone (Hunter)', 3, 25, 'group:stone') --MFF crabman(28/09/2015) damage and wear
|
|
end
|
|
|
|
if not DISABLE_STEEL_SPEAR then
|
|
throwing_register_spear_standard ('steel', 'Steel (Hunter)', 4, 30, 'default:steel_ingot') --MFF crabman(28/09/2015) damage and wear
|
|
end
|
|
|
|
if not DISABLE_DIAMOND_SPEAR then
|
|
throwing_register_spear_standard ('diamond', 'Diamond (Hunter)', 7, 50, 'default:diamond') --MFF crabman(28/09/2015) damage and wear
|
|
end
|
|
|
|
if not DISABLE_OBSIDIAN_SPEAR then
|
|
throwing_register_spear_standard ('obsidian', 'Obsidian (Hunter)', 5, 40, 'default:obsidian') --MFF crabman(28/09/2015) damage and wear
|
|
end
|
|
|
|
if not DISABLE_MITHRIL_SPEAR then
|
|
throwing_register_spear_standard ('mithril', 'Mithril (Hunter)', 8, 200, 'moreores:mithril_ingot') --MFF crabman(28/09/2015) damage and wear
|
|
end
|
|
|