Version MFF.
0
README.txt
Normal file → Executable file
56
build_arrow.lua
Normal file → Executable file
@ -38,56 +38,66 @@ local THROWING_ARROW_ENTITY={
|
|||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
node = "",
|
node = "",
|
||||||
|
player = "",
|
||||||
|
inventory = false,
|
||||||
|
stack = false,
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
self.timer=self.timer+dtime
|
self.timer=self.timer+dtime
|
||||||
local pos = self.object:getpos()
|
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 node = minetest.get_node(pos)
|
||||||
if not self.inventory or not self.stack then
|
|
||||||
self.object:remove()
|
|
||||||
end
|
|
||||||
|
|
||||||
if self.timer>0.2 then
|
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 1)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 1)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_build_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
|
||||||
self.object:remove()
|
|
||||||
if self.inventory and self.stack and not minetest.setting_getbool("creative_mode") then
|
if self.inventory and self.stack and not minetest.setting_getbool("creative_mode") then
|
||||||
self.inventory:remove_item("main", {name=self.stack:get_name()})
|
self.inventory:remove_item("main", {name=self.stack:get_name()})
|
||||||
end
|
end
|
||||||
if self.stack then
|
if self.stack then
|
||||||
minetest.add_item(self.lastpos, {name=self.stack:get_name()})
|
minetest.add_item(pos, {name=self.stack:get_name()})
|
||||||
end
|
end
|
||||||
local toughness = 0.95
|
local toughness = 0.95
|
||||||
if math.random() < toughness then
|
if math.random() < toughness then
|
||||||
minetest.add_item(self.lastpos, 'throwing:arrow_build')
|
minetest.add_item(pos, 'throwing:arrow_build')
|
||||||
else
|
else
|
||||||
minetest.add_item(self.lastpos, 'default:stick')
|
minetest.add_item(pos, 'default:stick')
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
if node.name ~= "air"
|
||||||
if node.name ~= "air" then
|
and not string.find(node.name, "water_")
|
||||||
self.object:remove()
|
and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt'))
|
||||||
if self.inventory and self.stack and not minetest.setting_getbool("creative_mode") then
|
and not (string.find(node.name, 'farming:') and not string.find(node.name, 'soil'))
|
||||||
self.inventory:remove_item("main", {name=self.stack:get_name()})
|
and not string.find(node.name, 'flowers:')
|
||||||
end
|
and not string.find(node.name, 'fire:') then
|
||||||
if self.stack then
|
if node.name ~= "ignore" and self.inventory and self.stack then
|
||||||
if not string.find(node.name, "water") and not string.find(node.name, "lava") and not string.find(node.name, "torch") and self.stack:get_definition().type == "node" and self.stack:get_name() ~= "default:torch" then
|
if not minetest.is_protected(self.lastpos, "")
|
||||||
|
and not string.find(node.name, "lava")
|
||||||
|
and not string.find(node.name, "torch")
|
||||||
|
and self.stack:get_definition().type == "node"
|
||||||
|
and self.stack:get_name() ~= "default:torch" then
|
||||||
minetest.place_node(self.lastpos, {name=self.stack:get_name()})
|
minetest.place_node(self.lastpos, {name=self.stack:get_name()})
|
||||||
else
|
else
|
||||||
minetest.add_item(self.lastpos, {name=self.stack:get_name()})
|
minetest.add_item(self.lastpos, {name=self.stack:get_name()})
|
||||||
end
|
end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
self.inventory:remove_item("main", {name=self.stack:get_name()})
|
||||||
|
end
|
||||||
end
|
end
|
||||||
minetest.add_item(self.lastpos, 'default:shovel_steel')
|
minetest.add_item(self.lastpos, 'default:shovel_steel')
|
||||||
end
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
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
|
end
|
||||||
|
|
||||||
minetest.register_entity("throwing:arrow_build_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_build_entity", THROWING_ARROW_ENTITY)
|
||||||
|
13
crafts.lua
Executable file
@ -0,0 +1,13 @@
|
|||||||
|
-- Craft recipe of the "Mithril String"
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "throwing:string_mithril",
|
||||||
|
description = "Mithril String",
|
||||||
|
inventory_image = "string_mithril.png",
|
||||||
|
type = "shapeless",
|
||||||
|
recipe = {"default:mithril_ingot", "farming:string"},
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craftitem("throwing:string_mithril", {
|
||||||
|
inventory_image = "throwing_string_mithril.png",
|
||||||
|
description = "Mithril String",
|
||||||
|
})
|
4
defaults.lua
Normal file → Executable file
@ -23,7 +23,3 @@ DISABLE_STEEL_ARROW = false
|
|||||||
DISABLE_DIAMOND_ARROW = false
|
DISABLE_DIAMOND_ARROW = false
|
||||||
DISABLE_OBSIDIAN_ARROW = false
|
DISABLE_OBSIDIAN_ARROW = false
|
||||||
|
|
||||||
DISABLE_STONE_SPEAR = false
|
|
||||||
DISABLE_STEEL_SPEAR = false
|
|
||||||
DISABLE_DIAMOND_SPEAR = false
|
|
||||||
DISABLE_OBSIDIAN_SPEAR = false
|
|
||||||
|
0
depends.txt
Normal file → Executable file
0
description.txt
Normal file → Executable file
63
dig_arrow.lua
Normal file → Executable file
@ -37,50 +37,59 @@ local THROWING_ARROW_ENTITY={
|
|||||||
textures = {"throwing:arrow_dig_box"},
|
textures = {"throwing:arrow_dig_box"},
|
||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
player = "",
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
|
||||||
self.timer=self.timer+dtime
|
|
||||||
local pos = self.object:getpos()
|
|
||||||
local node = minetest.get_node(pos)
|
|
||||||
|
|
||||||
if self.timer>0.2 then
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
|
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}, 1)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 1)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_dig_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
if throwing_touch(pos, obj:getpos()) then
|
||||||
|
local puncher = self.object
|
||||||
|
if self.player and minetest.get_player_by_name(self.player) then
|
||||||
|
puncher = minetest.get_player_by_name(self.player)
|
||||||
|
end
|
||||||
local damage = 1.5
|
local damage = 1.5
|
||||||
obj:punch(self.object, 1.0, {
|
if self.bow_damage and self.bow_damage > 0 then
|
||||||
|
damage = damage + (self.bow_damage/12)
|
||||||
|
end
|
||||||
|
obj:punch(puncher, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
damage_groups={fleshy=damage},
|
damage_groups={fleshy=damage},
|
||||||
}, nil)
|
}, nil)
|
||||||
|
if math.random(0,100) % 2 == 0 then -- 50% of chance to drop //MFF (Mg|07/27/15)
|
||||||
|
minetest.add_item(pos, "throwing:arrow_dig")
|
||||||
|
end
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
local toughness = 0.9
|
return
|
||||||
if math.random() < toughness then
|
|
||||||
minetest.add_item(self.lastpos, 'throwing:arrow_dig')
|
|
||||||
else
|
|
||||||
minetest.add_item(self.lastpos, 'default:stick')
|
|
||||||
end
|
end
|
||||||
end
|
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, 'dirt'))
|
||||||
|
and not (string.find(node.name, 'farming:') and not string.find(node.name, 'soil'))
|
||||||
|
and not string.find(node.name, 'flowers:')
|
||||||
|
and not string.find(node.name, 'fire:') then
|
||||||
|
if node.name ~= "ignore" and minetest.get_item_group(node.name, "unbreakable") == 0
|
||||||
|
and not minetest.is_protected(pos, self.player)
|
||||||
|
and node.diggable ~= false then
|
||||||
|
minetest.set_node(pos, {name = "air"})
|
||||||
|
minetest.add_item(pos, node.name)
|
||||||
end
|
end
|
||||||
end
|
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
|
||||||
if node.name ~= "air" then
|
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
if node.diggable ~= false then
|
return
|
||||||
minetest.dig_node(pos)
|
|
||||||
end
|
|
||||||
local toughness = 0.65
|
|
||||||
if math.random() < toughness then
|
|
||||||
minetest.add_item(self.lastpos, 'default:pick_steel')
|
|
||||||
else
|
|
||||||
minetest.add_item(self.lastpos, 'default:stick')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
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
|
end
|
||||||
|
|
||||||
minetest.register_entity("throwing:arrow_dig_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_dig_entity", THROWING_ARROW_ENTITY)
|
||||||
|
56
fire_arrow.lua
Normal file → Executable file
@ -31,53 +31,73 @@ minetest.register_node("throwing:arrow_fire_box", {
|
|||||||
|
|
||||||
local THROWING_ARROW_ENTITY={
|
local THROWING_ARROW_ENTITY={
|
||||||
physical = false,
|
physical = false,
|
||||||
timer=0,
|
|
||||||
visual = "wielditem",
|
visual = "wielditem",
|
||||||
visual_size = {x=0.1, y=0.1},
|
visual_size = {x=0.1, y=0.1},
|
||||||
textures = {"throwing:arrow_fire_box"},
|
textures = {"throwing:arrow_fire_box"},
|
||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
player = "",
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
self.timer=self.timer+dtime
|
local newpos = self.object:getpos()
|
||||||
local pos = 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 node = minetest.get_node(pos)
|
||||||
|
|
||||||
if self.timer>0.2 then
|
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
local objpos = obj:getpos()
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_fire_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
|
if throwing_touch(pos, objpos) then
|
||||||
|
local puncher = self.object
|
||||||
|
if self.player and minetest.get_player_by_name(self.player) then
|
||||||
|
puncher = minetest.get_player_by_name(self.player)
|
||||||
|
end
|
||||||
local damage = 4
|
local damage = 4
|
||||||
obj:punch(self.object, 1.0, {
|
if self.bow_damage and self.bow_damage > 0 then
|
||||||
|
damage = damage + (self.bow_damage/12)
|
||||||
|
end
|
||||||
|
obj:punch(puncher, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
damage_groups={fleshy=damage},
|
damage_groups={fleshy=damage},
|
||||||
}, nil)
|
}, nil)
|
||||||
self.object:remove()
|
if math.random(0,100) % 2 == 0 then -- 50% of chance to drop //MFF (Mg|07/27/15)
|
||||||
minetest.add_item(self.lastpos, 'default:stick')
|
minetest.add_item(pos, 'default:stick')
|
||||||
end
|
end
|
||||||
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
if node.name ~= "air"
|
||||||
if node.name ~= "air" and node.name ~= "throwing:light" then
|
and node.name ~= "throwing:light"
|
||||||
|
and node.name ~= "fire:basic_flame"
|
||||||
|
and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt'))
|
||||||
|
and not (string.find(node.name, 'farming:') and not string.find(node.name, 'soil'))
|
||||||
|
and not string.find(node.name, 'flowers:')
|
||||||
|
and not string.find(node.name, 'fire:') then
|
||||||
|
if node.name ~= "ignore" then
|
||||||
minetest.set_node(self.lastpos, {name="fire:basic_flame"})
|
minetest.set_node(self.lastpos, {name="fire:basic_flame"})
|
||||||
|
end
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
if math.floor(self.lastpos.x+0.5) ~= math.floor(pos.x+0.5) or math.floor(self.lastpos.y+0.5) ~= math.floor(pos.y+0.5) or math.floor(self.lastpos.z+0.5) ~= math.floor(pos.z+0.5) then
|
|
||||||
if minetest.get_node(self.lastpos).name == "throwing:light" then
|
|
||||||
minetest.remove_node(self.lastpos)
|
|
||||||
end
|
|
||||||
if minetest.get_node(pos).name == "air" then
|
if minetest.get_node(pos).name == "air" then
|
||||||
minetest.set_node(pos, {name="throwing:light"})
|
minetest.set_node(pos, {name="throwing:light"})
|
||||||
end
|
end
|
||||||
end
|
if minetest.get_node(self.lastpos).name == "throwing:light" then
|
||||||
|
minetest.remove_node(self.lastpos)
|
||||||
end
|
end
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
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
|
end
|
||||||
|
|
||||||
|
|
||||||
minetest.register_entity("throwing:arrow_fire_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_fire_entity", THROWING_ARROW_ENTITY)
|
||||||
|
|
||||||
minetest.register_node("throwing:light", {
|
minetest.register_node("throwing:light", {
|
||||||
@ -85,7 +105,7 @@ minetest.register_node("throwing:light", {
|
|||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
sunlight_propagates = true,
|
sunlight_propagates = true,
|
||||||
tiles = {"throwing_empty.png"},
|
tiles = {"throwing_empty.png"},
|
||||||
light_source = LIGHT_MAX-4,
|
light_source = default.LIGHT_MAX-4,
|
||||||
selection_box = {
|
selection_box = {
|
||||||
type = "fixed",
|
type = "fixed",
|
||||||
fixed = {
|
fixed = {
|
||||||
|
46
fireworks_arrows.lua
Normal file → Executable file
@ -38,6 +38,8 @@ local function throwing_register_fireworks(color, desc)
|
|||||||
textures = {"throwing:arrow_fireworks_" .. color .. "_box"},
|
textures = {"throwing:arrow_fireworks_" .. color .. "_box"},
|
||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
player = "",
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
local radius = 0.5
|
local radius = 0.5
|
||||||
@ -74,16 +76,15 @@ local function throwing_register_fireworks(color, desc)
|
|||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
self.timer=self.timer+dtime
|
self.timer=self.timer+dtime
|
||||||
local pos = self.object:getpos()
|
local newpos = self.object:getpos()
|
||||||
local node = minetest.get_node(pos)
|
|
||||||
if self.timer < 0.07 then
|
if self.timer < 0.07 then
|
||||||
minetest.sound_play("throwing_firework_launch", {pos=pos, gain=0.8, max_hear_distance=2*64})
|
minetest.sound_play("throwing_firework_launch", {pos=newpos, gain=0.8, max_hear_distance=2*64})
|
||||||
end
|
end
|
||||||
minetest.add_particlespawner({
|
minetest.add_particlespawner({
|
||||||
amount = 16,
|
amount = 16,
|
||||||
time = 0.1,
|
time = 0.1,
|
||||||
minpos = pos,
|
minpos = newpos,
|
||||||
maxpos = pos,
|
maxpos = newpos,
|
||||||
minvel = {x=-5, y=-5, z=-5},
|
minvel = {x=-5, y=-5, z=-5},
|
||||||
maxvel = {x=5, y=5, z=5},
|
maxvel = {x=5, y=5, z=5},
|
||||||
minacc = vector.new(),
|
minacc = vector.new(),
|
||||||
@ -94,38 +95,39 @@ local function throwing_register_fireworks(color, desc)
|
|||||||
maxsize = 1,
|
maxsize = 1,
|
||||||
texture = "throwing_sparkle.png",
|
texture = "throwing_sparkle.png",
|
||||||
})
|
})
|
||||||
if self.timer>0.2 then
|
if self.lastpos.x ~= nil then
|
||||||
|
for _, pos in pairs(throwing_get_trajectoire(self, newpos)) do
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_fireworks_" .. color .. "_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
|
||||||
local damage = 2
|
local damage = 2
|
||||||
|
if self.bow_damage and self.bow_damage > 0 then
|
||||||
|
damage = damage + (self.bow_damage/12)
|
||||||
|
end
|
||||||
obj:punch(self.object, 1.0, {
|
obj:punch(self.object, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
damage_groups={fleshy=damage},
|
damage_groups={fleshy=damage},
|
||||||
}, nil)
|
}, nil)
|
||||||
self.object:remove()
|
|
||||||
boom(pos)
|
boom(pos)
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
if self.timer > 2 then
|
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
boom(self.lastpos)
|
return
|
||||||
end
|
end
|
||||||
if self.lastpos.x~=nil then
|
end
|
||||||
if node.name ~= "air" and node.name ~= "throwing:firework_trail" then
|
end
|
||||||
|
local node = minetest.get_node(newpos)
|
||||||
|
if self.timer > 2 or node.name ~= "air" and node.name ~= "throwing:firework_trail" then
|
||||||
|
boom(self.lastpos)
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
boom(self.lastpos)
|
return
|
||||||
end
|
|
||||||
end
|
end
|
||||||
if node.name == 'air' then
|
if node.name == 'air' then
|
||||||
minetest.add_node(pos, {name="throwing:firework_trail"})
|
minetest.add_node(newpos, {name="throwing:firework_trail"})
|
||||||
minetest.get_node_timer(pos):start(0.1)
|
minetest.get_node_timer(newpos):start(0.1)
|
||||||
end
|
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:arrow_fireworks_" .. color .. "_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_fireworks_" .. color .. "_entity", THROWING_ARROW_ENTITY)
|
||||||
|
|
||||||
|
87
functions.lua
Normal file → Executable file
@ -16,24 +16,69 @@ minetest.register_on_leaveplayer(function(player)
|
|||||||
players[playerName] = nil
|
players[playerName] = nil
|
||||||
end)
|
end)
|
||||||
|
|
||||||
|
function throwing_is_player(name, obj)
|
||||||
|
return (obj:is_player() and obj:get_player_name() ~= name)
|
||||||
|
end
|
||||||
|
|
||||||
|
function throwing_is_entity(obj)
|
||||||
|
return (obj:get_luaentity() ~= nil
|
||||||
|
and not string.find(obj:get_luaentity().name, "throwing:")
|
||||||
|
and obj:get_luaentity().name ~= "__builtin:item"
|
||||||
|
and obj:get_luaentity().name ~= "gauges:hp_bar"
|
||||||
|
and obj:get_luaentity().name ~= "signs:text")
|
||||||
|
end
|
||||||
|
|
||||||
|
function throwing_get_trajectoire(self, newpos)
|
||||||
|
if self.lastpos.x == nil then
|
||||||
|
return {newpos}
|
||||||
|
end
|
||||||
|
local coord = {}
|
||||||
|
local nx = (newpos["x"] - self.lastpos["x"])/3
|
||||||
|
local ny = (newpos["y"] - self.lastpos["y"])/3
|
||||||
|
local nz = (newpos["z"] - self.lastpos["z"])/3
|
||||||
|
|
||||||
|
if nx and ny and nz then
|
||||||
|
table.insert(coord, {x=self.lastpos["x"]+nx, y=self.lastpos["y"]+ny ,z=self.lastpos["z"]+nz })
|
||||||
|
table.insert(coord, {x=newpos["x"]-nx, y=newpos["y"]-ny ,z=newpos["z"]-nz })
|
||||||
|
end
|
||||||
|
table.insert(coord, newpos)
|
||||||
|
return coord
|
||||||
|
end
|
||||||
|
|
||||||
|
function throwing_touch(pos, objpos)
|
||||||
|
local rx = pos.x - objpos.x
|
||||||
|
local ry = pos.y - (objpos.y+1)
|
||||||
|
local rz = pos.z - objpos.z
|
||||||
|
if (ry < 1 and ry > -1) and (rx < 1 and rx > -1) and (rz < 1 and rz > -1) then
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
function throwing_shoot_arrow (itemstack, player, stiffness, is_cross)
|
function throwing_shoot_arrow (itemstack, player, stiffness, is_cross)
|
||||||
|
if not player then return end
|
||||||
local arrow = itemstack:get_metadata()
|
local arrow = itemstack:get_metadata()
|
||||||
itemstack:set_metadata("")
|
itemstack:set_metadata("")
|
||||||
player:set_wielded_item(itemstack)
|
player:set_wielded_item(itemstack)
|
||||||
local playerpos = player:getpos()
|
local playerpos = player:getpos()
|
||||||
local obj = minetest.add_entity({x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}, arrow)
|
local obj = minetest.add_entity({x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}, arrow)
|
||||||
|
if not obj then return end
|
||||||
local dir = player:get_look_dir()
|
local dir = player:get_look_dir()
|
||||||
obj:setvelocity({x=dir.x*stiffness, y=dir.y*stiffness, z=dir.z*stiffness})
|
obj:setvelocity({x=dir.x*stiffness, y=dir.y*stiffness, z=dir.z*stiffness})
|
||||||
obj:setacceleration({x=dir.x*-3, y=-8.5, z=dir.z*-3})
|
obj:setacceleration({x=dir.x*-3, y=-10, z=dir.z*-3})
|
||||||
obj:setyaw(player:get_look_yaw()+math.pi)
|
obj:setyaw(player:get_look_yaw()+math.pi)
|
||||||
if is_cross then
|
if is_cross then
|
||||||
minetest.sound_play("throwing_crossbow_sound", {pos=playerpos})
|
minetest.sound_play("throwing_crossbow_sound", {pos=playerpos})
|
||||||
else
|
else
|
||||||
minetest.sound_play("throwing_bow_sound", {pos=playerpos})
|
minetest.sound_play("throwing_bow_sound", {pos=playerpos})
|
||||||
end
|
end
|
||||||
obj:get_luaentity().player = player
|
if obj:get_luaentity() then
|
||||||
|
obj:get_luaentity().player = player:get_player_name()
|
||||||
obj:get_luaentity().inventory = player:get_inventory()
|
obj:get_luaentity().inventory = player:get_inventory()
|
||||||
obj:get_luaentity().stack = player:get_inventory():get_stack("main", player:get_wield_index()-1)
|
obj:get_luaentity().stack = player:get_inventory():get_stack("main", player:get_wield_index()-1)
|
||||||
|
obj:get_luaentity().lastpos = {x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}
|
||||||
|
obj:get_luaentity().bow_damage = stiffness
|
||||||
|
end
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -44,6 +89,7 @@ function throwing_unload (itemstack, player, unloaded, wear)
|
|||||||
if not minetest.setting_getbool("creative_mode") then
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
player:get_inventory():add_item("main", arrow[1])
|
player:get_inventory():add_item("main", arrow[1])
|
||||||
end
|
end
|
||||||
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -67,6 +113,7 @@ function throwing_reload (itemstack, player, pos, is_cross, loaded)
|
|||||||
end
|
end
|
||||||
local meta = arrow[2]
|
local meta = arrow[2]
|
||||||
player:set_wielded_item({name=loaded, wear=wear, metadata=meta})
|
player:set_wielded_item({name=loaded, wear=wear, metadata=meta})
|
||||||
|
break
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -120,27 +167,25 @@ function throwing_register_bow (name, desc, scale, stiffness, reload_time, tough
|
|||||||
recipe = craft
|
recipe = craft
|
||||||
})
|
})
|
||||||
|
|
||||||
|
local craft_width = 1
|
||||||
|
-- Since # isn't stable especially when there are nils in the table, count by hand
|
||||||
|
for _,v in ipairs(craft) do
|
||||||
|
for i,__ in ipairs(v) do
|
||||||
|
if i > craft_width then
|
||||||
|
craft_width = i
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
local rev_craft = {}
|
||||||
|
for i,y in ipairs(craft) do
|
||||||
|
rev_craft[i] = {}
|
||||||
|
for j,x in ipairs(y) do
|
||||||
|
rev_craft[i][craft_width-j+1] = x
|
||||||
|
end
|
||||||
|
end
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'throwing:' .. name,
|
output = 'throwing:' .. name,
|
||||||
recipe = {
|
recipe = rev_craft
|
||||||
{craft[1][3], craft[1][2], craft[1][1]},
|
|
||||||
{craft[2][3], craft[2][2], craft[2][1]},
|
|
||||||
{craft[3][3], craft[3][2], craft[3][1]},
|
|
||||||
}
|
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Spears
|
|
||||||
|
|
||||||
function throwing_shoot_spear (itemstack, player)
|
|
||||||
local spear = itemstack:get_name() .. '_entity'
|
|
||||||
local playerpos = player:getpos()
|
|
||||||
local obj = minetest.add_entity({x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}, spear)
|
|
||||||
local dir = player:get_look_dir()
|
|
||||||
obj:setvelocity({x=dir.x*14, y=dir.y*14, z=dir.z*14})
|
|
||||||
obj:setacceleration({x=-dir.x*1, y=-9.8, z=-dir.z*1})
|
|
||||||
obj:setyaw(player:get_look_yaw()+math.pi)
|
|
||||||
minetest.sound_play("throwing_bow_sound", {pos=playerpos})
|
|
||||||
obj:get_luaentity().wear = itemstack:get_wear()
|
|
||||||
return true
|
|
||||||
end
|
|
||||||
|
6
init.lua
Normal file → Executable file
@ -2,13 +2,14 @@ throwing_arrows = {
|
|||||||
{"throwing:arrow_steel", "throwing:arrow_steel_entity"},
|
{"throwing:arrow_steel", "throwing:arrow_steel_entity"},
|
||||||
{"throwing:arrow_stone", "throwing:arrow_stone_entity"},
|
{"throwing:arrow_stone", "throwing:arrow_stone_entity"},
|
||||||
{"throwing:arrow_obsidian", "throwing:arrow_obsidian_entity"},
|
{"throwing:arrow_obsidian", "throwing:arrow_obsidian_entity"},
|
||||||
|
{"throwing:arrow_diamond", "throwing:arrow_diamond_entity"},
|
||||||
|
{"throwing:arrow_mithril", "throwing:arrow_mithril_entity"}, --MFF : Only for Hunters
|
||||||
{"throwing:arrow_fire", "throwing:arrow_fire_entity"},
|
{"throwing:arrow_fire", "throwing:arrow_fire_entity"},
|
||||||
{"throwing:arrow_teleport", "throwing:arrow_teleport_entity"},
|
{"throwing:arrow_teleport", "throwing:arrow_teleport_entity"},
|
||||||
{"throwing:arrow_dig", "throwing:arrow_dig_entity"},
|
{"throwing:arrow_dig", "throwing:arrow_dig_entity"},
|
||||||
{"throwing:arrow_build", "throwing:arrow_build_entity"},
|
{"throwing:arrow_build", "throwing:arrow_build_entity"},
|
||||||
{"throwing:arrow_tnt", "throwing:arrow_tnt_entity"},
|
{"throwing:arrow_tnt", "throwing:arrow_tnt_entity"},
|
||||||
{"throwing:arrow_torch", "throwing:arrow_torch_entity"},
|
{"throwing:arrow_torch", "throwing:arrow_torch_entity"},
|
||||||
{"throwing:arrow_diamond", "throwing:arrow_diamond_entity"},
|
|
||||||
{"throwing:arrow_shell", "throwing:arrow_shell_entity"},
|
{"throwing:arrow_shell", "throwing:arrow_shell_entity"},
|
||||||
{"throwing:arrow_fireworks_blue", "throwing:arrow_fireworks_blue_entity"},
|
{"throwing:arrow_fireworks_blue", "throwing:arrow_fireworks_blue_entity"},
|
||||||
{"throwing:arrow_fireworks_red", "throwing:arrow_fireworks_red_entity"},
|
{"throwing:arrow_fireworks_red", "throwing:arrow_fireworks_red_entity"},
|
||||||
@ -27,9 +28,10 @@ dofile(minetest.get_modpath("throwing").."/functions.lua")
|
|||||||
|
|
||||||
dofile(minetest.get_modpath("throwing").."/tools.lua")
|
dofile(minetest.get_modpath("throwing").."/tools.lua")
|
||||||
|
|
||||||
|
dofile(minetest.get_modpath("throwing").."/crafts.lua")
|
||||||
|
|
||||||
dofile(minetest.get_modpath("throwing").."/standard_arrows.lua")
|
dofile(minetest.get_modpath("throwing").."/standard_arrows.lua")
|
||||||
|
|
||||||
dofile(minetest.get_modpath("throwing").."/spears.lua")
|
|
||||||
|
|
||||||
if minetest.get_modpath('fire') and minetest.get_modpath('bucket') and not DISABLE_FIRE_ARROW then
|
if minetest.get_modpath('fire') and minetest.get_modpath('bucket') and not DISABLE_FIRE_ARROW then
|
||||||
dofile(minetest.get_modpath("throwing").."/fire_arrow.lua")
|
dofile(minetest.get_modpath("throwing").."/fire_arrow.lua")
|
||||||
|
BIN
screenshot.png
Before Width: | Height: | Size: 737 KiB |
34
shell_arrow.lua
Normal file → Executable file
@ -37,6 +37,8 @@ local THROWING_ARROW_ENTITY={
|
|||||||
textures = {"throwing:arrow_shell_box"},
|
textures = {"throwing:arrow_shell_box"},
|
||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
player = "",
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
local radius = 1
|
local radius = 1
|
||||||
@ -70,35 +72,41 @@ end
|
|||||||
-- Back to the arrow
|
-- Back to the arrow
|
||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
self.timer=self.timer+dtime
|
local newpos = self.object:getpos()
|
||||||
local pos = 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 node = minetest.get_node(pos)
|
||||||
|
|
||||||
if self.timer>0.2 then
|
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_shell_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
|
||||||
local speed = vector.length(self.object:getvelocity())
|
local speed = vector.length(self.object:getvelocity())
|
||||||
local damage = ((speed + 5)^1.2)/10 + 12
|
local damage = ((speed + 5)^1.2)/10 + 12
|
||||||
|
if self.bow_damage and self.bow_damage > 0 then
|
||||||
|
damage = damage + (self.bow_damage/12)
|
||||||
|
end
|
||||||
obj:punch(self.object, 1.0, {
|
obj:punch(self.object, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
damage_groups={fleshy=damage},
|
damage_groups={fleshy=damage},
|
||||||
}, nil)
|
}, nil)
|
||||||
self.object:remove()
|
|
||||||
boom(pos)
|
boom(pos)
|
||||||
end
|
self.object:remove()
|
||||||
end
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
if node.name ~= "air"
|
||||||
if node.name ~= "air" and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt')) and not string.find(node.name, 'flowers:') and not string.find(node.name, 'farming:') then
|
and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt'))
|
||||||
self.object:remove()
|
and not (string.find(node.name, 'farming:') and not string.find(node.name, 'soil'))
|
||||||
|
and not string.find(node.name, 'flowers:')
|
||||||
|
and not string.find(node.name, 'fire:') then
|
||||||
boom(self.lastpos)
|
boom(self.lastpos)
|
||||||
end
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
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
|
end
|
||||||
|
|
||||||
minetest.register_entity("throwing:arrow_shell_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_shell_entity", THROWING_ARROW_ENTITY)
|
||||||
|
BIN
sounds/throwing_bow_sound.ogg
Normal file → Executable file
BIN
sounds/throwing_crossbow_sound.ogg
Normal file → Executable file
BIN
sounds/throwing_firework_boom.ogg
Normal file → Executable file
BIN
sounds/throwing_firework_launch.ogg
Normal file → Executable file
BIN
sounds/throwing_shell_explode.ogg
Normal file → Executable file
129
spears.lua
@ -1,129 +0,0 @@
|
|||||||
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 + 20)^1.2)/10
|
|
||||||
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,
|
|
||||||
timer=0,
|
|
||||||
visual = "wielditem",
|
|
||||||
visual_size = {x=0.1, y=0.1},
|
|
||||||
textures = {"throwing:spear_" .. kind .. "_box"},
|
|
||||||
lastpos={},
|
|
||||||
collisionbox = {0,0,0,0,0,0},
|
|
||||||
}
|
|
||||||
|
|
||||||
THROWING_SPEAR_ENTITY.on_step = function(self, dtime)
|
|
||||||
self.timer=self.timer+dtime
|
|
||||||
local pos = self.object:getpos()
|
|
||||||
local node = minetest.get_node(pos)
|
|
||||||
if not self.wear then
|
|
||||||
self.object:remove()
|
|
||||||
return
|
|
||||||
end
|
|
||||||
|
|
||||||
if self.timer>0.2 then
|
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
|
||||||
for k, obj in pairs(objs) do
|
|
||||||
if obj:get_luaentity() ~= nil then
|
|
||||||
if obj:get_luaentity().name ~= "throwing:spear_" .. kind .. "_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
|
||||||
local speed = vector.length(self.object:getvelocity())
|
|
||||||
local damage = ((speed + eq +5)^1.2)/10
|
|
||||||
obj:punch(self.object, 1.0, {
|
|
||||||
full_punch_interval=1.0,
|
|
||||||
damage_groups={fleshy=damage},
|
|
||||||
}, nil)
|
|
||||||
self.object:remove()
|
|
||||||
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
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
|
||||||
if node.name ~= "air" and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt')) and not string.find(node.name, 'flowers:') and not string.find(node.name, 'farming:') then
|
|
||||||
self.object:remove()
|
|
||||||
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
|
|
||||||
end
|
|
||||||
end
|
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.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', 0, 20, 'group:stone')
|
|
||||||
end
|
|
||||||
|
|
||||||
if not DISABLE_STEEL_SPEAR then
|
|
||||||
throwing_register_spear_standard ('steel', 'Steel', 5, 30, 'default:steel_ingot')
|
|
||||||
end
|
|
||||||
|
|
||||||
if not DISABLE_DIAMOND_SPEAR then
|
|
||||||
throwing_register_spear_standard ('diamond', 'Diamond', 10, 40, 'default:diamond')
|
|
||||||
end
|
|
||||||
|
|
||||||
if not DISABLE_OBSIDIAN_SPEAR then
|
|
||||||
throwing_register_spear_standard ('obsidian', 'Obsidian', 15, 30, 'default:obsidian')
|
|
||||||
end
|
|
82
standard_arrows.lua
Normal file → Executable file
@ -26,59 +26,75 @@ function throwing_register_arrow_standard (kind, desc, eq, toughness, craft)
|
|||||||
{7.5/17, -2.5/17, -2.5/17, 8.5/17, -3.5/17, -3.5/17},
|
{7.5/17, -2.5/17, -2.5/17, 8.5/17, -3.5/17, -3.5/17},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
tiles = {"throwing_arrow_" .. kind .. ".png", "throwing_arrow_" .. kind .. ".png", "throwing_arrow_" .. kind .. "_back.png", "throwing_arrow_" .. kind .. "_front.png", "throwing_arrow_" .. kind .. "_2.png", "throwing_arrow_" .. kind .. ".png"},
|
tiles = {"throwing_arrow_" .. kind .. ".png", "throwing_arrow_" .. kind .. ".png", "throwing_arrow_" .. kind .. "_back.png", "throwing_arrow_" .. kind .. "_front.png",
|
||||||
|
"throwing_arrow_" .. kind .. "_2.png", "throwing_arrow_" .. kind .. ".png"},
|
||||||
groups = {not_in_creative_inventory=1},
|
groups = {not_in_creative_inventory=1},
|
||||||
})
|
})
|
||||||
|
|
||||||
local THROWING_ARROW_ENTITY={
|
local THROWING_ARROW_ENTITY={
|
||||||
physical = false,
|
physical = false,
|
||||||
timer=0,
|
|
||||||
visual = "wielditem",
|
visual = "wielditem",
|
||||||
visual_size = {x=0.1, y=0.1},
|
visual_size = {x=0.1, y=0.1},
|
||||||
textures = {"throwing:arrow_" .. kind .. "_box"},
|
textures = {"throwing:arrow_" .. kind .. "_box"},
|
||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
player = "",
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
self.timer=self.timer+dtime
|
local newpos = self.object:getpos()
|
||||||
local pos = 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 node = minetest.get_node(pos)
|
||||||
|
|
||||||
if self.timer>0.2 then
|
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
local objpos = obj:getpos()
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_" .. kind .. "_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
local speed = vector.length(self.object:getvelocity())
|
if throwing_touch(pos, objpos) then
|
||||||
local damage = ((speed + eq)^1.2)/10
|
local puncher = self.object
|
||||||
obj:punch(self.object, 1.0, {
|
if self.player and minetest.get_player_by_name(self.player) then
|
||||||
|
puncher = minetest.get_player_by_name(self.player)
|
||||||
|
end
|
||||||
|
local damage = eq
|
||||||
|
if self.bow_damage and self.bow_damage > 0 then
|
||||||
|
damage = damage + (self.bow_damage/12)
|
||||||
|
end
|
||||||
|
obj:punch(puncher, 1.0, {
|
||||||
full_punch_interval=1.0,
|
full_punch_interval=1.0,
|
||||||
damage_groups={fleshy=damage},
|
damage_groups={fleshy=damage},
|
||||||
}, nil)
|
}, nil)
|
||||||
|
if math.random() < toughness then
|
||||||
|
if math.random(0,100) % 2 == 0 then
|
||||||
|
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
|
||||||
|
end
|
||||||
|
else
|
||||||
|
minetest.add_item(self.lastpos, 'default:stick')
|
||||||
|
end
|
||||||
self.object:remove()
|
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, 'dirt'))
|
||||||
|
and not (string.find(node.name, 'farming:') and not string.find(node.name, 'soil'))
|
||||||
|
and not string.find(node.name, 'flowers:')
|
||||||
|
and not string.find(node.name, 'fire:') then
|
||||||
if math.random() < toughness then
|
if math.random() < toughness then
|
||||||
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
|
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
|
||||||
else
|
else
|
||||||
minetest.add_item(self.lastpos, 'default:stick')
|
minetest.add_item(self.lastpos, 'default:stick')
|
||||||
end
|
end
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
|
||||||
if node.name ~= "air" and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt')) and not string.find(node.name, 'flowers:') and not string.find(node.name, 'farming:') then
|
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
if math.random() < toughness then
|
return
|
||||||
minetest.add_item(self.lastpos, 'throwing:arrow_' .. kind)
|
|
||||||
else
|
|
||||||
minetest.add_item(self.lastpos, 'default:stick')
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
self.lastpos={x=newpos.x, y=newpos.y, z=newpos.z}
|
||||||
|
end
|
||||||
|
|
||||||
minetest.register_entity("throwing:arrow_" .. kind .. "_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_" .. kind .. "_entity", THROWING_ARROW_ENTITY)
|
||||||
|
|
||||||
@ -98,17 +114,21 @@ function throwing_register_arrow_standard (kind, desc, eq, toughness, craft)
|
|||||||
end
|
end
|
||||||
|
|
||||||
if not DISABLE_STONE_ARROW then
|
if not DISABLE_STONE_ARROW then
|
||||||
throwing_register_arrow_standard ('stone', 'Stone', 0, 0.88, 'group:stone')
|
throwing_register_arrow_standard ('stone', 'Stone', 4, 0.40, 'group:stone')
|
||||||
end
|
end
|
||||||
|
|
||||||
if not DISABLE_STEEL_ARROW then
|
if not DISABLE_STEEL_ARROW then
|
||||||
throwing_register_arrow_standard ('steel', 'Steel', 5, 0.94, 'default:steel_ingot')
|
throwing_register_arrow_standard ('steel', 'Steel', 5, 0.50, 'default:steel_ingot')
|
||||||
end
|
|
||||||
|
|
||||||
if not DISABLE_DIAMOND_ARROW then
|
|
||||||
throwing_register_arrow_standard ('diamond', 'Diamond', 10, 0.97, 'default:diamond')
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if not DISABLE_OBSIDIAN_ARROW then
|
if not DISABLE_OBSIDIAN_ARROW then
|
||||||
throwing_register_arrow_standard ('obsidian', 'Obsidian', 15, 0.88, 'default:obsidian')
|
throwing_register_arrow_standard ('obsidian', 'Obsidian', 6, 0.60, 'default:obsidian')
|
||||||
|
end
|
||||||
|
|
||||||
|
if not DISABLE_DIAMOND_ARROW then
|
||||||
|
throwing_register_arrow_standard ('diamond', 'Diamond', 7, 0.70, 'default:diamond')
|
||||||
|
end
|
||||||
|
|
||||||
|
if not DISABLE_MITHRIL_ARROW then
|
||||||
|
throwing_register_arrow_standard ('mithril', 'Mithril (Hunter)', 8, 0.80, 'default:mithril_ingot')
|
||||||
end
|
end
|
||||||
|
42
teleport_arrow.lua
Normal file → Executable file
@ -31,48 +31,52 @@ minetest.register_node("throwing:arrow_teleport_box", {
|
|||||||
|
|
||||||
local THROWING_ARROW_ENTITY={
|
local THROWING_ARROW_ENTITY={
|
||||||
physical = false,
|
physical = false,
|
||||||
timer=0,
|
|
||||||
visual = "wielditem",
|
visual = "wielditem",
|
||||||
visual_size = {x=0.1, y=0.1},
|
visual_size = {x=0.1, y=0.1},
|
||||||
textures = {"throwing:arrow_teleport_box"},
|
textures = {"throwing:arrow_teleport_box"},
|
||||||
lastpos={},
|
lastpos={},
|
||||||
collisionbox = {0,0,0,0,0,0},
|
collisionbox = {0,0,0,0,0,0},
|
||||||
player = "",
|
player = "",
|
||||||
|
bow_damage = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
THROWING_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
self.timer=self.timer+dtime
|
local newpos = self.object:getpos()
|
||||||
local pos = 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 node = minetest.get_node(pos)
|
||||||
if not self.player then
|
|
||||||
self.object:remove()
|
|
||||||
end
|
|
||||||
|
|
||||||
if self.timer>0.2 then
|
|
||||||
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
local objs = minetest.get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
if throwing_is_player(self.player, obj) or throwing_is_entity(obj) then
|
||||||
if obj:get_luaentity().name ~= "throwing:arrow_teleport_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
|
||||||
self.object:remove()
|
|
||||||
if self.player ~= "" then
|
if self.player ~= "" then
|
||||||
self.player:setpos(pos)
|
local player = minetest.get_player_by_name(self.player)
|
||||||
self.player:get_inventory():add_item("main", ItemStack("default:stick 2"))
|
if player then
|
||||||
end
|
player:setpos(self.lastpos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if self.lastpos.x~=nil then
|
if node.name ~= "air"
|
||||||
if node.name ~= "air" then
|
and not (string.find(node.name, 'grass') and not string.find(node.name, 'dirt'))
|
||||||
self.object:remove()
|
and not (string.find(node.name, 'farming:') and not string.find(node.name, 'soil'))
|
||||||
|
and not string.find(node.name, 'flowers:')
|
||||||
|
and not string.find(node.name, 'fire:') then
|
||||||
if self.player ~= "" then
|
if self.player ~= "" then
|
||||||
self.player:setpos(self.lastpos)
|
local player = minetest.get_player_by_name(self.player)
|
||||||
self.player:get_inventory():add_item("main", ItemStack("default:stick 2"))
|
if player then
|
||||||
|
player:setpos(self.lastpos)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
self.object:remove()
|
||||||
|
return
|
||||||
end
|
end
|
||||||
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
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
|
end
|
||||||
|
|
||||||
minetest.register_entity("throwing:arrow_teleport_entity", THROWING_ARROW_ENTITY)
|
minetest.register_entity("throwing:arrow_teleport_entity", THROWING_ARROW_ENTITY)
|
||||||
|
BIN
textures/___BOW_LOAD.PNG
Executable file
After Width: | Height: | Size: 241 B |
BIN
textures/throwing_arbalest.png
Normal file → Executable file
Before Width: | Height: | Size: 760 B After Width: | Height: | Size: 363 B |
Before Width: | Height: | Size: 739 B After Width: | Height: | Size: 421 B |
Before Width: | Height: | Size: 798 B After Width: | Height: | Size: 417 B |
BIN
textures/throwing_arbalest_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 807 B After Width: | Height: | Size: 449 B |
BIN
textures/throwing_arrow_build.png
Normal file → Executable file
Before Width: | Height: | Size: 217 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_build_2.png
Normal file → Executable file
Before Width: | Height: | Size: 224 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_build_back.png
Normal file → Executable file
Before Width: | Height: | Size: 213 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_build_front.png
Normal file → Executable file
Before Width: | Height: | Size: 188 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_diamond.png
Normal file → Executable file
Before Width: | Height: | Size: 213 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_diamond_2.png
Normal file → Executable file
Before Width: | Height: | Size: 217 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_diamond_back.png
Normal file → Executable file
Before Width: | Height: | Size: 210 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_diamond_front.png
Normal file → Executable file
Before Width: | Height: | Size: 191 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_dig.png
Normal file → Executable file
Before Width: | Height: | Size: 229 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_dig_2.png
Normal file → Executable file
Before Width: | Height: | Size: 221 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_dig_back.png
Normal file → Executable file
Before Width: | Height: | Size: 215 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_dig_front.png
Normal file → Executable file
Before Width: | Height: | Size: 190 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_fire.png
Normal file → Executable file
Before Width: | Height: | Size: 262 B After Width: | Height: | Size: 196 B |
BIN
textures/throwing_arrow_fire_2.png
Normal file → Executable file
Before Width: | Height: | Size: 271 B After Width: | Height: | Size: 192 B |
BIN
textures/throwing_arrow_fire_back.png
Normal file → Executable file
Before Width: | Height: | Size: 268 B After Width: | Height: | Size: 204 B |
BIN
textures/throwing_arrow_fire_front.png
Normal file → Executable file
Before Width: | Height: | Size: 306 B After Width: | Height: | Size: 232 B |
BIN
textures/throwing_arrow_fireworks_blue.png
Normal file → Executable file
Before Width: | Height: | Size: 222 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_fireworks_blue_2.png
Normal file → Executable file
Before Width: | Height: | Size: 223 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_fireworks_blue_back.png
Normal file → Executable file
Before Width: | Height: | Size: 232 B After Width: | Height: | Size: 161 B |
BIN
textures/throwing_arrow_fireworks_blue_front.png
Normal file → Executable file
Before Width: | Height: | Size: 207 B After Width: | Height: | Size: 143 B |
BIN
textures/throwing_arrow_fireworks_red.png
Normal file → Executable file
Before Width: | Height: | Size: 235 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_fireworks_red_2.png
Normal file → Executable file
Before Width: | Height: | Size: 223 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_fireworks_red_back.png
Normal file → Executable file
Before Width: | Height: | Size: 234 B After Width: | Height: | Size: 161 B |
BIN
textures/throwing_arrow_fireworks_red_front.png
Normal file → Executable file
Before Width: | Height: | Size: 203 B After Width: | Height: | Size: 143 B |
BIN
textures/throwing_arrow_mithril.png
Normal file
After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_mithril_2.png
Normal file
After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_mithril_back.png
Normal file
After Width: | Height: | Size: 143 B |
BIN
textures/throwing_arrow_mithril_front.png
Normal file
After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_model.png
Executable file
After Width: | Height: | Size: 191 B |
BIN
textures/throwing_arrow_obsidian.png
Normal file → Executable file
Before Width: | Height: | Size: 213 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_obsidian_2.png
Normal file → Executable file
Before Width: | Height: | Size: 216 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_obsidian_back.png
Normal file → Executable file
Before Width: | Height: | Size: 204 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_obsidian_front.png
Normal file → Executable file
Before Width: | Height: | Size: 188 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_shell.png
Normal file → Executable file
Before Width: | Height: | Size: 243 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_shell_2.png
Normal file → Executable file
Before Width: | Height: | Size: 252 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_shell_back.png
Normal file → Executable file
Before Width: | Height: | Size: 204 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_shell_front.png
Normal file → Executable file
Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 145 B |
BIN
textures/throwing_arrow_steel.png
Normal file → Executable file
Before Width: | Height: | Size: 230 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_steel_2.png
Normal file → Executable file
Before Width: | Height: | Size: 227 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_steel_back.png
Normal file → Executable file
Before Width: | Height: | Size: 209 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_steel_front.png
Normal file → Executable file
Before Width: | Height: | Size: 189 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_stone.png
Normal file → Executable file
Before Width: | Height: | Size: 224 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_stone_2.png
Normal file → Executable file
Before Width: | Height: | Size: 219 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_stone_back.png
Normal file → Executable file
Before Width: | Height: | Size: 213 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_stone_front.png
Normal file → Executable file
Before Width: | Height: | Size: 190 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_teleport.png
Normal file → Executable file
Before Width: | Height: | Size: 220 B After Width: | Height: | Size: 131 B |
BIN
textures/throwing_arrow_teleport_2.png
Normal file → Executable file
Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 132 B |
BIN
textures/throwing_arrow_teleport_back.png
Normal file → Executable file
Before Width: | Height: | Size: 212 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_teleport_front.png
Normal file → Executable file
Before Width: | Height: | Size: 189 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_arrow_tnt.png
Normal file → Executable file
Before Width: | Height: | Size: 241 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_tnt_2.png
Normal file → Executable file
Before Width: | Height: | Size: 241 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_tnt_back.png
Normal file → Executable file
Before Width: | Height: | Size: 211 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_tnt_front.png
Normal file → Executable file
Before Width: | Height: | Size: 224 B After Width: | Height: | Size: 145 B |
BIN
textures/throwing_arrow_torch.png
Normal file → Executable file
Before Width: | Height: | Size: 224 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_torch_2.png
Normal file → Executable file
Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 136 B |
BIN
textures/throwing_arrow_torch_back.png
Normal file → Executable file
Before Width: | Height: | Size: 228 B After Width: | Height: | Size: 153 B |
BIN
textures/throwing_arrow_torch_front.png
Normal file → Executable file
Before Width: | Height: | Size: 178 B After Width: | Height: | Size: 133 B |
BIN
textures/throwing_bow_composite.png
Normal file → Executable file
Before Width: | Height: | Size: 646 B After Width: | Height: | Size: 329 B |
BIN
textures/throwing_bow_composite_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 692 B After Width: | Height: | Size: 457 B |
BIN
textures/throwing_bow_minotaur_horn.png
Executable file
After Width: | Height: | Size: 472 B |
BIN
textures/throwing_bow_minotaur_horn_improved.png
Executable file
After Width: | Height: | Size: 303 B |
BIN
textures/throwing_bow_minotaur_horn_improved_loaded.png
Executable file
After Width: | Height: | Size: 407 B |
BIN
textures/throwing_bow_minotaur_horn_loaded.png
Executable file
After Width: | Height: | Size: 431 B |
BIN
textures/throwing_bow_royal.png
Normal file → Executable file
Before Width: | Height: | Size: 617 B After Width: | Height: | Size: 374 B |
BIN
textures/throwing_bow_royal_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 660 B After Width: | Height: | Size: 488 B |
BIN
textures/throwing_bow_steel.png
Normal file → Executable file
Before Width: | Height: | Size: 633 B After Width: | Height: | Size: 336 B |
BIN
textures/throwing_bow_steel_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 683 B After Width: | Height: | Size: 461 B |
BIN
textures/throwing_bow_wood.png
Normal file → Executable file
Before Width: | Height: | Size: 581 B After Width: | Height: | Size: 252 B |
BIN
textures/throwing_bow_wood_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 622 B After Width: | Height: | Size: 373 B |
BIN
textures/throwing_crossbow.png
Normal file → Executable file
Before Width: | Height: | Size: 673 B After Width: | Height: | Size: 350 B |
BIN
textures/throwing_crossbow_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 677 B After Width: | Height: | Size: 429 B |
BIN
textures/throwing_empty.png
Normal file → Executable file
Before Width: | Height: | Size: 178 B After Width: | Height: | Size: 67 B |
BIN
textures/throwing_longbow.png
Normal file → Executable file
Before Width: | Height: | Size: 661 B After Width: | Height: | Size: 212 B |
BIN
textures/throwing_longbow_loaded.png
Normal file → Executable file
Before Width: | Height: | Size: 674 B After Width: | Height: | Size: 336 B |