Rearrange the code structure.

This commit is contained in:
bzoss 2020-06-12 19:54:45 -04:00
parent 2c322977a6
commit 7b4ded46f9
4 changed files with 302 additions and 291 deletions

@ -0,0 +1,67 @@
local invisibility = {}
-- reset player invisibility if they go offline
minetest.register_on_leaveplayer(function(player)
local name = player:get_player_name()
if invisibility[name] then
invisibility[name] = nil
end
end)
function mcl_potions.invisible(player, toggle)
if not player then return false end
invisibility[player:get_player_name()] = toggle
if toggle then -- hide player
player:set_properties({visual_size = {x = 0, y = 0}})
player:set_nametag_attributes({color = {a = 0}})
else -- show player
player:set_properties({visual_size = {x = 1, y = 1}})
player:set_nametag_attributes({color = {a = 255}})
end
end
function mcl_potions._use_potion()
minetest.item_eat(0, "mcl_potions:glass_bottle")
minetest.sound_play("mcl_potions_drinking")
end
function mcl_potions.healing_func(player, hp) player:set_hp(player:get_hp() + hp) end
function mcl_potions.swiftness_func(player, factor, duration)
playerphysics.add_physics_factor(player, "speed", "swiftness", factor)
minetest.after(duration, function() playerphysics.remove_physics_factor(player, "speed", "swiftness") end )
end
function mcl_potions.leaping_func(player, factor, duration)
playerphysics.add_physics_factor(player, "jump", "leaping", factor)
minetest.after(duration, function() playerphysics.remove_physics_factor(player, "jump", "leaping") end )
end
function mcl_potions.weakness_func(player, factor, duration)
player:set_attribute("weakness", tostring(factor))
print(player:get_player_name().." ".."weakness = "..player:get_attribute("weakness"))
minetest.after(duration, function() player:set_attribute("weakness", tostring(0)) end )
end
function mcl_potions.poison_func(player, factor, duration)
player:set_attribute("poison", tostring(factor))
print(player:get_player_name().." ".."poison = "..player:get_attribute("poison"))
minetest.after(duration, function() player:set_attribute("poison", tostring(0)) end )
end
function mcl_potions.regeneration_func(player, factor, duration)
player:set_attribute("regeneration", tostring(factor))
print(player:get_player_name().." ".."regeneration = "..player:get_attribute("regeneration"))
minetest.after(duration, function() player:set_attribute("regeneration", tostring(0)) end )
end
function mcl_potions.invisiblility_func(player, duration)
invisible(player, true)
minetest.after(duration, function() invisible(player, false) end )
end

@ -2,7 +2,8 @@ local S = minetest.get_translator("mcl_potions")
mcl_potions = {} mcl_potions = {}
local modpath = minetest.get_modpath("mcl_potions") local modpath = minetest.get_modpath("mcl_potions")
dofile(modpath .. "/invisibility.lua") dofile(modpath .. "/functions.lua")
dofile(modpath .. "/splash.lua")
local brewhelp = S("Put this item in an item frame for decoration. It's useless otherwise.") local brewhelp = S("Put this item in an item frame for decoration. It's useless otherwise.")
@ -137,12 +138,7 @@ local potion_image = function(colorstring, opacity)
return "mcl_potions_potion_overlay.png^[colorize:"..colorstring..":"..tostring(opacity).."^mcl_potions_potion_bottle_drinkable.png" return "mcl_potions_potion_overlay.png^[colorize:"..colorstring..":"..tostring(opacity).."^mcl_potions_potion_bottle_drinkable.png"
end end
local splash_image = function(colorstring, opacity)
if not opacity then
opacity = 127
end
return "mcl_potions_splash_overlay.png^[colorize:"..colorstring..":"..tostring(opacity).."^mcl_potions_splash_bottle.png"
end
-- Cauldron fill up rules: -- Cauldron fill up rules:
-- Adding any water increases the water level by 1, preserving the current water type -- Adding any water increases the water level by 1, preserving the current water type
@ -332,12 +328,6 @@ minetest.register_craftitem("mcl_potions:dragon_breath", {
stack_max = 1, stack_max = 1,
}) })
local function _use_potion()
minetest.item_eat(0, "mcl_potions:glass_bottle")
minetest.sound_play("mcl_potions_drinking")
end
local healing_func = function(player, hp) player:set_hp(player:get_hp() + hp) end
minetest.register_craftitem("mcl_potions:healing", { minetest.register_craftitem("mcl_potions:healing", {
description = S("Healing Potion"), description = S("Healing Potion"),
@ -348,14 +338,14 @@ minetest.register_craftitem("mcl_potions:healing", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
healing_func(user, 4) mcl_potions.healing_func(user, 4)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
healing_func(user, 4) mcl_potions.healing_func(user, 4)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -369,14 +359,14 @@ minetest.register_craftitem("mcl_potions:healing_2", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
healing_func(user, 8) mcl_potions.healing_func(user, 8)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
healing_func(user, 8) mcl_potions.healing_func(user, 8)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
@ -391,14 +381,14 @@ minetest.register_craftitem("mcl_potions:harming", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
healing_func(user, -6) mcl_potions.healing_func(user, -6)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
healing_func(user, -6) mcl_potions.healing_func(user, -6)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -412,14 +402,14 @@ minetest.register_craftitem("mcl_potions:harming_2", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
healing_func(user, -12) mcl_potions.healing_func(user, -12)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
healing_func(user, -12) mcl_potions.healing_func(user, -12)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -434,10 +424,6 @@ minetest.register_craftitem("mcl_potions:night_vision", {
stack_max = 1, stack_max = 1,
}) })
local swiftness_func = function(player, factor, duration)
playerphysics.add_physics_factor(player, "speed", "swiftness", factor)
minetest.after(duration, function() playerphysics.remove_physics_factor(player, "speed", "swiftness") end )
end
minetest.register_craftitem("mcl_potions:swiftness", { minetest.register_craftitem("mcl_potions:swiftness", {
description = S("Swiftness Potion"), description = S("Swiftness Potion"),
@ -448,14 +434,14 @@ minetest.register_craftitem("mcl_potions:swiftness", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
swiftness_func(user, 1.2, 180) mcl_potions.swiftness_func(user, 1.2, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
swiftness_func(user, 1.2, 180) mcl_potions.swiftness_func(user, 1.2, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -469,14 +455,14 @@ minetest.register_craftitem("mcl_potions:swiftness_2", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
swiftness_func(user, 1.4, 90) mcl_potions.swiftness_func(user, 1.4, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
swiftness_func(user, 1.4, 90) mcl_potions.swiftness_func(user, 1.4, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -490,14 +476,14 @@ minetest.register_craftitem("mcl_potions:swiftness_plus", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
swiftness_func(user, 1.2, 480) mcl_potions.swiftness_func(user, 1.2, 480)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
swiftness_func(user, 1.2, 480) mcl_potions.swiftness_func(user, 1.2, 480)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -511,14 +497,14 @@ minetest.register_craftitem("mcl_potions:slowness", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
swiftness_func(user, 0.85, 90) mcl_potions.swiftness_func(user, 0.85, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
swiftness_func(user, 0.85, 90) mcl_potions.swiftness_func(user, 0.85, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -532,21 +518,17 @@ minetest.register_craftitem("mcl_potions:slowness_plus", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
swiftness_func(user, 0.85, 240) mcl_potions.swiftness_func(user, 0.85, 240)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
swiftness_func(user, 0.85, 240) mcl_potions.swiftness_func(user, 0.85, 240)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
local leaping_func = function(player, factor, duration)
playerphysics.add_physics_factor(player, "jump", "leaping", factor)
minetest.after(duration, function() playerphysics.remove_physics_factor(player, "jump", "leaping") end )
end
minetest.register_craftitem("mcl_potions:leaping", { minetest.register_craftitem("mcl_potions:leaping", {
@ -558,14 +540,14 @@ minetest.register_craftitem("mcl_potions:leaping", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
leaping_func(user, 1.2, 180) mcl_potions.leaping_func(user, 1.2, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
leaping_func(user, 1.2, 180) mcl_potions.leaping_func(user, 1.2, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -579,14 +561,14 @@ minetest.register_craftitem("mcl_potions:leaping_2", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
leaping_func(user, 1.4, 90) mcl_potions.leaping_func(user, 1.4, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
leaping_func(user, 1.4, 90) mcl_potions.leaping_func(user, 1.4, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
@ -600,23 +582,19 @@ minetest.register_craftitem("mcl_potions:leaping_plus", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
leaping_func(user, 1.2, 480) mcl_potions.leaping_func(user, 1.2, 480)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
leaping_func(user, 1.2, 480) mcl_potions.leaping_func(user, 1.2, 480)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
}) })
local weakness_func = function(player, factor, duration)
player:set_attribute("weakness", tostring(factor))
print(player:get_player_name().." ".."weakness = "..player:get_attribute("weakness"))
minetest.after(duration, function() player:set_attribute("weakness", tostring(0)) end )
end
minetest.register_craftitem("mcl_potions:weakness", { minetest.register_craftitem("mcl_potions:weakness", {
description = S("Weakness Potion"), description = S("Weakness Potion"),
_doc_items_longdesc = brewhelp, _doc_items_longdesc = brewhelp,
@ -626,23 +604,19 @@ minetest.register_craftitem("mcl_potions:weakness", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
weakness_func(user, 1.2, 180) mcl_potions.weakness_func(user, 1.2, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
weakness_func(user, 1.2, 180) mcl_potions.weakness_func(user, 1.2, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
local poison_func = function(player, factor, duration)
player:set_attribute("poison", tostring(factor))
print(player:get_player_name().." ".."poison = "..player:get_attribute("poison"))
minetest.after(duration, function() player:set_attribute("poison", tostring(0)) end )
end
minetest.register_craftitem("mcl_potions:poison", { minetest.register_craftitem("mcl_potions:poison", {
description = S("Poison Potion"), description = S("Poison Potion"),
_doc_items_longdesc = brewhelp, _doc_items_longdesc = brewhelp,
@ -652,14 +626,14 @@ minetest.register_craftitem("mcl_potions:poison", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
poison_func(user, 2.5, 45) mcl_potions.poison_func(user, 2.5, 45)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
poison_func(user, 2.5, 45) mcl_potions.poison_func(user, 2.5, 45)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
@ -673,14 +647,14 @@ minetest.register_craftitem("mcl_potions:poison_2", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
poison_func(user, 1.2, 21) mcl_potions.poison_func(user, 1.2, 21)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
poison_func(user, 1.2, 21) mcl_potions.poison_func(user, 1.2, 21)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
@ -694,23 +668,19 @@ minetest.register_craftitem("mcl_potions:poison_plus", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
poison_func(user, 2.5, 90) mcl_potions.poison_func(user, 2.5, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
poison_func(user, 2.5, 90) mcl_potions.poison_func(user, 2.5, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
local regeneration_func = function(player, factor, duration)
player:set_attribute("regeneration", tostring(factor))
print(player:get_player_name().." ".."regeneration = "..player:get_attribute("regeneration"))
minetest.after(duration, function() player:set_attribute("regeneration", tostring(0)) end )
end
minetest.register_craftitem("mcl_potions:regeneration", { minetest.register_craftitem("mcl_potions:regeneration", {
description = S("Regeneration Potion"), description = S("Regeneration Potion"),
_doc_items_longdesc = brewhelp, _doc_items_longdesc = brewhelp,
@ -720,14 +690,14 @@ minetest.register_craftitem("mcl_potions:regeneration", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
regeneration_func(user, 2.5, 45) mcl_potions.regeneration_func(user, 2.5, 45)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
regeneration_func(user, 2.5, 45) mcl_potions.regeneration_func(user, 2.5, 45)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
@ -741,14 +711,14 @@ minetest.register_craftitem("mcl_potions:regeneration_2", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
regeneration_func(user, 1.2, 21) mcl_potions.regeneration_func(user, 1.2, 21)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
regeneration_func(user, 1.2, 21) mcl_potions.regeneration_func(user, 1.2, 21)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
@ -762,22 +732,18 @@ minetest.register_craftitem("mcl_potions:regeneration_plus", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
regeneration_func(user, 2.5, 90) mcl_potions.regeneration_func(user, 2.5, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
regeneration_func(user, 2.5, 90) mcl_potions.regeneration_func(user, 2.5, 90)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
local invisiblility_func = function(player, duration)
invisible(player, true)
minetest.after(duration, function() mcl_potions.invisible(player, false) end )
end
minetest.register_craftitem("mcl_potions:invisibility", { minetest.register_craftitem("mcl_potions:invisibility", {
description = S("Invisibility Potion"), description = S("Invisibility Potion"),
@ -788,14 +754,14 @@ minetest.register_craftitem("mcl_potions:invisibility", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
invisiblility_func(user, 180) mcl_potions.invisiblility_func(user, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
invisiblility_func(user, 180) mcl_potions.invisiblility_func(user, 180)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
@ -809,14 +775,14 @@ minetest.register_craftitem("mcl_potions:invisibility_plus", {
stack_max = 1, stack_max = 1,
on_place = function(itemstack, user, pointed_thing) on_place = function(itemstack, user, pointed_thing)
invisiblility_func(user, 480) mcl_potions.invisiblility_func(user, 480)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end, end,
on_secondary_use = function(itemstack, user, pointed_thing) on_secondary_use = function(itemstack, user, pointed_thing)
invisiblility_func(user, 480) mcl_potions.invisiblility_func(user, 480)
_use_potion() mcl_potions._use_potion()
return itemstack return itemstack
end end
}) })
@ -829,144 +795,6 @@ minetest.register_on_punchnode(function(pos, node, puncher, pointed_thing)
end) end)
function register_splash(name, descr, color, def)
local id = "mcl_potions:"..name.."_splash"
minetest.register_craftitem(id, {
description = descr,
inventory_image = splash_image(color),
on_use = function(itemstack, placer, pointed_thing)
--weapons_shot(itemstack, placer, pointed_thing, def.velocity, name)
local velocity = 10
local dir = placer:get_look_dir();
local pos = placer:getpos();
local obj = minetest.env:add_entity({x=pos.x+dir.x,y=pos.y+2+dir.y,z=pos.z+dir.z}, id.."_flying")
obj:setvelocity({x=dir.x*velocity,y=dir.y*velocity,z=dir.z*velocity})
obj:setacceleration({x=0, y=-9.8, z=0})
itemstack:take_item()
return itemstack
end,
})
local w = 0.35
minetest.register_entity(id.."_flying",{
textures = {splash_image(color)},
hp_max = 1,
visual_size = {x=w,y=w},
collisionbox = {-w,-w,-w, w,w,w},
on_step = function(self, dtime)
local pos = self.object:getpos()
local node = minetest.get_node(pos)
local n = node.name
local d = 2
if n ~= "air" then
minetest.sound_play("mcl_potions_breaking_glass")
minetest.add_particlespawner({
amount = 40,
time = 2,
minpos = {x=pos.x-d, y=pos.y, z=pos.z-d},
maxpos = {x=pos.x+d, y=pos.y+1, z=pos.z+d},
minvel = {x=-1, y=0, z=-1},
maxvel = {x=1, y=0.5, z=1},
minacc = {x=-0.5, y=0, z=-0.5},
maxacc = {x=0.5, y=.2, z=0.5},
minexptime = 1,
maxexptime = 5,
minsize = 2,
maxsize = 4,
collisiondetection = true,
vertical = false,
texture = "mcl_potions_sprite.png^[colorize:"..color..":127",
})
self.object:remove()
for i, obj in ipairs(minetest.get_objects_inside_radius(pos, 3)) do
if minetest.is_player(obj) then def.potion_fun(obj) end
end
end
end,
})
end
register_splash("healing", "Splash Healing", "#AA0000", {
potion_fun = function(player) player:set_hp(player:get_hp() + 3) end,
})
register_splash("healing_2", "Splash Healing II", "#DD0000", {
potion_fun = function(player) player:set_hp(player:get_hp() + 6) end,
})
register_splash("harming", "Splash Harming", "#660099", {
potion_fun = function(player) healing_func(player, -4) end,
})
register_splash("harming_2", "Splash Harming II", "#330066", {
potion_fun = function(player) healing_func(player, -6) end,
})
register_splash("leaping", "Splash Leaping", "#00CC33", {
potion_fun = function(player) leaping_func(player, 1.2, 135) end
})
register_splash("leaping_2", "Splash Leaping II", "#00EE33", {
potion_fun = function(player) leaping_func(player, 1.4, 135) end
})
register_splash("leaping_plus", "Splash Leaping +", "#00DD33", {
potion_fun = function(player) leaping_func(player, 1.2, 360) end
})
register_splash("swiftness", "Splash Swiftness", "#009999", {
potion_fun = function(player) swiftness_func(player, 1.2, 135) end
})
register_splash("swiftness_2", "Splash Swiftness II", "#00BBBB", {
potion_fun = function(player) swiftness_func(player, 1.4, 135) end
})
register_splash("swiftness_plus", "Splash Swiftness +", "#00BBBB", {
potion_fun = function(player) swiftness_func(player, 1.2, 360) end
})
register_splash("slowness", "Splash Slowness ", "#000080", {
potion_fun = function(player) swiftness_func(player, 0.85, 68) end
})
register_splash("slowness_plus", "Splash Slowness +", "#000066", {
potion_fun = function(player) swiftness_func(player, 0.85, 180) end
})
register_splash("poison", "Splash Poison", "#335544", {
potion_fun = function(player) poison_func(player, 0.85, 180) end
})
register_splash("poison_2", "Splash Poison II", "#446655", {
potion_fun = function(player) poison_func(player, 0.85, 180) end
})
register_splash("poison_plus", "Splash Poison II", "#557766", {
potion_fun = function(player) poison_func(player, 0.85, 180) end
})
register_splash("regeneration", "Splash Regeneration", "#A52BB2", {
potion_fun = function(player) regeneration_func(player, 0.85, 180) end
})
register_splash("regeneration_2", "Splash Regeneration II", "#B52CC2", {
potion_fun = function(player) regeneration_func(player, 0.85, 180) end
})
register_splash("regeneration_plus", "Splash Regeneration +", "#C53DD3", {
potion_fun = function(player) regeneration_func(player, 0.85, 180) end
})
register_splash("invisibility", "Splash Invisibility", "#B0B0B0", {
potion_fun = function(player) invisiblility_func(player, 135) end
})
register_splash("invisibility", "Splash Invisibility", "#A0A0A0", {
potion_fun = function(player) invisiblility_func(player, 300) end
})
-- duration effects of redstone are a factor of 8/3 -- duration effects of redstone are a factor of 8/3
-- duration effects of glowstone are a time factor of 1/2 and effect of 14/12 -- duration effects of glowstone are a time factor of 1/2 and effect of 14/12
@ -1036,7 +864,6 @@ local mod_table = {
["mcl_mobitems:gunpowder"] = splash_table, ["mcl_mobitems:gunpowder"] = splash_table,
} }
mcl_potions = {}
-- Compare two ingredients for compatable alchemy -- Compare two ingredients for compatable alchemy
function mcl_potions.get_alchemy(ingr, pot) function mcl_potions.get_alchemy(ingr, pot)

@ -1,28 +0,0 @@
-- invisibility function
invisibility = {}
-- reset player invisibility if they go offline
minetest.register_on_leaveplayer(function(player)
local name = player:get_player_name()
if invisibility[name] then
invisibility[name] = nil
end
end)
invisible = function(player, toggle)
if not player then return false end
invisibility[player:get_player_name()] = toggle
if toggle then -- hide player
player:set_properties({visual_size = {x = 0, y = 0}})
player:set_nametag_attributes({color = {a = 0}})
else -- show player
player:set_properties({visual_size = {x = 1, y = 1}})
player:set_nametag_attributes({color = {a = 255}})
end
end

@ -0,0 +1,145 @@
local splash_image = function(colorstring, opacity)
if not opacity then
opacity = 127
end
return "mcl_potions_splash_overlay.png^[colorize:"..colorstring..":"..tostring(opacity).."^mcl_potions_splash_bottle.png"
end
local function register_splash(name, descr, color, def)
local id = "mcl_potions:"..name.."_splash"
minetest.register_craftitem(id, {
description = descr,
inventory_image = splash_image(color),
on_use = function(itemstack, placer, pointed_thing)
--weapons_shot(itemstack, placer, pointed_thing, def.velocity, name)
local velocity = 10
local dir = placer:get_look_dir();
local pos = placer:getpos();
local obj = minetest.env:add_entity({x=pos.x+dir.x,y=pos.y+2+dir.y,z=pos.z+dir.z}, id.."_flying")
obj:setvelocity({x=dir.x*velocity,y=dir.y*velocity,z=dir.z*velocity})
obj:setacceleration({x=0, y=-9.8, z=0})
itemstack:take_item()
return itemstack
end,
})
local w = 0.35
minetest.register_entity(id.."_flying",{
textures = {splash_image(color)},
hp_max = 1,
visual_size = {x=w,y=w},
collisionbox = {-w,-w,-w, w,w,w},
on_step = function(self, dtime)
local pos = self.object:getpos()
local node = minetest.get_node(pos)
local n = node.name
local d = 2
if n ~= "air" then
minetest.sound_play("mcl_potions_breaking_glass")
minetest.add_particlespawner({
amount = 40,
time = 2,
minpos = {x=pos.x-d, y=pos.y, z=pos.z-d},
maxpos = {x=pos.x+d, y=pos.y+1, z=pos.z+d},
minvel = {x=-1, y=0, z=-1},
maxvel = {x=1, y=0.5, z=1},
minacc = {x=-0.5, y=0, z=-0.5},
maxacc = {x=0.5, y=.2, z=0.5},
minexptime = 1,
maxexptime = 5,
minsize = 2,
maxsize = 4,
collisiondetection = true,
vertical = false,
texture = "mcl_potions_sprite.png^[colorize:"..color..":127",
})
self.object:remove()
for i, obj in ipairs(minetest.get_objects_inside_radius(pos, 3)) do
if minetest.is_player(obj) then def.potion_fun(obj) end
end
end
end,
})
end
register_splash("healing", "Splash Healing", "#AA0000", {
potion_fun = function(player) player:set_hp(player:get_hp() + 3) end,
})
register_splash("healing_2", "Splash Healing II", "#DD0000", {
potion_fun = function(player) player:set_hp(player:get_hp() + 6) end,
})
register_splash("harming", "Splash Harming", "#660099", {
potion_fun = function(player) mcl_potions.healing_func(player, -4) end,
})
register_splash("harming_2", "Splash Harming II", "#330066", {
potion_fun = function(player) mcl_potions.healing_func(player, -6) end,
})
register_splash("leaping", "Splash Leaping", "#00CC33", {
potion_fun = function(player) mcl_potions.leaping_func(player, 1.2, 135) end
})
register_splash("leaping_2", "Splash Leaping II", "#00EE33", {
potion_fun = function(player) mcl_potions.leaping_func(player, 1.4, 135) end
})
register_splash("leaping_plus", "Splash Leaping +", "#00DD33", {
potion_fun = function(player) mcl_potions.leaping_func(player, 1.2, 360) end
})
register_splash("swiftness", "Splash Swiftness", "#009999", {
potion_fun = function(player) mcl_potions.swiftness_func(player, 1.2, 135) end
})
register_splash("swiftness_2", "Splash Swiftness II", "#00BBBB", {
potion_fun = function(player) mcl_potions.swiftness_func(player, 1.4, 135) end
})
register_splash("swiftness_plus", "Splash Swiftness +", "#00BBBB", {
potion_fun = function(player) mcl_potions.swiftness_func(player, 1.2, 360) end
})
register_splash("slowness", "Splash Slowness ", "#000080", {
potion_fun = function(player) mcl_potions.swiftness_func(player, 0.85, 68) end
})
register_splash("slowness_plus", "Splash Slowness +", "#000066", {
potion_fun = function(player) mcl_potions.swiftness_func(player, 0.85, 180) end
})
register_splash("poison", "Splash Poison", "#335544", {
potion_fun = function(player) mcl_potions.poison_func(player, 0.85, 180) end
})
register_splash("poison_2", "Splash Poison II", "#446655", {
potion_fun = function(player) mcl_potions.poison_func(player, 0.85, 180) end
})
register_splash("poison_plus", "Splash Poison II", "#557766", {
potion_fun = function(player) mcl_potions.poison_func(player, 0.85, 180) end
})
register_splash("regeneration", "Splash Regeneration", "#A52BB2", {
potion_fun = function(player) mcl_potions.regeneration_func(player, 0.85, 180) end
})
register_splash("regeneration_2", "Splash Regeneration II", "#B52CC2", {
potion_fun = function(player) mcl_potions.regeneration_func(player, 0.85, 180) end
})
register_splash("regeneration_plus", "Splash Regeneration +", "#C53DD3", {
potion_fun = function(player) mcl_potions.regeneration_func(player, 0.85, 180) end
})
register_splash("invisibility", "Splash Invisibility", "#B0B0B0", {
potion_fun = function(player) mcl_potions.invisiblility_func(player, 135) end
})
register_splash("invisibility", "Splash Invisibility", "#A0A0A0", {
potion_fun = function(player) mcl_potions.invisiblility_func(player, 300) end
})