code tidy

This commit is contained in:
tenplus1 2022-09-27 09:15:59 +01:00
parent 840291ee5b
commit be80ec3269
12 changed files with 260 additions and 208 deletions

39
bee.lua
View File

@ -1,6 +1,7 @@
local S = mobs.intllib_animal local S = mobs.intllib_animal
-- Bee by KrupnoPavel (.b3d model by sirrobzeroone) -- Bee by KrupnoPavel (.b3d model by sirrobzeroone)
mobs:register_mob("mobs_animal:bee", { mobs:register_mob("mobs_animal:bee", {
@ -13,18 +14,18 @@ mobs:register_mob("mobs_animal:bee", {
visual = "mesh", visual = "mesh",
mesh = "mobs_bee.b3d", mesh = "mobs_bee.b3d",
textures = { textures = {
{"mobs_bee.png"}, {"mobs_bee.png"}
}, },
blood_texture = "mobs_bee_inv.png", blood_texture = "mobs_bee_inv.png",
blood_amount = 1, blood_amount = 1,
makes_footstep_sound = false, makes_footstep_sound = false,
sounds = { sounds = {
random = "mobs_bee", random = "mobs_bee"
}, },
walk_velocity = 1, walk_velocity = 1,
jump = true, jump = true,
drops = { drops = {
{name = "mobs:honey", chance = 2, min = 1, max = 2}, {name = "mobs:honey", chance = 2, min = 1, max = 2}
}, },
water_damage = 1, water_damage = 1,
lava_damage = 2, lava_damage = 2,
@ -36,17 +37,20 @@ mobs:register_mob("mobs_animal:bee", {
stand_start = 0, stand_start = 0,
stand_end = 30, stand_end = 30,
walk_start = 35, walk_start = 35,
walk_end = 65, walk_end = 65
}, },
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
mobs:capture_mob(self, clicker, 50, 90, 0, true, "mobs_animal:bee") mobs:capture_mob(self, clicker, 50, 90, 0, true, "mobs_animal:bee")
end, end,
-- after_activate = function(self, staticdata, def, dtime) -- after_activate = function(self, staticdata, def, dtime)
-- print ("------", self.name, dtime, self.health) -- print ("------", self.name, dtime, self.health)
-- end, -- end,
}) })
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:bee", name = "mobs_animal:bee",
nodes = {"group:flower"}, nodes = {"group:flower"},
@ -55,23 +59,28 @@ mobs:spawn({
chance = 7000, chance = 7000,
min_height = 3, min_height = 3,
max_height = 200, max_height = 200,
day_toggle = true, day_toggle = true
}) })
end end
-- spawn egg
mobs:register_egg("mobs_animal:bee", S("Bee"), "mobs_bee_inv.png") mobs:register_egg("mobs_animal:bee", S("Bee"), "mobs_bee_inv.png")
-- compatibility
-- compatibility (only required if moving from old mobs to mobs_redo)
mobs:alias_mob("mobs:bee", "mobs_animal:bee") mobs:alias_mob("mobs:bee", "mobs_animal:bee")
-- honey -- honey
minetest.register_craftitem(":mobs:honey", { minetest.register_craftitem(":mobs:honey", {
description = S("Honey"), description = S("Honey"),
inventory_image = "mobs_honey_inv.png", inventory_image = "mobs_honey_inv.png",
on_use = minetest.item_eat(4), on_use = minetest.item_eat(4),
groups = {food_honey = 1, food_sugar = 1, flammable = 1}, groups = {food_honey = 1, food_sugar = 1, flammable = 1}
}) })
-- beehive (when placed spawns bee) -- beehive (when placed spawns bee)
minetest.register_node(":mobs:beehive", { minetest.register_node(":mobs:beehive", {
description = S("Beehive"), description = S("Beehive"),
@ -104,7 +113,7 @@ minetest.register_node(":mobs:beehive", {
minetest.set_node(pos, {name = "mobs:beehive", param2 = 1}) minetest.set_node(pos, {name = "mobs:beehive", param2 = 1})
if math.random(1, 4) == 1 then if math.random(4) == 1 then
minetest.add_entity(pos, "mobs_animal:bee") minetest.add_entity(pos, "mobs_animal:bee")
end end
end end
@ -131,14 +140,14 @@ minetest.register_node(":mobs:beehive", {
-- only dig beehive if no honey inside -- only dig beehive if no honey inside
return meta:get_inventory():is_empty("beehive") return meta:get_inventory():is_empty("beehive")
end, end
}) })
-- beehive recipe
minetest.register_craft({ minetest.register_craft({
output = "mobs:beehive", output = "mobs:beehive",
recipe = { recipe = {
{"mobs:bee","mobs:bee","mobs:bee"}, {"mobs:bee","mobs:bee","mobs:bee"}
} }
}) })
@ -147,25 +156,27 @@ minetest.register_node(":mobs:honey_block", {
description = S("Honey Block"), description = S("Honey Block"),
tiles = {"mobs_honey_block.png"}, tiles = {"mobs_honey_block.png"},
groups = {snappy = 3, flammable = 2}, groups = {snappy = 3, flammable = 2},
sounds = default.node_sound_dirt_defaults(), sounds = default.node_sound_dirt_defaults()
}) })
-- recipe
minetest.register_craft({ minetest.register_craft({
output = "mobs:honey_block", output = "mobs:honey_block",
recipe = { recipe = {
{"mobs:honey", "mobs:honey", "mobs:honey"}, {"mobs:honey", "mobs:honey", "mobs:honey"},
{"mobs:honey", "mobs:honey", "mobs:honey"}, {"mobs:honey", "mobs:honey", "mobs:honey"},
{"mobs:honey", "mobs:honey", "mobs:honey"}, {"mobs:honey", "mobs:honey", "mobs:honey"}
} }
}) })
minetest.register_craft({ minetest.register_craft({
output = "mobs:honey 9", output = "mobs:honey 9",
recipe = { recipe = {
{"mobs:honey_block"}, {"mobs:honey_block"}
} }
}) })
-- beehive workings -- beehive workings
minetest.register_abm({ minetest.register_abm({
nodenames = {"mobs:beehive"}, nodenames = {"mobs:beehive"},

View File

@ -19,7 +19,7 @@ stepheight = 0.6,
textures = { textures = {
{"mobs_bunny_grey.png"}, {"mobs_bunny_grey.png"},
{"mobs_bunny_brown.png"}, {"mobs_bunny_brown.png"},
{"mobs_bunny_white.png"}, {"mobs_bunny_white.png"}
}, },
sounds = {}, sounds = {},
makes_footstep_sound = false, makes_footstep_sound = false,
@ -31,7 +31,7 @@ stepheight = 0.6,
jump_height = 6, jump_height = 6,
drops = { drops = {
{name = "mobs:rabbit_raw", chance = 1, min = 1, max = 1}, {name = "mobs:rabbit_raw", chance = 1, min = 1, max = 1},
{name = "mobs:rabbit_hide", chance = 1, min = 0, max = 1}, {name = "mobs:rabbit_hide", chance = 1, min = 0, max = 1}
}, },
water_damage = 0, water_damage = 0,
lava_damage = 4, lava_damage = 4,
@ -44,13 +44,14 @@ stepheight = 0.6,
walk_start = 16, walk_start = 16,
walk_end = 24, walk_end = 24,
punch_start = 16, punch_start = 16,
punch_end = 24, punch_end = 24
}, },
follow = {"farming:carrot", "farming_plus:carrot_item", "default:grass_1"}, follow = {"farming:carrot", "farming_plus:carrot_item", "default:grass_1"},
view_range = 8, view_range = 8,
replace_rate = 10, replace_rate = 10,
replace_what = {"farming:carrot_7", "farming:carrot_8", "farming_plus:carrot"}, replace_what = {"farming:carrot_7", "farming:carrot_8", "farming_plus:carrot"},
replace_with = "air", replace_with = "air",
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
-- feed or tame -- feed or tame
@ -69,7 +70,7 @@ stepheight = 0.6,
end end
self.object:set_properties({ self.object:set_properties({
textures = {"mobs_bunny_evil.png"}, textures = {"mobs_bunny_evil.png"}
}) })
self.type = "monster" self.type = "monster"
@ -88,11 +89,13 @@ stepheight = 0.6,
{"default:snow", "default:snowblock", "default:dirt_with_snow"}) then {"default:snow", "default:snowblock", "default:dirt_with_snow"}) then
self.base_texture = {"mobs_bunny_white.png"} self.base_texture = {"mobs_bunny_white.png"}
self.object:set_properties({textures = self.base_texture}) self.object:set_properties({textures = self.base_texture})
-- brown desert bunny -- brown desert bunny
elseif minetest.find_node_near(pos, 1, elseif minetest.find_node_near(pos, 1,
{"default:desert_sand", "default:desert_stone"}) then {"default:desert_sand", "default:desert_stone"}) then
self.base_texture = {"mobs_bunny_brown.png"} self.base_texture = {"mobs_bunny_brown.png"}
self.object:set_properties({textures = self.base_texture}) self.object:set_properties({textures = self.base_texture})
-- grey stone bunny -- grey stone bunny
elseif minetest.find_node_near(pos, 1, elseif minetest.find_node_near(pos, 1,
{"default:stone", "default:gravel"}) then {"default:stone", "default:gravel"}) then
@ -103,7 +106,7 @@ stepheight = 0.6,
return true -- run only once, false/nil runs every activation return true -- run only once, false/nil runs every activation
end, end,
attack_type = "dogfight", attack_type = "dogfight",
damage = 5, damage = 5
}) })
@ -114,16 +117,17 @@ if minetest.get_modpath("ethereal") then
end end
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:bunny", name = "mobs_animal:bunny",
nodes = {spawn_on}, nodes = {spawn_on},
neighbors = {"group:grass"}, neighbors = {"group:grass"},
min_light = 14, min_light = 14,
interval = 60, interval = 60,
chance = 8000, -- 15000 chance = 8000,
min_height = 5, min_height = 5,
max_height = 200, max_height = 200,
day_toggle = true, day_toggle = true
}) })
end end
@ -139,7 +143,7 @@ minetest.register_craftitem(":mobs:rabbit_raw", {
description = S("Raw Rabbit"), description = S("Raw Rabbit"),
inventory_image = "mobs_rabbit_raw.png", inventory_image = "mobs_rabbit_raw.png",
on_use = minetest.item_eat(3), on_use = minetest.item_eat(3),
groups = {food_meat_raw = 1, food_rabbit_raw = 1, flammable = 2}, groups = {food_meat_raw = 1, food_rabbit_raw = 1, flammable = 2}
}) })
-- cooked rabbit -- cooked rabbit
@ -147,32 +151,31 @@ minetest.register_craftitem(":mobs:rabbit_cooked", {
description = S("Cooked Rabbit"), description = S("Cooked Rabbit"),
inventory_image = "mobs_rabbit_cooked.png", inventory_image = "mobs_rabbit_cooked.png",
on_use = minetest.item_eat(5), on_use = minetest.item_eat(5),
groups = {food_meat = 1, food_rabbit = 1, flammable = 2}, groups = {food_meat = 1, food_rabbit = 1, flammable = 2}
}) })
minetest.register_craft({ minetest.register_craft({
type = "cooking", type = "cooking",
output = "mobs:rabbit_cooked", output = "mobs:rabbit_cooked",
recipe = "mobs:rabbit_raw", recipe = "mobs:rabbit_raw",
cooktime = 5, cooktime = 5
}) })
-- rabbit hide -- rabbit hide
minetest.register_craftitem(":mobs:rabbit_hide", { minetest.register_craftitem(":mobs:rabbit_hide", {
description = S("Rabbit Hide"), description = S("Rabbit Hide"),
inventory_image = "mobs_rabbit_hide.png", inventory_image = "mobs_rabbit_hide.png",
groups = {flammable = 2, pelt = 1}, groups = {flammable = 2, pelt = 1}
}) })
minetest.register_craft({ minetest.register_craft({
type = "fuel", type = "fuel",
recipe = "mobs:rabbit_hide", recipe = "mobs:rabbit_hide",
burntime = 2, burntime = 2
}) })
minetest.register_craft({ minetest.register_craft({
output = "mobs:leather", output = "mobs:leather",
-- type = "shapeless",
recipe = { recipe = {
{"mobs:rabbit_hide", "mobs:rabbit_hide"}, {"mobs:rabbit_hide", "mobs:rabbit_hide"},
{"mobs:rabbit_hide", "mobs:rabbit_hide"} {"mobs:rabbit_hide", "mobs:rabbit_hide"}

View File

@ -17,14 +17,14 @@ stepheight = 0.6,
textures = { textures = {
{"mobs_chicken.png"}, -- white {"mobs_chicken.png"}, -- white
{"mobs_chicken_brown.png"}, {"mobs_chicken_brown.png"},
{"mobs_chicken_black.png"}, {"mobs_chicken_black.png"}
}, },
child_texture = { child_texture = {
{"mobs_chick.png"}, {"mobs_chick.png"}
}, },
makes_footstep_sound = true, makes_footstep_sound = true,
sounds = { sounds = {
random = "mobs_chicken", random = "mobs_chicken"
}, },
walk_velocity = 1, walk_velocity = 1,
run_velocity = 3, run_velocity = 3,
@ -32,7 +32,7 @@ stepheight = 0.6,
runaway_from = {"player", "mobs_animal:pumba"}, runaway_from = {"player", "mobs_animal:pumba"},
drops = { drops = {
{name = "mobs:chicken_raw", chance = 1, min = 1, max = 1}, {name = "mobs:chicken_raw", chance = 1, min = 1, max = 1},
{name = "mobs:chicken_feather", chance = 1, min = 0, max = 2}, {name = "mobs:chicken_feather", chance = 1, min = 0, max = 2}
}, },
water_damage = 1, water_damage = 1,
lava_damage = 5, lava_damage = 5,
@ -53,7 +53,7 @@ stepheight = 0.6,
walk_speed = 24, walk_speed = 24,
run_start = 91, run_start = 91,
run_end = 110, run_end = 110,
run_speed = 24, run_speed = 24
}, },
follow = { follow = {
"farming:seed_wheat", "farming:seed_cotton", "farming:seed_barley", "farming:seed_wheat", "farming:seed_cotton", "farming:seed_barley",
@ -77,7 +77,7 @@ stepheight = 0.6,
self.egg_timer = 0 self.egg_timer = 0
if self.child if self.child
or math.random(1, 100) > 1 then or math.random(100) > 1 then
return return
end end
@ -88,9 +88,9 @@ stepheight = 0.6,
minetest.sound_play("default_place_node_hard", { minetest.sound_play("default_place_node_hard", {
pos = pos, pos = pos,
gain = 1.0, gain = 1.0,
max_hear_distance = 5, max_hear_distance = 5
}) })
end, end
}) })
@ -102,16 +102,17 @@ end
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:chicken", name = "mobs_animal:chicken",
nodes = spawn_on, nodes = spawn_on,
neighbors = {"group:grass"}, neighbors = {"group:grass"},
min_light = 14, min_light = 14,
interval = 60, interval = 60,
chance = 8000, -- 15000 chance = 8000,
min_height = 5, min_height = 5,
max_height = 200, max_height = 200,
day_toggle = true, day_toggle = true
}) })
end end
@ -133,14 +134,14 @@ mobs:register_arrow("mobs_animal:egg_entity", {
hit_player = function(self, player) hit_player = function(self, player)
player:punch(minetest.get_player_by_name(self.playername) or self.object, 1.0, { player:punch(minetest.get_player_by_name(self.playername) or self.object, 1.0, {
full_punch_interval = 1.0, full_punch_interval = 1.0,
damage_groups = {fleshy = 1}, damage_groups = {fleshy = 1}
}, nil) }, nil)
end, end,
hit_mob = function(self, player) hit_mob = function(self, player)
player:punch(self.object, 1.0, { player:punch(self.object, 1.0, {
full_punch_interval = 1.0, full_punch_interval = 1.0,
damage_groups = {fleshy = 1}, damage_groups = {fleshy = 1}
}, nil) }, nil)
end, end,
@ -181,7 +182,7 @@ local mobs_shoot_egg = function (item, player, pointed_thing)
minetest.sound_play("default_place_node_hard", { minetest.sound_play("default_place_node_hard", {
pos = playerpos, pos = playerpos,
gain = 1.0, gain = 1.0,
max_hear_distance = 5, max_hear_distance = 5
}) })
local obj = minetest.add_entity({ local obj = minetest.add_entity({
@ -251,13 +252,13 @@ minetest.register_craftitem(":mobs:chicken_egg_fried", {
description = S("Fried Egg"), description = S("Fried Egg"),
inventory_image = "mobs_chicken_egg_fried.png", inventory_image = "mobs_chicken_egg_fried.png",
on_use = minetest.item_eat(2), on_use = minetest.item_eat(2),
groups = {food_egg_fried = 1, flammable = 2}, groups = {food_egg_fried = 1, flammable = 2}
}) })
minetest.register_craft({ minetest.register_craft({
type = "cooking", type = "cooking",
recipe = "mobs:egg", recipe = "mobs:egg",
output = "mobs:chicken_egg_fried", output = "mobs:chicken_egg_fried"
}) })
-- raw chicken -- raw chicken
@ -265,7 +266,7 @@ minetest.register_craftitem(":mobs:chicken_raw", {
description = S("Raw Chicken"), description = S("Raw Chicken"),
inventory_image = "mobs_chicken_raw.png", inventory_image = "mobs_chicken_raw.png",
on_use = minetest.item_eat(2), on_use = minetest.item_eat(2),
groups = {food_meat_raw = 1, food_chicken_raw = 1, flammable = 2}, groups = {food_meat_raw = 1, food_chicken_raw = 1, flammable = 2}
}) })
-- cooked chicken -- cooked chicken
@ -273,24 +274,24 @@ minetest.register_craftitem(":mobs:chicken_cooked", {
description = S("Cooked Chicken"), description = S("Cooked Chicken"),
inventory_image = "mobs_chicken_cooked.png", inventory_image = "mobs_chicken_cooked.png",
on_use = minetest.item_eat(6), on_use = minetest.item_eat(6),
groups = {food_meat = 1, food_chicken = 1, flammable = 2}, groups = {food_meat = 1, food_chicken = 1, flammable = 2}
}) })
minetest.register_craft({ minetest.register_craft({
type = "cooking", type = "cooking",
recipe = "mobs:chicken_raw", recipe = "mobs:chicken_raw",
output = "mobs:chicken_cooked", output = "mobs:chicken_cooked"
}) })
-- feather -- feather
minetest.register_craftitem(":mobs:chicken_feather", { minetest.register_craftitem(":mobs:chicken_feather", {
description = S("Feather"), description = S("Feather"),
inventory_image = "mobs_chicken_feather.png", inventory_image = "mobs_chicken_feather.png",
groups = {flammable = 2, feather = 1}, groups = {flammable = 2, feather = 1}
}) })
minetest.register_craft({ minetest.register_craft({
type = "fuel", type = "fuel",
recipe = "mobs:chicken_feather", recipe = "mobs:chicken_feather",
burntime = 1, burntime = 1
}) })

14
cow.lua
View File

@ -70,6 +70,7 @@ mobs:register_mob("mobs_animal:cow", {
}, },
-- stay_near = {{"farming:straw", "group:grass"}, 10}, -- stay_near = {{"farming:straw", "group:grass"}, 10},
fear_height = 2, fear_height = 2,
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
-- feed or tame -- feed or tame
@ -100,8 +101,9 @@ mobs:register_mob("mobs_animal:cow", {
end end
if self.gotten == true then if self.gotten == true then
minetest.chat_send_player(name,
S("Cow already milked!")) minetest.chat_send_player(name, S("Cow already milked!"))
return return
end end
@ -112,6 +114,7 @@ mobs:register_mob("mobs_animal:cow", {
-- which bucket are we using -- which bucket are we using
local ret_item = "mobs:bucket_milk" local ret_item = "mobs:bucket_milk"
if item == "wooden_bucket:bucket_wood_empty" then if item == "wooden_bucket:bucket_wood_empty" then
ret_item = "mobs:wooden_bucket_milk" ret_item = "mobs:wooden_bucket_milk"
end end
@ -120,7 +123,9 @@ mobs:register_mob("mobs_animal:cow", {
clicker:get_inventory():add_item("main", ret_item) clicker:get_inventory():add_item("main", ret_item)
else else
local pos = self.object:get_pos() local pos = self.object:get_pos()
pos.y = pos.y + 0.5 pos.y = pos.y + 0.5
minetest.add_item(pos, {name = ret_item}) minetest.add_item(pos, {name = ret_item})
end end
@ -144,6 +149,7 @@ mobs:register_mob("mobs_animal:cow", {
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:cow", name = "mobs_animal:cow",
nodes = {"default:dirt_with_grass", "ethereal:green_dirt"}, nodes = {"default:dirt_with_grass", "ethereal:green_dirt"},
@ -170,7 +176,7 @@ minetest.register_craftitem(":mobs:bucket_milk", {
inventory_image = "mobs_bucket_milk.png", inventory_image = "mobs_bucket_milk.png",
stack_max = 1, stack_max = 1,
on_use = minetest.item_eat(8, "bucket:bucket_empty"), on_use = minetest.item_eat(8, "bucket:bucket_empty"),
groups = {food_milk = 1, flammable = 3, drink = 1}, groups = {food_milk = 1, flammable = 3, drink = 1}
}) })
-- glass of milk -- glass of milk
@ -178,7 +184,7 @@ minetest.register_craftitem(":mobs:glass_milk", {
description = S("Glass of Milk"), description = S("Glass of Milk"),
inventory_image = "mobs_glass_milk.png", inventory_image = "mobs_glass_milk.png",
on_use = minetest.item_eat(2, "vessels:drinking_glass"), on_use = minetest.item_eat(2, "vessels:drinking_glass"),
groups = {food_milk_glass = 1, flammable = 3, vessel = 1, drink = 1}, groups = {food_milk_glass = 1, flammable = 3, vessel = 1, drink = 1}
}) })
minetest.register_craft({ minetest.register_craft({

View File

@ -8,11 +8,10 @@ else
if minetest.get_modpath("intllib") then if minetest.get_modpath("intllib") then
dofile(minetest.get_modpath("intllib") .. "/init.lua") dofile(minetest.get_modpath("intllib") .. "/init.lua")
if intllib.make_gettext_pair then if intllib.make_gettext_pair then
gettext, ngettext = intllib.make_gettext_pair() -- new gettext method S = intllib.make_gettext_pair() -- new gettext method
else else
gettext = intllib.Getter() -- old text file method S = intllib.Getter() -- old text file method
end end
S = gettext
else -- boilerplate function else -- boilerplate function
S = function(str, ...) S = function(str, ...)
local args = {...} local args = {...}
@ -56,7 +55,9 @@ end
-- Lucky Blocks -- Lucky Blocks
if minetest.get_modpath("lucky_block") then
dofile(path .. "lucky_block.lua") dofile(path .. "lucky_block.lua")
end
print ("[MOD] Mobs Redo Animals loaded") print ("[MOD] Mobs Redo Animals loaded")

View File

@ -2,6 +2,7 @@
local S = mobs.intllib_animal local S = mobs.intllib_animal
local hairball = minetest.settings:get("mobs_hairball") local hairball = minetest.settings:get("mobs_hairball")
-- Kitten by Jordach / BFD -- Kitten by Jordach / BFD
mobs:register_mob("mobs_animal:kitten", { mobs:register_mob("mobs_animal:kitten", {
@ -26,11 +27,11 @@ stepheight = 1.1,
{"mobs_kitten_striped.png"}, {"mobs_kitten_striped.png"},
{"mobs_kitten_splotchy.png"}, {"mobs_kitten_splotchy.png"},
{"mobs_kitten_ginger.png"}, {"mobs_kitten_ginger.png"},
{"mobs_kitten_sandy.png"}, {"mobs_kitten_sandy.png"}
}, },
makes_footstep_sound = false, makes_footstep_sound = false,
sounds = { sounds = {
random = "mobs_kitten", random = "mobs_kitten"
}, },
walk_velocity = 0.6, walk_velocity = 0.6,
walk_chance = 15, walk_chance = 15,
@ -38,7 +39,7 @@ stepheight = 1.1,
runaway = true, runaway = true,
jump = false, jump = false,
drops = { drops = {
{name = "farming:string", chance = 1, min = 0, max = 1}, {name = "farming:string", chance = 1, min = 0, max = 1}
}, },
water_damage = 0, water_damage = 0,
lava_damage = 5, lava_damage = 5,
@ -92,7 +93,7 @@ stepheight = 1.1,
self.hairball_timer = 0 self.hairball_timer = 0
if self.child if self.child
or math.random(1, 250) > 1 then or math.random(250) > 1 then
return return
end end
@ -103,9 +104,9 @@ stepheight = 1.1,
minetest.sound_play("default_dig_snappy", { minetest.sound_play("default_dig_snappy", {
pos = pos, pos = pos,
gain = 1.0, gain = 1.0,
max_hear_distance = 5, max_hear_distance = 5
}) })
end, end
}) })
@ -116,16 +117,17 @@ if minetest.get_modpath("ethereal") then
end end
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:kitten", name = "mobs_animal:kitten",
nodes = {spawn_on}, nodes = {spawn_on},
neighbors = {"group:grass"}, neighbors = {"group:grass"},
min_light = 14, min_light = 14,
interval = 60, interval = 60,
chance = 10000, -- 22000 chance = 10000,
min_height = 5, min_height = 5,
max_height = 50, max_height = 50,
day_toggle = true, day_toggle = true
}) })
end end
@ -164,11 +166,11 @@ minetest.register_craftitem(":mobs:hairball", {
minetest.sound_play("default_place_node_hard", { minetest.sound_play("default_place_node_hard", {
pos = newpos, pos = newpos,
gain = 1.0, gain = 1.0,
max_hear_distance = 5, max_hear_distance = 5
}) })
itemstack:take_item() itemstack:take_item()
return itemstack return itemstack
end, end
}) })

View File

@ -1,6 +1,3 @@
if minetest.get_modpath("lucky_block") then
lucky_block:add_blocks({ lucky_block:add_blocks({
{"spw", "mobs:sheep", 5}, {"spw", "mobs:sheep", 5},
{"spw", "mobs:rat", 5}, {"spw", "mobs:rat", 5},
@ -20,12 +17,12 @@ if minetest.get_modpath("lucky_block") then
{"dro", {"mobs:pork_raw", "mobs:pork_cooked"}, 10}, {"dro", {"mobs:pork_raw", "mobs:pork_cooked"}, 10},
{"dro", {"mobs:mutton_raw", "mobs:mutton_cooked"}, 10}, {"dro", {"mobs:mutton_raw", "mobs:mutton_cooked"}, 10},
{"dro", {"mobs:meat_raw", "mobs:meat"}, 10}, {"dro", {"mobs:meat_raw", "mobs:meat"}, 10},
{"dro", {"mobs:glass_milk"}, 5}, {"dro", {"mobs:glass_milk"}, 5}
}) })
if minetest.registered_nodes["default:nyancat"] then if minetest.registered_nodes["default:nyancat"] then
lucky_block:add_blocks({ lucky_block:add_blocks({
{"tro", "default:nyancat", "mobs_kitten", true}, {"tro", "default:nyancat", "mobs_kitten", true}
}) })
end end
end

View File

@ -1,6 +1,7 @@
local S = mobs.intllib_animal local S = mobs.intllib_animal
-- Panda by AspireMint (CC BY-SA 3.0) -- Panda by AspireMint (CC BY-SA 3.0)
mobs:register_mob("mobs_animal:panda", { mobs:register_mob("mobs_animal:panda", {
@ -20,12 +21,12 @@ stepheight = 0.6,
visual = "mesh", visual = "mesh",
mesh = "mobs_panda.b3d", mesh = "mobs_panda.b3d",
textures = { textures = {
{"mobs_panda.png"}, {"mobs_panda.png"}
}, },
makes_footstep_sound = true, makes_footstep_sound = true,
sounds = { sounds = {
random = "mobs_panda", random = "mobs_panda",
attack = "mobs_panda", attack = "mobs_panda"
}, },
walk_chance = 5, walk_chance = 5,
walk_velocity = 0.5, walk_velocity = 0.5,
@ -35,7 +36,7 @@ stepheight = 0.6,
follow = {"ethereal:bamboo", "bamboo:trunk"}, follow = {"ethereal:bamboo", "bamboo:trunk"},
view_range = 8, view_range = 8,
drops = { drops = {
{name = "mobs:meat_raw", chance = 1, min = 1, max = 2}, {name = "mobs:meat_raw", chance = 1, min = 1, max = 2}
}, },
water_damage = 0, water_damage = 0,
lava_damage = 5, lava_damage = 5,
@ -59,14 +60,16 @@ stepheight = 0.6,
punch_end = 120, punch_end = 120,
-- 0 = rest, 1 = hiding (covers eyes), 2 = surprised -- 0 = rest, 1 = hiding (covers eyes), 2 = surprised
}, },
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
if mobs:feed_tame(self, clicker, 20, true, true) then return end if mobs:feed_tame(self, clicker, 20, true, true) then return end
if mobs:protect(self, clicker) then return end if mobs:protect(self, clicker) then return end
if mobs:capture_mob(self, clicker, 0, 5, 50, false, nil) then return end if mobs:capture_mob(self, clicker, 0, 5, 50, false, nil) then return end
end, end
}) })
if minetest.get_modpath("ethereal") and not mobs.custom_spawn_animal then if minetest.get_modpath("ethereal") and not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
@ -75,11 +78,12 @@ if minetest.get_modpath("ethereal") and not mobs.custom_spawn_animal then
neighbors = {"group:grass"}, neighbors = {"group:grass"},
min_light = 14, min_light = 14,
interval = 60, interval = 60,
chance = 8000, -- 15000 chance = 8000,
min_height = 10, min_height = 10,
max_height = 80, max_height = 80,
day_toggle = true, day_toggle = true
}) })
end end
mobs:register_egg("mobs_animal:panda", S("Panda"), "mobs_panda_inv.png") mobs:register_egg("mobs_animal:panda", S("Panda"), "mobs_panda_inv.png")

View File

@ -1,6 +1,7 @@
local S = mobs.intllib_animal local S = mobs.intllib_animal
-- Penguin by D00Med -- Penguin by D00Med
mobs:register_mob("mobs_animal:penguin", { mobs:register_mob("mobs_animal:penguin", {
@ -16,7 +17,7 @@ stepheight = 0.6,
mesh = "mobs_penguin.b3d", mesh = "mobs_penguin.b3d",
visual_size = {x = 0.25, y = 0.25}, visual_size = {x = 0.25, y = 0.25},
textures = { textures = {
{"mobs_penguin.png"}, {"mobs_penguin.png"}
}, },
sounds = {}, sounds = {},
makes_footstep_sound = true, makes_footstep_sound = true,
@ -26,7 +27,7 @@ stepheight = 0.6,
jump = false, jump = false,
stepheight = 1.1, stepheight = 1.1,
drops = { drops = {
{name = "mobs:meat_raw", chance = 1, min = 1, max = 1}, {name = "mobs:meat_raw", chance = 1, min = 1, max = 1}
}, },
water_damage = 0, water_damage = 0,
lava_damage = 4, lava_damage = 4,
@ -39,7 +40,7 @@ stepheight = 0.6,
walk_start = 25, walk_start = 25,
walk_end = 45, walk_end = 45,
fly_start = 75, -- swim animation fly_start = 75, -- swim animation
fly_end = 95, fly_end = 95
-- 50-70 is slide/water idle -- 50-70 is slide/water idle
}, },
fly_in = {"default:water_source", "default:water_flowing"}, fly_in = {"default:water_source", "default:water_flowing"},
@ -56,10 +57,12 @@ stepheight = 0.6,
if mobs:feed_tame(self, clicker, 4, false, true) then return end if mobs:feed_tame(self, clicker, 4, false, true) then return end
if mobs:protect(self, clicker) then return end if mobs:protect(self, clicker) then return end
if mobs:capture_mob(self, clicker, 5, 50, 80, false, nil) then return end if mobs:capture_mob(self, clicker, 5, 50, 80, false, nil) then return end
end, end
}) })
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:penguin", name = "mobs_animal:penguin",
nodes = {"default:snowblock"}, nodes = {"default:snowblock"},
@ -68,8 +71,9 @@ mobs:spawn({
chance = 20000, chance = 20000,
min_height = 0, min_height = 0,
max_height = 200, max_height = 200,
day_toggle = true, day_toggle = true
}) })
end end
mobs:register_egg("mobs_animal:penguin", S("Penguin"), "mobs_penguin_inv.png") mobs:register_egg("mobs_animal:penguin", S("Penguin"), "mobs_penguin_inv.png")

View File

@ -1,6 +1,7 @@
local S = mobs.intllib_animal local S = mobs.intllib_animal
-- Rat by PilzAdam (B3D model by sirrobzeroone) -- Rat by PilzAdam (B3D model by sirrobzeroone)
mobs:register_mob("mobs_animal:rat", { mobs:register_mob("mobs_animal:rat", {
@ -15,11 +16,11 @@ stepheight = 0.6,
mesh = "mobs_rat.b3d", mesh = "mobs_rat.b3d",
textures = { textures = {
{"mobs_rat.png"}, {"mobs_rat.png"},
{"mobs_rat2.png"}, {"mobs_rat2.png"}
}, },
makes_footstep_sound = false, makes_footstep_sound = false,
sounds = { sounds = {
random = "mobs_rat", random = "mobs_rat"
}, },
walk_velocity = 1, walk_velocity = 1,
run_velocity = 2, run_velocity = 2,
@ -29,6 +30,7 @@ stepheight = 0.6,
lava_damage = 4, lava_damage = 4,
light_damage = 0, light_damage = 0,
fear_height = 2, fear_height = 2,
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
mobs:capture_mob(self, clicker, 50, 90, 0, true, "mobs_animal:rat") mobs:capture_mob(self, clicker, 50, 90, 0, true, "mobs_animal:rat")
end, end,
@ -59,6 +61,7 @@ stepheight = 0.6,
}) })
-- example on_spawn function
local function rat_spawn(self, pos) local function rat_spawn(self, pos)
self = self:get_luaentity() self = self:get_luaentity()
print (self.name, pos.x, pos.y, pos.z) print (self.name, pos.x, pos.y, pos.z)
@ -66,7 +69,9 @@ local function rat_spawn(self, pos)
self.health = 100 self.health = 100
end end
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:rat", name = "mobs_animal:rat",
nodes = {"default:stone"}, nodes = {"default:stone"},

View File

@ -88,6 +88,7 @@ for _, col in ipairs(all_colours) do
{"default:dirt_with_grass", "default:dirt", -2} {"default:dirt_with_grass", "default:dirt", -2}
}, },
fear_height = 3, fear_height = 3,
on_replace = function(self, pos, oldnode, newnode) on_replace = function(self, pos, oldnode, newnode)
self.food = (self.food or 0) + 1 self.food = (self.food or 0) + 1
@ -100,11 +101,15 @@ for _, col in ipairs(all_colours) do
self.drops = drops_normal self.drops = drops_normal
self.object:set_properties({ self.object:set_properties({
textures = {"mobs_sheep_base.png^(mobs_sheep_wool.png^[colorize:" .. col[3] .. ")"}, textures = {
"mobs_sheep_base.png^(mobs_sheep_wool.png^[colorize:"
.. col[3] .. ")"
},
mesh = "mobs_sheep.b3d", mesh = "mobs_sheep.b3d",
}) })
end end
end, end,
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
--are we feeding? --are we feeding?
@ -117,7 +122,10 @@ for _, col in ipairs(all_colours) do
self.drops = drops_normal self.drops = drops_normal
self.object:set_properties({ self.object:set_properties({
textures = {"mobs_sheep_base.png^(mobs_sheep_wool.png^[colorize:" .. col[3] .. ")"}, textures = {
"mobs_sheep_base.png^(mobs_sheep_wool.png^[colorize:"
.. col[3] .. ")"
},
mesh = "mobs_sheep.b3d" mesh = "mobs_sheep.b3d"
}) })
end end
@ -144,7 +152,7 @@ for _, col in ipairs(all_colours) do
local obj = minetest.add_item( local obj = minetest.add_item(
self.object:get_pos(), self.object:get_pos(),
ItemStack( "wool:" .. col[1] .. " " .. math.random(1, 3) ) ItemStack( "wool:" .. col[1] .. " " .. math.random(3) )
) )
if obj then if obj then
@ -162,7 +170,7 @@ for _, col in ipairs(all_colours) do
self.object:set_properties({ self.object:set_properties({
textures = {"mobs_sheep_shaved.png"}, textures = {"mobs_sheep_shaved.png"},
mesh = "mobs_sheep_shaved.b3d", mesh = "mobs_sheep_shaved.b3d"
}) })
return return
@ -214,7 +222,9 @@ for _, col in ipairs(all_colours) do
end end
}) })
mobs:register_egg("mobs_animal:sheep_"..col[1], S("@1 Sheep", col[2]), "wool_"..col[1]..".png^mobs_sheep_inv.png") -- spawn egg
mobs:register_egg("mobs_animal:sheep_"..col[1], S("@1 Sheep", col[2]),
"wool_"..col[1]..".png^mobs_sheep_inv.png")
-- compatibility -- compatibility
mobs:alias_mob("mobs:sheep_" .. col[1], "mobs_animal:sheep_" .. col[1]) mobs:alias_mob("mobs:sheep_" .. col[1], "mobs_animal:sheep_" .. col[1])
@ -223,13 +233,14 @@ end
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:sheep_white", name = "mobs_animal:sheep_white",
nodes = {"default:dirt_with_grass", "ethereal:green_dirt"}, nodes = {"default:dirt_with_grass", "ethereal:green_dirt"},
neighbors = {"group:grass"}, neighbors = {"group:grass"},
min_light = 14, min_light = 14,
interval = 60, interval = 60,
chance = 8000, -- 15000 chance = 8000,
min_height = 0, min_height = 0,
max_height = 200, max_height = 200,
day_toggle = true day_toggle = true
@ -239,6 +250,7 @@ end
mobs:alias_mob("mobs:sheep", "mobs_animal:sheep_white") -- compatibility mobs:alias_mob("mobs:sheep", "mobs_animal:sheep_white") -- compatibility
-- raw mutton -- raw mutton
minetest.register_craftitem(":mobs:mutton_raw", { minetest.register_craftitem(":mobs:mutton_raw", {
description = S("Raw Mutton"), description = S("Raw Mutton"),

View File

@ -1,6 +1,7 @@
local S = mobs.intllib_animal local S = mobs.intllib_animal
-- Warthog originally by KrupnoPavel, B3D model by sirrobzeroone -- Warthog originally by KrupnoPavel, B3D model by sirrobzeroone
mobs:register_mob("mobs_animal:pumba", { mobs:register_mob("mobs_animal:pumba", {
@ -56,6 +57,7 @@ mobs:register_mob("mobs_animal:pumba", {
die_loop = false, die_loop = false,
die_rotate = true die_rotate = true
}, },
on_rightclick = function(self, clicker) on_rightclick = function(self, clicker)
if mobs:feed_tame(self, clicker, 8, true, true) then return end if mobs:feed_tame(self, clicker, 8, true, true) then return end
@ -64,6 +66,7 @@ mobs:register_mob("mobs_animal:pumba", {
end end
}) })
local spawn_on = {"default:dirt_with_grass"} local spawn_on = {"default:dirt_with_grass"}
local spawn_by = {"group:grass"} local spawn_by = {"group:grass"}
@ -78,19 +81,22 @@ if minetest.get_modpath("ethereal") then
end end
if not mobs.custom_spawn_animal then if not mobs.custom_spawn_animal then
mobs:spawn({ mobs:spawn({
name = "mobs_animal:pumba", name = "mobs_animal:pumba",
nodes = spawn_on, nodes = spawn_on,
neighbors = spawn_by, neighbors = spawn_by,
min_light = 14, min_light = 14,
interval = 60, interval = 60,
chance = 8000, -- 15000 chance = 8000,
min_height = 0, min_height = 0,
max_height = 200, max_height = 200,
day_toggle = true day_toggle = true
}) })
end end
-- spawn egg
mobs:register_egg("mobs_animal:pumba", S("Warthog"), "mobs_pumba_inv.png") mobs:register_egg("mobs_animal:pumba", S("Warthog"), "mobs_pumba_inv.png")