fishing-0.2.1
New water lilies and seaweed (plantlife) can be caught when they share the same space with the bobber. A chance to catch a blue white fish (mobf) when it's near to the bobber.
This commit is contained in:
parent
37aa0d6bfd
commit
9babaf625a
96
bobber.lua
96
bobber.lua
@ -1,5 +1,5 @@
|
|||||||
-----------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------
|
||||||
-- Fishing - Mossmanikin's version - Bobber 0.1.6
|
-- Fishing - Mossmanikin's version - Bobber 0.1.7
|
||||||
-- License (code & textures): WTFPL
|
-- License (code & textures): WTFPL
|
||||||
-- Contains code from: fishing (original), mobs, throwing, volcano
|
-- Contains code from: fishing (original), mobs, throwing, volcano
|
||||||
-- Supports: 3d_armor, animal_clownfish, animal_fish_blue_white, animal_rat, flowers_plus, mobs, seaplants
|
-- Supports: 3d_armor, animal_clownfish, animal_fish_blue_white, animal_rat, flowers_plus, mobs, seaplants
|
||||||
@ -25,6 +25,29 @@ local CaTCH = {
|
|||||||
}
|
}
|
||||||
minetest.register_alias("flowers_plus:seaweed", "flowers:seaweed") -- exception
|
minetest.register_alias("flowers_plus:seaweed", "flowers:seaweed") -- exception
|
||||||
|
|
||||||
|
local PLaNTS = {
|
||||||
|
-- MoD* iTeM MeSSaGe ("You caught "..)
|
||||||
|
{"flowers", "waterlily", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_225", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_45", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_675", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s1", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s2", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s3", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s4", "a Waterlily." },
|
||||||
|
{"flowers", "seaweed", "some Seaweed."},
|
||||||
|
{"flowers", "seaweed_2", "some Seaweed."},
|
||||||
|
{"flowers", "seaweed_3", "some Seaweed."},
|
||||||
|
{"flowers", "seaweed_4", "some Seaweed."},
|
||||||
|
}
|
||||||
|
-- *as used in the node name
|
||||||
|
|
||||||
|
local MoBS = { -- not in use
|
||||||
|
-- iTeM MeSSaGe ("You caught "..)
|
||||||
|
{"animal_clownfish:clownfish", "a Clownfish." },
|
||||||
|
{"animal_fish_blue_white:fish_blue_white", "a Blue white fish."},
|
||||||
|
}
|
||||||
|
|
||||||
minetest.register_node("fishing:bobber_box", {
|
minetest.register_node("fishing:bobber_box", {
|
||||||
drawtype = "nodebox",
|
drawtype = "nodebox",
|
||||||
node_box = {
|
node_box = {
|
||||||
@ -63,10 +86,13 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
local player = puncher:get_player_name()
|
local player = puncher:get_player_name()
|
||||||
local inv = puncher:get_inventory()
|
local inv = puncher:get_inventory()
|
||||||
if MESSAGES == true then minetest.chat_send_player(player, "You didn't catch anything.", false) end -- fish escaped
|
if MESSAGES == true then minetest.chat_send_player(player, "You didn't catch anything.", false) end -- fish escaped
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
||||||
if MESSAGES == true then minetest.chat_send_player(player, "The bait is still there.", false) end -- bait still there
|
if MESSAGES == true then minetest.chat_send_player(player, "The bait is still there.", false) end -- bait still there
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
-- make sound and remove bobber
|
||||||
minetest.sound_play("fishing_bobber1", {
|
minetest.sound_play("fishing_bobber1", {
|
||||||
pos = self.object:getpos(),
|
pos = self.object:getpos(),
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
@ -79,23 +105,31 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
local player = clicker:get_player_name()
|
local player = clicker:get_player_name()
|
||||||
if item:get_name() == "fishing:pole" then
|
if item:get_name() == "fishing:pole" then
|
||||||
local inv = clicker:get_inventory()
|
local inv = clicker:get_inventory()
|
||||||
--local room_fish = inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
|
||||||
local say = minetest.chat_send_player
|
local say = minetest.chat_send_player
|
||||||
local pos = self.object:getpos()
|
local pos = self.object:getpos()
|
||||||
if minetest.env:get_node(pos).name == "flowers:waterlily"
|
-- catch visible plant
|
||||||
or minetest.env:get_node(pos).name == "flowers:waterlily_225"
|
if minetest.get_node(pos).name ~= "air" then
|
||||||
or minetest.env:get_node(pos).name == "flowers:waterlily_45"
|
for i in ipairs(PLaNTS) do
|
||||||
or minetest.env:get_node(pos).name == "flowers:waterlily_675" then
|
local PLaNT = PLaNTS[i][1]..":"..PLaNTS[i][2]
|
||||||
minetest.env:add_node({x=pos.x, y=pos.y, z=pos.z}, {name="air"})
|
local MeSSaGe = PLaNTS[i][3]
|
||||||
if inv:room_for_item("main", {name="flowers:waterlily", count=1, wear=WeaR, metadata=""}) then
|
local DRoP = minetest.registered_nodes[PLaNT].drop
|
||||||
inv:add_item("main", {name="flowers:waterlily", count=1, wear=WeaR, metadata=""})
|
if minetest.get_node(pos).name == PLaNT then
|
||||||
if MESSAGES == true then say(player, "You caught a Waterlily", false) end -- caught Waterlily
|
minetest.add_node({x=pos.x, y=pos.y, z=pos.z}, {name="air"})
|
||||||
|
if inv:room_for_item("main", {name=DRoP, count=1, wear=0, metadata=""}) then
|
||||||
|
inv:add_item("main", {name=DRoP, count=1, wear=0, metadata=""})
|
||||||
|
if MESSAGES == true then say(player, "You caught "..MeSSaGe, false) end -- caught Plant
|
||||||
end
|
end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
||||||
if MESSAGES == true then say(player, "The bait is still there.", false) end -- bait still there
|
if MESSAGES == true then say(player, "The bait is still there.", false) end -- bait still there
|
||||||
end
|
end
|
||||||
elseif self.object:get_hp() <= 300 then
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- catch visible fish and invisible stuff
|
||||||
|
if self.object:get_hp() <= 300 then
|
||||||
if math.random(1, 100) < FISH_CHANCE then
|
if math.random(1, 100) < FISH_CHANCE then
|
||||||
local chance = math.random(1, 120) -- ><((((º>
|
local chance = math.random(1, 120) -- ><((((º>
|
||||||
for i in pairs(CaTCH) do
|
for i in pairs(CaTCH) do
|
||||||
@ -109,16 +143,30 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
local NRMaX = NRMiN + CHaNCe - 1
|
local NRMaX = NRMiN + CHaNCe - 1
|
||||||
if chance <= NRMaX and chance >= NRMiN then
|
if chance <= NRMaX and chance >= NRMiN then
|
||||||
if minetest.get_modpath(MoD) ~= nil then
|
if minetest.get_modpath(MoD) ~= nil then
|
||||||
|
-- remove visible fish, if there
|
||||||
|
local find_fish = minetest.get_objects_inside_radius({x=pos.x,y=pos.y+0.5,z=pos.z}, 1)
|
||||||
|
for k, obj in pairs(find_fish) do
|
||||||
|
if obj:get_luaentity() ~= nil and obj:get_luaentity().name == "animal_fish_blue_white:fish_blue_white" then
|
||||||
|
MoD = "animal_fish_blue_white"
|
||||||
|
iTeM = "fish_blue_white"
|
||||||
|
WeaR = 0
|
||||||
|
MeSSaGe = "a Blue white fish."
|
||||||
|
obj:remove()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
-- add (in)visible fish to inventory
|
||||||
if inv:room_for_item("main", {name=MoD..":"..iTeM, count=1, wear=WeaR, metadata=""}) then
|
if inv:room_for_item("main", {name=MoD..":"..iTeM, count=1, wear=WeaR, metadata=""}) then
|
||||||
inv:add_item("main", {name=MoD..":"..iTeM, count=1, wear=WeaR, metadata=""})
|
inv:add_item("main", {name=MoD..":"..iTeM, count=1, wear=WeaR, metadata=""})
|
||||||
if MESSAGES == true then say(player, "You caught "..MeSSaGe, false) end -- caught somethin'
|
if MESSAGES == true then say(player, "You caught "..MeSSaGe, false) end -- caught somethin'
|
||||||
end
|
end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if GeTBaiTBack == true then
|
if GeTBaiTBack == true then
|
||||||
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
||||||
if MESSAGES == true then say(player, "The bait is still there.", false) end -- bait still there?
|
if MESSAGES == true then say(player, "The bait is still there.", false) end -- bait still there?
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
else
|
else
|
||||||
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
||||||
@ -130,8 +178,10 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
else --if math.random(1, 100) > FISH_CHANCE then
|
else --if math.random(1, 100) > FISH_CHANCE then
|
||||||
if MESSAGES == true then say(player, "Your fish escaped.", false) end -- fish escaped
|
if MESSAGES == true then say(player, "Your fish escaped.", false) end -- fish escaped
|
||||||
end
|
end
|
||||||
else -- if self.object:get_hp() > 300 then
|
end
|
||||||
|
if self.object:get_hp() > 300 and minetest.get_node(pos).name == "air" then
|
||||||
if MESSAGES == true then say(player, "You didn't catch anything.", false) end -- fish escaped
|
if MESSAGES == true then say(player, "You didn't catch anything.", false) end -- fish escaped
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if math.random(1, 2) == 1 then
|
if math.random(1, 2) == 1 then
|
||||||
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
||||||
@ -140,6 +190,9 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
-- weither player has fishing pole or not
|
||||||
|
-- make sound and remove bobber
|
||||||
minetest.sound_play("fishing_bobber1", {
|
minetest.sound_play("fishing_bobber1", {
|
||||||
pos = self.object:getpos(),
|
pos = self.object:getpos(),
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
@ -150,7 +203,7 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
on_step = function(self, dtime)
|
on_step = function(self, dtime)
|
||||||
local pos = self.object:getpos()
|
local pos = self.object:getpos()
|
||||||
if BOBBER_CHECK_RADIUS > 0 then
|
if BOBBER_CHECK_RADIUS > 0 then
|
||||||
local objs = minetest.env:get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, BOBBER_CHECK_RADIUS)
|
local objs = minetest.get_objects_inside_radius(pos, BOBBER_CHECK_RADIUS)
|
||||||
for k, obj in pairs(objs) do
|
for k, obj in pairs(objs) do
|
||||||
if obj:get_luaentity() ~= nil then
|
if obj:get_luaentity() ~= nil then
|
||||||
if obj:get_luaentity().name == "fishing:bobber_entity" then
|
if obj:get_luaentity().name == "fishing:bobber_entity" then
|
||||||
@ -170,6 +223,7 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
local p = player:getpos()
|
local p = player:getpos()
|
||||||
local dist = ((p.x-s.x)^2 + (p.y-s.y)^2 + (p.z-s.z)^2)^0.5
|
local dist = ((p.x-s.x)^2 + (p.y-s.y)^2 + (p.z-s.z)^2)^0.5
|
||||||
if dist > self.view_range then
|
if dist > self.view_range then
|
||||||
|
-- make sound and remove bobber
|
||||||
minetest.sound_play("fishing_bobber1", {
|
minetest.sound_play("fishing_bobber1", {
|
||||||
pos = self.object:getpos(),
|
pos = self.object:getpos(),
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
@ -177,6 +231,21 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
self.object:remove()
|
self.object:remove()
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
if self.object:get_hp() > 310 then
|
||||||
|
local find_fish = minetest.get_objects_inside_radius({x=pos.x,y=pos.y+0.5,z=pos.z}, 1)
|
||||||
|
for k, obj in pairs(find_fish) do
|
||||||
|
if obj:get_luaentity() ~= nil then
|
||||||
|
if obj:get_luaentity().name == "animal_fish_blue_white:fish_blue_white" then
|
||||||
|
if math.random(1, 30) == 1 then
|
||||||
|
self.object:set_hp(310)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
local do_env_damage = function(self)
|
local do_env_damage = function(self)
|
||||||
self.object:set_hp(self.object:get_hp()-self.water_damage)
|
self.object:set_hp(self.object:get_hp()-self.water_damage)
|
||||||
if self.object:get_hp() == 600 then
|
if self.object:get_hp() == 600 then
|
||||||
@ -211,6 +280,7 @@ local FISHING_BOBBER_ENTITY={
|
|||||||
self.object:moveto({x=pos.x+(0.001*(math.random(-8, 8))),y=pos.y,z=pos.z+(0.001*(math.random(-8, 8)))})
|
self.object:moveto({x=pos.x+(0.001*(math.random(-8, 8))),y=pos.y,z=pos.z+(0.001*(math.random(-8, 8)))})
|
||||||
self.object:setyaw(self.object:getyaw()+((math.random(0,360)-180)/1440*math.pi))
|
self.object:setyaw(self.object:getyaw()+((math.random(0,360)-180)/1440*math.pi))
|
||||||
elseif self.object:get_hp() == 0 then
|
elseif self.object:get_hp() == 0 then
|
||||||
|
-- make sound and remove bobber
|
||||||
minetest.sound_play("fishing_bobber1", {
|
minetest.sound_play("fishing_bobber1", {
|
||||||
pos = self.object:getpos(),
|
pos = self.object:getpos(),
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
|
@ -1,5 +1,5 @@
|
|||||||
-----------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------
|
||||||
-- Fishing - Mossmanikin's version - Bobber Shark 0.0.4
|
-- Fishing - Mossmanikin's version - Bobber Shark 0.0.5
|
||||||
-- License (code & textures): WTFPL
|
-- License (code & textures): WTFPL
|
||||||
-----------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------
|
||||||
|
|
||||||
@ -10,6 +10,23 @@ local CaTCH_BiG = {
|
|||||||
{"fishing", "pike", 0, "a Northern Pike.", false, 3, 3}
|
{"fishing", "pike", 0, "a Northern Pike.", false, 3, 3}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local PLaNTS = {
|
||||||
|
-- MoD* iTeM MeSSaGe ("You caught "..)
|
||||||
|
{"flowers", "waterlily", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_225", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_45", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_675", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s1", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s2", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s3", "a Waterlily." },
|
||||||
|
{"flowers", "waterlily_s4", "a Waterlily." },
|
||||||
|
{"flowers", "seaweed", "some Seaweed."},
|
||||||
|
{"flowers", "seaweed_2", "some Seaweed."},
|
||||||
|
{"flowers", "seaweed_3", "some Seaweed."},
|
||||||
|
{"flowers", "seaweed_4", "some Seaweed."},
|
||||||
|
}
|
||||||
|
-- *as used in the node name
|
||||||
|
|
||||||
local FISHING_BOBBER_ENTITY_SHARK={
|
local FISHING_BOBBER_ENTITY_SHARK={
|
||||||
hp_max = 605,
|
hp_max = 605,
|
||||||
water_damage = 1,
|
water_damage = 1,
|
||||||
@ -40,20 +57,28 @@ local FISHING_BOBBER_ENTITY_SHARK={
|
|||||||
if item:get_name() == "fishing:pole" then
|
if item:get_name() == "fishing:pole" then
|
||||||
local inv = clicker:get_inventory()
|
local inv = clicker:get_inventory()
|
||||||
local pos = self.object:getpos()
|
local pos = self.object:getpos()
|
||||||
if minetest.env:get_node(pos).name == "flowers:waterlily"
|
-- catch visible plant
|
||||||
or minetest.env:get_node(pos).name == "flowers:waterlily_225"
|
if minetest.get_node(pos).name ~= "air" then
|
||||||
or minetest.env:get_node(pos).name == "flowers:waterlily_45"
|
for i in ipairs(PLaNTS) do
|
||||||
or minetest.env:get_node(pos).name == "flowers:waterlily_675" then
|
local PLaNT = PLaNTS[i][1]..":"..PLaNTS[i][2]
|
||||||
minetest.env:add_node({x=pos.x, y=pos.y, z=pos.z}, {name="air"})
|
local MeSSaGe = PLaNTS[i][3]
|
||||||
if inv:room_for_item("main", {name="flowers:waterlily", count=1, wear=WeaR, metadata=""}) then
|
local DRoP = minetest.registered_nodes[PLaNT].drop
|
||||||
inv:add_item("main", {name="flowers:waterlily", count=1, wear=WeaR, metadata=""})
|
if minetest.get_node(pos).name == PLaNT then
|
||||||
if MESSAGES == true then say(player, "You caught a Waterlily", false) end -- caught Waterlily
|
minetest.add_node({x=pos.x, y=pos.y, z=pos.z}, {name="air"})
|
||||||
|
if inv:room_for_item("main", {name=DRoP, count=1, wear=0, metadata=""}) then
|
||||||
|
inv:add_item("main", {name=DRoP, count=1, wear=0, metadata=""})
|
||||||
|
if MESSAGES == true then say(player, "You caught "..MeSSaGe, false) end -- caught Plant
|
||||||
end
|
end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""})
|
||||||
if MESSAGES == true then say(player, "The bait is still there.", false) end -- bait still there
|
if MESSAGES == true then say(player, "The bait is still there.", false) end -- bait still there
|
||||||
end
|
end
|
||||||
elseif self.object:get_hp() <= 300 then
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
if self.object:get_hp() <= 300 then
|
||||||
if math.random(1, 100) < SHARK_CHANCE then
|
if math.random(1, 100) < SHARK_CHANCE then
|
||||||
local chance = math.random(1, 6) -- ><((((º>
|
local chance = math.random(1, 6) -- ><((((º>
|
||||||
for i in pairs(CaTCH_BiG) do
|
for i in pairs(CaTCH_BiG) do
|
||||||
@ -71,6 +96,7 @@ local FISHING_BOBBER_ENTITY_SHARK={
|
|||||||
inv:add_item("main", {name=MoD..":"..iTeM, count=1, wear=WeaR, metadata=""})
|
inv:add_item("main", {name=MoD..":"..iTeM, count=1, wear=WeaR, metadata=""})
|
||||||
if MESSAGES == true then say(player, "You caught "..MeSSaGe, false) end -- caught somethin'
|
if MESSAGES == true then say(player, "You caught "..MeSSaGe, false) end -- caught somethin'
|
||||||
end
|
end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if GeTBaiTBack == true then
|
if GeTBaiTBack == true then
|
||||||
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
||||||
@ -80,11 +106,14 @@ local FISHING_BOBBER_ENTITY_SHARK={
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
else --if math.random(1, 100) > FISH_CHANCE then
|
else --if math.random(1, 100) > FISH_CHANCE then
|
||||||
if MESSAGES == true then say(player, "Your fish escaped.", false) end -- fish escaped
|
if MESSAGES == true then say(player, "Your fish escaped.", false) end -- fish escaped
|
||||||
end
|
end
|
||||||
else
|
end
|
||||||
|
if self.object:get_hp() > 300 and minetest.get_node(pos).name == "air" then
|
||||||
if MESSAGES == true then say(player, "You didn't catch anything.", false) end -- fish escaped
|
if MESSAGES == true then say(player, "You didn't catch anything.", false) end -- fish escaped
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
if math.random(1, 3) == 1 then
|
if math.random(1, 3) == 1 then
|
||||||
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""}) then
|
||||||
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
inv:add_item("main", {name="fishing:fish_raw", count=1, wear=0, metadata=""})
|
||||||
@ -92,6 +121,7 @@ local FISHING_BOBBER_ENTITY_SHARK={
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
else
|
else
|
||||||
if MESSAGES == true then say(player, "Your fish escaped.", false) end -- fish escaped
|
if MESSAGES == true then say(player, "Your fish escaped.", false) end -- fish escaped
|
||||||
end
|
end
|
||||||
|
38
init.lua
38
init.lua
@ -1,6 +1,6 @@
|
|||||||
-----------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------
|
||||||
local title = "Fishing - Mossmanikin's version"
|
local title = "Fishing - Mossmanikin's version"
|
||||||
local version = "0.2.0"
|
local version = "0.2.1"
|
||||||
local mname = "fishing"
|
local mname = "fishing"
|
||||||
-----------------------------------------------------------------------------------------------
|
-----------------------------------------------------------------------------------------------
|
||||||
-- original by wulfsdad (http://forum.minetest.net/viewtopic.php?id=4375)
|
-- original by wulfsdad (http://forum.minetest.net/viewtopic.php?id=4375)
|
||||||
@ -54,33 +54,39 @@ minetest.register_tool("fishing:pole", {
|
|||||||
on_use = function (itemstack, user, pointed_thing)
|
on_use = function (itemstack, user, pointed_thing)
|
||||||
if pointed_thing and pointed_thing.under then
|
if pointed_thing and pointed_thing.under then
|
||||||
local pt = pointed_thing
|
local pt = pointed_thing
|
||||||
local node = minetest.env:get_node(pt.under)
|
local node = minetest.get_node(pt.under)
|
||||||
if string.find(node.name, "default:water") then
|
if string.find(node.name, "default:water") then
|
||||||
local player = user:get_player_name()
|
local player = user:get_player_name()
|
||||||
local inv = user:get_inventory()
|
local inv = user:get_inventory()
|
||||||
if inv:get_stack("main", user:get_wield_index()+1):get_name() == "fishing:bait_worm" then
|
if inv:get_stack("main", user:get_wield_index()+1):get_name() == "fishing:bait_worm" then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
inv:remove_item("main", "fishing:bait_worm")
|
inv:remove_item("main", "fishing:bait_worm")
|
||||||
|
end
|
||||||
minetest.sound_play("fishing_bobber2", {
|
minetest.sound_play("fishing_bobber2", {
|
||||||
pos = pt.under,
|
pos = pt.under,
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
})
|
})
|
||||||
minetest.env:add_entity({interval = 1,x=pt.under.x, y=pt.under.y+(45/64), z=pt.under.z}, "fishing:bobber_entity")
|
minetest.add_entity({interval = 1,x=pt.under.x, y=pt.under.y+(45/64), z=pt.under.z}, "fishing:bobber_entity")
|
||||||
|
|
||||||
if WEAR_OUT == true then
|
if WEAR_OUT == true
|
||||||
|
and not minetest.setting_getbool("creative_mode") then
|
||||||
return rod_wear(itemstack, user, pointed_thing, 30)
|
return rod_wear(itemstack, user, pointed_thing, 30)
|
||||||
else
|
else
|
||||||
return {name="fishing:pole", count=1, wear=0, metadata=""}
|
return {name="fishing:pole", count=1, wear=0, metadata=""}
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
if inv:get_stack("main", user:get_wield_index()+1):get_name() == "fishing:fish_raw" then
|
if inv:get_stack("main", user:get_wield_index()+1):get_name() == "fishing:fish_raw" then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
inv:remove_item("main", "fishing:fish_raw")
|
inv:remove_item("main", "fishing:fish_raw")
|
||||||
|
end
|
||||||
minetest.sound_play("fishing_bobber2", {
|
minetest.sound_play("fishing_bobber2", {
|
||||||
pos = pt.under,
|
pos = pt.under,
|
||||||
gain = 0.5,
|
gain = 0.5,
|
||||||
})
|
})
|
||||||
minetest.env:add_entity({interval = 1,x=pt.under.x, y=pt.under.y+(45/64), z=pt.under.z}, "fishing:bobber_entity_shark")
|
minetest.add_entity({interval = 1,x=pt.under.x, y=pt.under.y+(45/64), z=pt.under.z}, "fishing:bobber_entity_shark")
|
||||||
|
|
||||||
if WEAR_OUT == true then
|
if WEAR_OUT == true
|
||||||
|
and not minetest.setting_getbool("creative_mode") then
|
||||||
return rod_wear(itemstack, user, pointed_thing, 30)
|
return rod_wear(itemstack, user, pointed_thing, 30)
|
||||||
else
|
else
|
||||||
return {name="fishing:pole", count=1, wear=0, metadata=""}
|
return {name="fishing:pole", count=1, wear=0, metadata=""}
|
||||||
@ -94,15 +100,17 @@ minetest.register_tool("fishing:pole", {
|
|||||||
local pt = pointed_thing
|
local pt = pointed_thing
|
||||||
if minetest.get_node(pt.under).name~="default:water_source" and minetest.get_node(pt.under).name~="default:water_flowing" then
|
if minetest.get_node(pt.under).name~="default:water_source" and minetest.get_node(pt.under).name~="default:water_flowing" then
|
||||||
local wear = itemstack:get_wear()
|
local wear = itemstack:get_wear()
|
||||||
print (wear)
|
--print (wear)
|
||||||
local direction = minetest.dir_to_facedir(placer:get_look_dir())
|
local direction = minetest.dir_to_facedir(placer:get_look_dir())
|
||||||
local meta1 = minetest.env:get_meta({x=pt.under.x, y=pt.under.y , z=pt.under.z})
|
--local meta1 = minetest.get_meta(pt.under)
|
||||||
local meta2 = minetest.env:get_meta({x=pt.under.x, y=pt.under.y+1, z=pt.under.z})
|
local meta = minetest.get_meta(pt.above)
|
||||||
minetest.set_node({x=pt.under.x, y=pt.under.y+1, z=pt.under.z}, {name="fishing:pole_deco", param2=direction})
|
minetest.set_node(pt.above, {name="fishing:pole_deco", param2=direction})
|
||||||
meta1:set_int("wear", wear)
|
--meta1:set_int("wear", wear)
|
||||||
meta2:set_int("wear", wear)
|
meta:set_int("wear", wear)
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
itemstack:take_item()
|
itemstack:take_item()
|
||||||
end
|
end
|
||||||
|
end
|
||||||
return itemstack
|
return itemstack
|
||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
@ -205,7 +213,7 @@ minetest.register_node("fishing:pole_deco", {
|
|||||||
sounds = default.node_sound_wood_defaults(),
|
sounds = default.node_sound_wood_defaults(),
|
||||||
on_dig = function(pos, node, digger)
|
on_dig = function(pos, node, digger)
|
||||||
if digger:is_player() and digger:get_inventory() then
|
if digger:is_player() and digger:get_inventory() then
|
||||||
local meta = minetest.env:get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
local wear_out = meta:get_int("wear")
|
local wear_out = meta:get_int("wear")
|
||||||
digger:get_inventory():add_item("main", {name="fishing:pole", count=1, wear=wear_out, metadata=""})
|
digger:get_inventory():add_item("main", {name="fishing:pole", count=1, wear=wear_out, metadata=""})
|
||||||
end
|
end
|
||||||
@ -231,7 +239,7 @@ minetest.register_node(":default:dirt", {
|
|||||||
local tool_in_use = digger:get_wielded_item():get_name()
|
local tool_in_use = digger:get_wielded_item():get_name()
|
||||||
if tool_in_use == "" or tool_in_use == "default:dirt" then
|
if tool_in_use == "" or tool_in_use == "default:dirt" then
|
||||||
if WORM_IS_MOB == true then
|
if WORM_IS_MOB == true then
|
||||||
minetest.env:add_entity({x = pos.x, y = pos.y+0.4, z = pos.z}, "fishing:bait_worm_entity")
|
minetest.add_entity({x = pos.x, y = pos.y+0.4, z = pos.z}, "fishing:bait_worm_entity")
|
||||||
else
|
else
|
||||||
local inv = digger:get_inventory()
|
local inv = digger:get_inventory()
|
||||||
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
||||||
@ -288,7 +296,7 @@ local function hoe_on_use(itemstack, user, pointed_thing, uses)
|
|||||||
|
|
||||||
if math.random(1, 100) < WORM_CHANCE then
|
if math.random(1, 100) < WORM_CHANCE then
|
||||||
if WORM_IS_MOB == true then
|
if WORM_IS_MOB == true then
|
||||||
minetest.env:add_entity({x=pt.under.x, y=pt.under.y+0.4, z=pt.under.z}, "fishing:bait_worm_entity")
|
minetest.add_entity({x=pt.under.x, y=pt.under.y+0.4, z=pt.under.z}, "fishing:bait_worm_entity")
|
||||||
else
|
else
|
||||||
local inv = user:get_inventory()
|
local inv = user:get_inventory()
|
||||||
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
if inv:room_for_item("main", {name="fishing:bait_worm", count=1, wear=0, metadata=""}) then
|
||||||
|
Loading…
x
Reference in New Issue
Block a user