mirror of
https://gitlab.com/echoes91/spears.git
synced 2025-07-26 01:40:19 +02:00
Compare commits
26 Commits
3.0
...
6bc97332e6
Author | SHA1 | Date | |
---|---|---|---|
6bc97332e6 | |||
32d0ee567a | |||
5c7ef471ca | |||
dd5c92c0bc | |||
ee21ce3826 | |||
e1459d04cf | |||
60c0656cd1 | |||
57c840451c | |||
440c620bf0 | |||
bc1536223c | |||
81e2c5c343 | |||
299a3134ff | |||
3f3210d172 | |||
e9e7afd6c5 | |||
67b13d723b | |||
152e649fb4 | |||
f9e839435c | |||
4514a8d0a1 | |||
2100c74a21 | |||
b888cda310 | |||
e2182ca004 | |||
a5b33a6e9a | |||
8770387fbc | |||
66c69c5265 | |||
662e637595 | |||
63d339a686 |
@ -1,3 +1,12 @@
|
|||||||
|
Update 3.1.1
|
||||||
|
- Fix all initial settings values and completely deprecate defaults.lua
|
||||||
|
|
||||||
|
Version 3.1:
|
||||||
|
- Initial l18n translations support
|
||||||
|
- Replace stereo sounds with mono
|
||||||
|
- Fix behaviour with initial settings
|
||||||
|
- Clean reduntant variables and deprecate defaults.lua
|
||||||
|
|
||||||
Version 3.0:
|
Version 3.0:
|
||||||
- First attempt to detect collisionboxes
|
- First attempt to detect collisionboxes
|
||||||
- Implemented settings through settingtypes.txt, deprecating "spears.conf"
|
- Implemented settings through settingtypes.txt, deprecating "spears.conf"
|
||||||
|
28
defaults.lua
28
defaults.lua
@ -1,15 +1,15 @@
|
|||||||
-- Seems like defaults in settingtypes.txt are not taken by default
|
-- Seems like defaults in settingtypes.txt are not taken by default
|
||||||
if minetest.settings:get("spears_throw_speed") == nil then
|
--if minetest.settings:get("spears_throw_speed") == nil then
|
||||||
minetest.settings:set("spears_throw_speed", 13)
|
-- minetest.settings:set("spears_throw_speed", 13)
|
||||||
end
|
--end
|
||||||
|
|
||||||
if minetest.settings:get("spears_drag_coeff") == nil then
|
--[[ if minetest.settings:get("spears_drag_coeff") == nil then
|
||||||
minetest.settings:set("spears_drag_coeff", 0.1)
|
minetest.settings:set("spears_drag_coeff", 0.1)
|
||||||
end
|
end ]]
|
||||||
|
|
||||||
if minetest.settings:get("spears_node_cracky_limit") == nil then
|
-- if minetest.settings:get("spears_node_cracky_limit") == nil then
|
||||||
minetest.settings:set("spears_node_cracky_limit", 3)
|
-- minetest.settings:set("spears_node_cracky_limit", 3)
|
||||||
end
|
-- end
|
||||||
|
|
||||||
|
|
||||||
-- DISABLE_STONE_SPEAR = false
|
-- DISABLE_STONE_SPEAR = false
|
||||||
@ -21,10 +21,10 @@ end
|
|||||||
-- DISABLE_GOLD_SPEAR = false
|
-- DISABLE_GOLD_SPEAR = false
|
||||||
-- DISABLE_IRON_SPEAR = false
|
-- DISABLE_IRON_SPEAR = false
|
||||||
-- SPEARS_THROW_SPEED = 13
|
-- SPEARS_THROW_SPEED = 13
|
||||||
SPEARS_V_ZERO = {x = 0, y = 0, z = 0}
|
-- SPEARS_V_ZERO = {x = 0, y = 0, z = 0}
|
||||||
-- SPEARS_DRAG_COEFF = 0.1
|
-- SPEARS_DRAG_COEFF = 0.1
|
||||||
SPEARS_NODE_UNKNOWN = nil
|
-- SPEARS_NODE_UNKNOWN = nil
|
||||||
SPEARS_NODE_THROUGH = 0
|
-- SPEARS_NODE_THROUGH = 0
|
||||||
SPEARS_NODE_STICKY = 1
|
-- SPEARS_NODE_STICKY = 1
|
||||||
SPEARS_NODE_CRACKY = 2
|
-- SPEARS_NODE_CRACKY = 2
|
||||||
-- SPEARS_NODE_CRACKY_LIMIT = 3
|
-- SPEARS_NODE_CRACKY_LIMIT = 3
|
@ -13,12 +13,12 @@ function spears_throw (itemstack, player, pointed_thing)
|
|||||||
if pointed_thing.type == "node" and vector.distance(pointed_a, throw_pos) < 1 then -- Stick into node
|
if pointed_thing.type == "node" and vector.distance(pointed_a, throw_pos) < 1 then -- Stick into node
|
||||||
local node = minetest.get_node(pointed_b)
|
local node = minetest.get_node(pointed_b)
|
||||||
local check_node = spears_check_node(node.name)
|
local check_node = spears_check_node(node.name)
|
||||||
if check_node == SPEARS_NODE_UNKNOWN then
|
if check_node == nil then
|
||||||
return false
|
return false
|
||||||
elseif check_node == SPEARS_NODE_CRACKY then
|
elseif check_node == 'cracky' then
|
||||||
minetest.sound_play("default_metal_footstep", {pos = pointed_a}, true)
|
minetest.sound_play("default_metal_footstep", {pos = pointed_a}, true)
|
||||||
return false
|
return false
|
||||||
elseif check_node == SPEARS_NODE_STICKY then
|
elseif check_node == 'sticky' then
|
||||||
local spear_object = minetest.add_entity(vector.divide(vector.add(vector.multiply(pointed_a, 2), pointed_b), 3), spear)
|
local spear_object = minetest.add_entity(vector.divide(vector.add(vector.multiply(pointed_a, 2), pointed_b), 3), spear)
|
||||||
spear_object:set_rotation(rotation)
|
spear_object:set_rotation(rotation)
|
||||||
spear_object:get_luaentity()._wear = wear
|
spear_object:get_luaentity()._wear = wear
|
||||||
@ -26,11 +26,11 @@ function spears_throw (itemstack, player, pointed_thing)
|
|||||||
minetest.sound_play("default_place_node", {pos = pointed_a}, true)
|
minetest.sound_play("default_place_node", {pos = pointed_a}, true)
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
else -- Avoid hitting yourself and throw
|
else -- Throw
|
||||||
local throw_speed = tonumber(minetest.settings:get("spears_throw_speed"))
|
local throw_speed = tonumber(minetest.settings:get("spears_throw_speed") or 13)
|
||||||
while vector.distance(player_pos, throw_pos) < 1.2 do
|
--while vector.distance(player_pos, throw_pos) < 1.2 do
|
||||||
throw_pos = vector.add(throw_pos, vector.multiply(direction, 0.1))
|
-- throw_pos = vector.add(throw_pos, vector.multiply(direction, 0.1))
|
||||||
end
|
--end
|
||||||
local player_vel = player:get_velocity()
|
local player_vel = player:get_velocity()
|
||||||
local spear_object = minetest.add_entity(throw_pos, spear)
|
local spear_object = minetest.add_entity(throw_pos, spear)
|
||||||
spear_object:set_velocity(vector.add(player_vel, vector.multiply(direction, throw_speed)))
|
spear_object:set_velocity(vector.add(player_vel, vector.multiply(direction, throw_speed)))
|
||||||
@ -38,6 +38,7 @@ function spears_throw (itemstack, player, pointed_thing)
|
|||||||
minetest.sound_play("spears_throw", {pos = player_pos}, true)
|
minetest.sound_play("spears_throw", {pos = player_pos}, true)
|
||||||
spear_object:get_luaentity()._wear = wear
|
spear_object:get_luaentity()._wear = wear
|
||||||
spear_object:get_luaentity()._stickpos = nil
|
spear_object:get_luaentity()._stickpos = nil
|
||||||
|
spear_object:get_luaentity()._owner = player:get_luaentity()
|
||||||
return true
|
return true
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -50,6 +51,7 @@ function spears_set_entity(spear_type, base_damage, toughness)
|
|||||||
visual_size = {x = 0.3, y = 0.3, z = 0.3},
|
visual_size = {x = 0.3, y = 0.3, z = 0.3},
|
||||||
wield_item = "spears:spear_" .. spear_type,
|
wield_item = "spears:spear_" .. spear_type,
|
||||||
collisionbox = {-0.3, -0.3, -0.3, 0.3, 0.3, 0.3},
|
collisionbox = {-0.3, -0.3, -0.3, 0.3, 0.3, 0.3},
|
||||||
|
lastpos={},
|
||||||
},
|
},
|
||||||
|
|
||||||
on_activate = function (self, staticdata, dtime_s)
|
on_activate = function (self, staticdata, dtime_s)
|
||||||
@ -79,7 +81,7 @@ function spears_set_entity(spear_type, base_damage, toughness)
|
|||||||
if self._stickpos ~= nil then -- Spear is stuck
|
if self._stickpos ~= nil then -- Spear is stuck
|
||||||
local node = minetest.get_node(self._stickpos)
|
local node = minetest.get_node(self._stickpos)
|
||||||
local check_node = spears_check_node(node.name)
|
local check_node = spears_check_node(node.name)
|
||||||
if check_node ~= SPEARS_NODE_STICKY then -- Fall when node is removed
|
if check_node ~= 'sticky' then -- Fall when node is removed
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
minetest.add_item(pos, {name='spears:spear_' .. spear_type, wear = wear})
|
minetest.add_item(pos, {name='spears:spear_' .. spear_type, wear = wear})
|
||||||
return false
|
return false
|
||||||
@ -106,31 +108,31 @@ function spears_set_entity(spear_type, base_damage, toughness)
|
|||||||
-- Hit a node?
|
-- Hit a node?
|
||||||
local node = minetest.get_node(spearhead_pos)
|
local node = minetest.get_node(spearhead_pos)
|
||||||
local check_node = spears_check_node(node.name)
|
local check_node = spears_check_node(node.name)
|
||||||
if check_node == SPEARS_NODE_UNKNOWN then
|
if check_node == nil then
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
minetest.add_item(pos, {name='spears:spear_' .. spear_type, wear = wear})
|
minetest.add_item(pos, {name='spears:spear_' .. spear_type, wear = wear})
|
||||||
elseif check_node ~= SPEARS_NODE_THROUGH then
|
elseif check_node ~= 'through' then
|
||||||
wear = spears_wear(wear, toughness)
|
wear = spears_wear(wear, toughness)
|
||||||
if wear >= 65535 then
|
if wear >= 65535 then
|
||||||
minetest.sound_play("default_tool_breaks", {pos = pos}, true)
|
minetest.sound_play("default_tool_breaks", {pos = pos}, true)
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
minetest.add_item(pos, {name='defaut:stick'})
|
minetest.add_item(pos, {name='defaut:stick'})
|
||||||
return false
|
return false
|
||||||
elseif check_node == SPEARS_NODE_CRACKY then
|
elseif check_node == 'cracky' then
|
||||||
minetest.sound_play("default_metal_footstep", {pos = pos}, true)
|
minetest.sound_play("default_metal_footstep", {pos = pos}, true)
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
minetest.add_item(pos, {name='spears:spear_' .. spear_type, wear = wear})
|
minetest.add_item(pos, {name='spears:spear_' .. spear_type, wear = wear})
|
||||||
return false
|
return false
|
||||||
elseif check_node == SPEARS_NODE_STICKY then
|
elseif check_node == 'sticky' then
|
||||||
self.object:set_acceleration(SPEARS_V_ZERO)
|
self.object:set_acceleration({x = 0, y = 0, z = 0})
|
||||||
self.object:set_velocity(SPEARS_V_ZERO)
|
self.object:set_velocity({x = 0, y = 0, z = 0})
|
||||||
minetest.sound_play("default_place_node", {pos = pos}, true)
|
minetest.sound_play("default_place_node", {pos = pos}, true)
|
||||||
self._stickpos = spearhead_pos
|
self._stickpos = spearhead_pos
|
||||||
self._wear = wear
|
self._wear = wear
|
||||||
end
|
end
|
||||||
else -- Get drag
|
else -- Get drag
|
||||||
local viscosity = minetest.registered_nodes[node.name].liquid_viscosity
|
local viscosity = minetest.registered_nodes[node.name].liquid_viscosity
|
||||||
local drag_coeff = tonumber(minetest.settings:get("spears_drag_coeff"))
|
local drag_coeff = tonumber(minetest.settings:get("spears_drag_coeff") or 0.1)
|
||||||
local drag = math.max(viscosity, drag_coeff)
|
local drag = math.max(viscosity, drag_coeff)
|
||||||
local acceleration = vector.multiply(velocity, -drag)
|
local acceleration = vector.multiply(velocity, -drag)
|
||||||
acceleration.y = acceleration.y - 10 * ((7 - drag) / 7)
|
acceleration.y = acceleration.y - 10 * ((7 - drag) / 7)
|
||||||
@ -144,15 +146,15 @@ end
|
|||||||
|
|
||||||
function spears_check_node(node_name)
|
function spears_check_node(node_name)
|
||||||
local node = minetest.registered_nodes[node_name]
|
local node = minetest.registered_nodes[node_name]
|
||||||
local cracky_limit = tonumber(minetest.settings:get("spears_node_cracky_limit"))
|
local cracky_limit = tonumber(minetest.settings:get("spears_node_cracky_limit") or 3)
|
||||||
if node == nil then
|
if node == nil then
|
||||||
return SPEARS_NODE_UNKNOWN
|
return nil
|
||||||
elseif node.groups.cracky ~= nil and node.groups.cracky < cracky_limit then
|
elseif node.groups.cracky ~= nil and node.groups.cracky < cracky_limit then
|
||||||
return SPEARS_NODE_CRACKY
|
return 'cracky'
|
||||||
elseif node.walkable and not node.buildable_to then
|
elseif node.walkable and not node.buildable_to then
|
||||||
return SPEARS_NODE_STICKY
|
return 'sticky'
|
||||||
else
|
else
|
||||||
return SPEARS_NODE_THROUGH
|
return 'through'
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
2
init.lua
2
init.lua
@ -1,4 +1,4 @@
|
|||||||
dofile(minetest.get_modpath("spears").."/defaults.lua")
|
-- dofile(minetest.get_modpath("spears").."/defaults.lua")
|
||||||
|
|
||||||
-- local input = io.open(minetest.get_modpath("spears").."/spears.conf", "r")
|
-- local input = io.open(minetest.get_modpath("spears").."/spears.conf", "r")
|
||||||
-- if input then
|
-- if input then
|
||||||
|
9
locale/spears.eo.tr
Normal file
9
locale/spears.eo.tr
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# textdomain: spears
|
||||||
|
Stone Spear=Ŝtona Ponardego
|
||||||
|
Iron Spear=Fera Ponardego
|
||||||
|
Steel Spear=Ŝtala Ponardego
|
||||||
|
Copper Spear=Kupra Ponardego
|
||||||
|
Bronze Spear=Bronza Ponardego
|
||||||
|
Obsidian Spear=Obsidiana Ponardego
|
||||||
|
Diamond Spear=Diamanta Ponardego
|
||||||
|
Golden Spear=Ora Ponardego
|
9
locale/spears.fr.tr
Normal file
9
locale/spears.fr.tr
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# textdomain: spears
|
||||||
|
|
||||||
|
Stone spear=Lance en pierre
|
||||||
|
Steel spear=Lance en acier
|
||||||
|
Copper spear=Lance en cuivre
|
||||||
|
Bronze spear=Lance en bronze
|
||||||
|
Obsidian spear=Lance en obsidienne
|
||||||
|
Diamond spear=Lance en diamant
|
||||||
|
Golden spear=Lance en or
|
9
locale/spears.it.tr
Normal file
9
locale/spears.it.tr
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# textdomain: spears
|
||||||
|
Stone Spear=Lancia di Pietra
|
||||||
|
Iron Spear=Lancia di Ferro
|
||||||
|
Steel Spear=Lancia di Acciaio
|
||||||
|
Copper Spear=Lancia di Rame
|
||||||
|
Bronze Spear=Lancia di Bronzo
|
||||||
|
Obsidian Spear=Lancia di Ossidiana
|
||||||
|
Diamond Spear=Lancia di Diamante
|
||||||
|
Golden Spear=Lancia Dorata
|
9
locale/template.txt
Normal file
9
locale/template.txt
Normal file
@ -0,0 +1,9 @@
|
|||||||
|
# textdomain: spears
|
||||||
|
Stone Spear=
|
||||||
|
Iron Spear=
|
||||||
|
Steel Spear=
|
||||||
|
Copper Spear=
|
||||||
|
Bronze Spear=
|
||||||
|
Obsidian Spear=
|
||||||
|
Diamond Spear=
|
||||||
|
Golden Spear=
|
1
mod.conf
1
mod.conf
@ -5,4 +5,3 @@ description = Add spears to Minetest, versatile weapons that can be thrown
|
|||||||
author = Echoes91
|
author = Echoes91
|
||||||
title = Spears
|
title = Spears
|
||||||
min_minetest_version = 5.4
|
min_minetest_version = 5.4
|
||||||
|
|
||||||
|
Binary file not shown.
Binary file not shown.
34
tools.lua
34
tools.lua
@ -1,7 +1,9 @@
|
|||||||
|
local S = minetest.get_translator("spears")
|
||||||
|
|
||||||
function spears_register_spear(spear_type, desc, base_damage, toughness, material)
|
function spears_register_spear(spear_type, desc, base_damage, toughness, material)
|
||||||
|
|
||||||
minetest.register_tool("spears:spear_" .. spear_type, {
|
minetest.register_tool("spears:spear_" .. spear_type, {
|
||||||
description = desc .. " spear",
|
description = desc,
|
||||||
wield_image = "spears_spear_" .. spear_type .. ".png^[transform4",
|
wield_image = "spears_spear_" .. spear_type .. ".png^[transform4",
|
||||||
inventory_image = "spears_spear_" .. spear_type .. ".png",
|
inventory_image = "spears_spear_" .. spear_type .. ".png",
|
||||||
wield_scale= {x = 1.5, y = 1.5, z = 1.5},
|
wield_scale= {x = 1.5, y = 1.5, z = 1.5},
|
||||||
@ -13,6 +15,13 @@ function spears_register_spear(spear_type, desc, base_damage, toughness, materia
|
|||||||
return itemstack
|
return itemstack
|
||||||
end,
|
end,
|
||||||
on_place = function(itemstack, user, pointed_thing)
|
on_place = function(itemstack, user, pointed_thing)
|
||||||
|
if pointed_thing.type == "node" then
|
||||||
|
local node = minetest.get_node(pointed_thing.under)
|
||||||
|
if minetest.registered_nodes[node.name] and (node.name == "itemframes:pedestal" or node.name == "itemframes:frame") then
|
||||||
|
minetest.registered_nodes[node.name].on_rightclick(pointed_thing.under, node, user, itemstack)
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
end
|
||||||
spears_throw(itemstack, user, pointed_thing)
|
spears_throw(itemstack, user, pointed_thing)
|
||||||
if not minetest.settings:get_bool("creative_mode") then
|
if not minetest.settings:get_bool("creative_mode") then
|
||||||
itemstack:take_item()
|
itemstack:take_item()
|
||||||
@ -55,43 +64,42 @@ function spears_register_spear(spear_type, desc, base_damage, toughness, materia
|
|||||||
end
|
end
|
||||||
|
|
||||||
if minetest.settings:get_bool('spears_enable_stone_spear') then
|
if minetest.settings:get_bool('spears_enable_stone_spear') then
|
||||||
spears_register_spear('stone', 'Stone', 4, 20, 'group:stone')
|
spears_register_spear('stone', S('Stone Spear'), 4, 20, 'group:stone')
|
||||||
minetest.log("info", "[MOD] Stone spear enabled")
|
|
||||||
end
|
end
|
||||||
|
|
||||||
if minetest.get_modpath("pigiron") then
|
if minetest.get_modpath("pigiron") then
|
||||||
if minetest.settings:get_bool('spears_enable_iron_spear') then
|
if minetest.settings:get_bool('spears_enable_iron_spear') then
|
||||||
spears_register_spear('iron', 'Iron', 5.5, 30, 'pigiron:iron_ingot')
|
spears_register_spear('iron', S('Iron Spear'), 5.5, 30, 'pigiron:iron_ingot')
|
||||||
end
|
end
|
||||||
if minetest.settings:get_bool('spears_enable_steel_spear') then
|
if minetest.settings:get_bool('spears_enable_steel_spear') then
|
||||||
spears_register_spear('steel', 'Steel', 6, 35, 'default:steel_ingot')
|
spears_register_spear('steel', S('Steel Spear'), 6, 35, 'default:steel_ingot')
|
||||||
end
|
end
|
||||||
if minetest.settings:get_bool('spears_enable_copper_spear') then
|
if minetest.settings:get_bool('spears_enable_copper_spear') then
|
||||||
spears_register_spear('copper', 'Copper', 4.8, 30, 'default:copper_ingot')
|
spears_register_spear('copper', S('Copper Spear'), 4.8, 30, 'default:copper_ingot')
|
||||||
end
|
end
|
||||||
if minetest.settings:get_bool('spears_enable_bronze_spear') then
|
if minetest.settings:get_bool('spears_enable_bronze_spear') then
|
||||||
spears_register_spear('bronze', 'Bronze', 5.5, 35, 'default:bronze_ingot')
|
spears_register_spear('bronze', S('Bronze Spear'), 5.5, 35, 'default:bronze_ingot')
|
||||||
end
|
end
|
||||||
else
|
else
|
||||||
if minetest.settings:get_bool('spears_enable_steel_spear') then
|
if minetest.settings:get_bool('spears_enable_steel_spear') then
|
||||||
spears_register_spear('steel', 'Steel', 6, 30, 'default:steel_ingot')
|
spears_register_spear('steel', S('Steel Spear'), 6, 30, 'default:steel_ingot')
|
||||||
end
|
end
|
||||||
if minetest.settings:get_bool('spears_enable_copper_spear') then
|
if minetest.settings:get_bool('spears_enable_copper_spear') then
|
||||||
spears_register_spear('copper', 'Copper', 5, 30, 'default:copper_ingot')
|
spears_register_spear('copper', S('Copper Spear'), 5, 30, 'default:copper_ingot')
|
||||||
end
|
end
|
||||||
if minetest.settings:get_bool('spears_enable_bronze_spear') then
|
if minetest.settings:get_bool('spears_enable_bronze_spear') then
|
||||||
spears_register_spear('bronze', 'Bronze', 6, 35, 'default:bronze_ingot')
|
spears_register_spear('bronze', S('Bronze Spear'), 6, 35, 'default:bronze_ingot')
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if minetest.settings:get_bool('spears_enable_obsidian_spear') then
|
if minetest.settings:get_bool('spears_enable_obsidian_spear') then
|
||||||
spears_register_spear('obsidian', 'Obsidian', 8, 30, 'default:obsidian')
|
spears_register_spear('obsidian', S('Obsidian Spear'), 8, 30, 'default:obsidian')
|
||||||
end
|
end
|
||||||
|
|
||||||
if minetest.settings:get_bool('spears_enable_diamond_spear') then
|
if minetest.settings:get_bool('spears_enable_diamond_spear') then
|
||||||
spears_register_spear('diamond', 'Diamond', 8, 40, 'default:diamond')
|
spears_register_spear('diamond', S('Diamond Spear'), 8, 40, 'default:diamond')
|
||||||
end
|
end
|
||||||
|
|
||||||
if minetest.settings:get_bool('spears_enable_gold_spear') then
|
if minetest.settings:get_bool('spears_enable_gold_spear') then
|
||||||
spears_register_spear('gold', 'Golden', 5, 40, 'default:gold_ingot')
|
spears_register_spear('gold', S('Golden Spear'), 5, 40, 'default:gold_ingot')
|
||||||
end
|
end
|
||||||
|
Reference in New Issue
Block a user