mirror of
https://github.com/sys4-fr/server-nalc.git
synced 2025-01-27 18:20:27 +01:00
[Fix Issue #11] Rotten flesh has more uses
This commit is contained in:
parent
6a6cc58506
commit
b5e8b52218
@ -26,3 +26,4 @@ mtfoods?
|
|||||||
mush45?
|
mush45?
|
||||||
mushroom?
|
mushroom?
|
||||||
seaplants?
|
seaplants?
|
||||||
|
pclasses?
|
||||||
|
@ -20,6 +20,11 @@ HUNGER_EXHAUST_PLACE = 1 -- exhaustion increased this value after placed
|
|||||||
HUNGER_EXHAUST_MOVE = 0.3 -- exhaustion increased this value if player movement detected
|
HUNGER_EXHAUST_MOVE = 0.3 -- exhaustion increased this value if player movement detected
|
||||||
HUNGER_EXHAUST_LVL = 160 -- at what exhaustion player satiation gets lowerd
|
HUNGER_EXHAUST_LVL = 160 -- at what exhaustion player satiation gets lowerd
|
||||||
|
|
||||||
|
-- NALC : Fix MFF pclasses behaviour
|
||||||
|
local pc = false
|
||||||
|
if minetest.get_modpath("pclasses") and pclasses then
|
||||||
|
pc = true
|
||||||
|
end
|
||||||
|
|
||||||
--load custom settings
|
--load custom settings
|
||||||
local set = io.open(minetest.get_modpath("hbhunger").."/hbhunger.conf", "r")
|
local set = io.open(minetest.get_modpath("hbhunger").."/hbhunger.conf", "r")
|
||||||
@ -106,13 +111,14 @@ local function hunger_step()
|
|||||||
local hp = player:get_hp()
|
local hp = player:get_hp()
|
||||||
local timerquot = 1 -- By default regen 0.5 hearth every 10sec
|
local timerquot = 1 -- By default regen 0.5 hearth every 10sec
|
||||||
|
|
||||||
if pclasses.api.get_player_class(name) == "warrior" then
|
if pc then -- NALC : Fix MFF modif
|
||||||
timerquot = 1.42 -- Black_Mithril armor = 0.5 hearth every 7.0sec
|
if pclasses.api.get_player_class(name) == "warrior" then
|
||||||
elseif pclasses.api.util.does_wear_full_armor(name, "mithril", false) then
|
timerquot = 1.42 -- Black_Mithril armor = 0.5 hearth every 7.0sec
|
||||||
timerquot = 1.17 -- Mithril armor = 0.5 hearth every 8.5sec
|
elseif pclasses.api.util.does_wear_full_armor(name, "mithril", false) then
|
||||||
|
timerquot = 1.17 -- Mithril armor = 0.5 hearth every 8.5sec
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
if timer > 10/timerquot then
|
if timer > 10/timerquot then
|
||||||
-- heal player by 1 hp if not dead and satiation is > 15 (of 30)
|
-- heal player by 1 hp if not dead and satiation is > 15 (of 30)
|
||||||
if h > 15 and hp > 0 and player:get_breath() > 0 then
|
if h > 15 and hp > 0 and player:get_breath() > 0 then
|
||||||
|
@ -1 +1 @@
|
|||||||
Subproject commit 71aa7b6d83f3e7edeac72678eedbeb002cd639e6
|
Subproject commit 2e77df9a8cee745ac2ce28a2aaa4fb4e3bfe02d2
|
@ -1,2 +1,4 @@
|
|||||||
default
|
default
|
||||||
mobs
|
mobs
|
||||||
|
maptools?
|
||||||
|
zombie?
|
||||||
|
@ -1,10 +1,19 @@
|
|||||||
|
|
||||||
-- Wolf by KrupnoPavel
|
-- Wolf by KrupnoPavel
|
||||||
|
|
||||||
|
local drop_coin = nil -- NALC : Drop silver coin by chance if maptools mod loaded
|
||||||
|
if minetest.get_modpath("maptools") then
|
||||||
|
drop_coin = {
|
||||||
|
name = "maptools:silver_coin",
|
||||||
|
chance = 4, min = 1, max = 1,
|
||||||
|
}
|
||||||
|
end
|
||||||
|
|
||||||
mobs:register_mob(
|
mobs:register_mob(
|
||||||
"pmobs:wolf",
|
"pmobs:wolf",
|
||||||
{
|
{
|
||||||
type = "monster",
|
type = "monster",
|
||||||
|
docile_by_day = true,
|
||||||
passive = false,
|
passive = false,
|
||||||
pathfinding = false,
|
pathfinding = false,
|
||||||
reach = 2,
|
reach = 2,
|
||||||
@ -30,21 +39,23 @@ mobs:register_mob(
|
|||||||
damage = 3,
|
damage = 3,
|
||||||
attack_type = "dogfight",
|
attack_type = "dogfight",
|
||||||
drops = {
|
drops = {
|
||||||
{name = "mobs:meat_raw",
|
{
|
||||||
chance = 1,
|
name = "mobs:meat_raw",
|
||||||
min = 2,
|
chance = 1,
|
||||||
max = 3,},
|
min = 2,
|
||||||
{name = "maptools:silver_coin",
|
max = 3,
|
||||||
chance = 4, min = 1, max = 1,},
|
},
|
||||||
|
drop_coin -- NALC
|
||||||
},
|
},
|
||||||
drawtype = "front",
|
drawtype = "front",
|
||||||
water_damage = 0,
|
water_damage = 0,
|
||||||
lava_damage = 5,
|
lava_damage = 5,
|
||||||
light_damage = 0,
|
light_damage = 0,
|
||||||
on_rightclick = function(self, clicker)
|
on_rightclick = function(self, clicker)
|
||||||
local tool = clicker:get_wielded_item()
|
local tool = clicker:get_wielded_item():get_name()
|
||||||
if tool:get_name() == "mobs:meat_raw" then
|
if tool == "mobs:meat_raw" or
|
||||||
clicker:get_inventory():remove_item("main", "mobs:meat_raw")
|
(minetest.get_modpath("zombie") and tool == "zombie:rotten_flesh") then
|
||||||
|
clicker:get_inventory():remove_item("main", tool)
|
||||||
minetest.add_entity(self.object:getpos(), "pmobs:dog")
|
minetest.add_entity(self.object:getpos(), "pmobs:dog")
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
end
|
end
|
||||||
|
@ -1,2 +1,5 @@
|
|||||||
default
|
default
|
||||||
mobs
|
mobs
|
||||||
|
nether?
|
||||||
|
maptools?
|
||||||
|
hbhunger?
|
||||||
|
@ -1,81 +1,131 @@
|
|||||||
|
|
||||||
-- Zombie by BlockMen
|
-- Zombie by BlockMen
|
||||||
|
|
||||||
mobs:register_mob("zombie:zombie", {
|
local drop_coin = nil -- NALC : Drop silver coin if maptools mod
|
||||||
-- animal, monster, npc, barbarian
|
local drop_napple = nil -- NALC : Drop nether apple if nether
|
||||||
type = "monster",
|
|
||||||
-- aggressive, deals 6 damage to player when hit
|
if minetest.get_modpath("maptools") then
|
||||||
passive = false,
|
drop_coin = {
|
||||||
attack_type = "dogfight",
|
name = "maptools:silver_coin",
|
||||||
pathfinding = false,
|
chance = 1, min = 1, max = 1
|
||||||
damage = 3,
|
}
|
||||||
-- health & armor
|
end
|
||||||
hp_min = 12,
|
|
||||||
hp_max = 35,
|
if minetest.get_modpath("nether") then
|
||||||
armor = 150,
|
drop_napple = {
|
||||||
-- textures and model
|
name = "nether:apple",
|
||||||
collisionbox = {-0.25, -1, -0.3, 0.25, 0.75, 0.3},
|
chance = 8, min = 1, max = 1
|
||||||
visual = "mesh",
|
}
|
||||||
mesh = "mobs_zombie.x",
|
end
|
||||||
textures = {
|
|
||||||
{"mobs_zombie.png"},
|
mobs:register_mob(
|
||||||
},
|
"zombie:zombie",
|
||||||
visual_size = {x=1, y=1},
|
{
|
||||||
blood_texture = "mobs_blood.png",
|
-- animal, monster, npc, barbarian
|
||||||
-- sounds
|
type = "monster",
|
||||||
makes_footstep_sound = true,
|
-- aggressive, deals 6 damage to player when hit
|
||||||
sounds = {
|
passive = false,
|
||||||
random = "mobs_zombie",
|
attack_type = "dogfight",
|
||||||
damage = "mobs_zombie_hit",
|
pathfinding = false,
|
||||||
attack = "mobs_zombie_attack",
|
damage = 3,
|
||||||
death = "mobs_zombie_death",
|
-- health & armor
|
||||||
},
|
hp_min = 12,
|
||||||
-- speed and jump
|
hp_max = 35,
|
||||||
view_range = 10,
|
armor = 150,
|
||||||
walk_velocity = 1,
|
-- textures and model
|
||||||
run_velocity = 3,
|
collisionbox = {-0.25, -1, -0.3, 0.25, 0.75, 0.3},
|
||||||
jump = true,
|
visual = "mesh",
|
||||||
floats = 0,
|
mesh = "mobs_zombie.x",
|
||||||
-- drops nether fruit and silver coin when dead
|
textures = {
|
||||||
drops = {
|
{"mobs_zombie.png"},
|
||||||
{name = "nether:apple",
|
},
|
||||||
chance = 2, min = 1, max = 2,},
|
visual_size = {x=1, y=1},
|
||||||
{name = "zombie:zombie_tibia",
|
blood_texture = "mobs_blood.png",
|
||||||
chance = 10, min = 1, max = 1,},
|
-- sounds
|
||||||
{name = "maptools:silver_coin",
|
makes_footstep_sound = true,
|
||||||
chance = 1, min = 1, max = 1,},
|
sounds = {
|
||||||
{name = "zombie:rotten_flesh",
|
random = "mobs_zombie",
|
||||||
chance = 2, min = 3, max = 5,},
|
damage = "mobs_zombie_hit",
|
||||||
},
|
attack = "mobs_zombie_attack",
|
||||||
-- damaged by
|
death = "mobs_zombie_death",
|
||||||
water_damage = 1,
|
},
|
||||||
lava_damage = 5,
|
-- speed and jump
|
||||||
light_damage = 2,
|
view_range = 10,
|
||||||
-- model animation
|
walk_velocity = 1,
|
||||||
animation = {
|
run_velocity = 3,
|
||||||
speed_normal = 10, speed_run = 15,
|
jump = true,
|
||||||
stand_start = 0, stand_end = 79,
|
floats = 0,
|
||||||
walk_start = 168, walk_end = 188,
|
-- drops nether fruit and silver coin when dead
|
||||||
run_start = 168, run_end = 188,
|
drops = {
|
||||||
-- punch_start = 168, punch_end = 188,
|
{name = "zombie:rotten_flesh",
|
||||||
},
|
chance = 2, min = 3, max = 5,},
|
||||||
})
|
{name = "zombie:zombie_tibia",
|
||||||
|
chance = 10, min = 1, max = 1,},
|
||||||
|
drop_napple, -- NALC
|
||||||
|
drop_coin -- NALC
|
||||||
|
},
|
||||||
|
-- damaged by
|
||||||
|
water_damage = 1,
|
||||||
|
lava_damage = 5,
|
||||||
|
light_damage = 2,
|
||||||
|
-- model animation
|
||||||
|
animation = {
|
||||||
|
speed_normal = 10, speed_run = 15,
|
||||||
|
stand_start = 0, stand_end = 79,
|
||||||
|
walk_start = 168, walk_end = 188,
|
||||||
|
run_start = 168, run_end = 188,
|
||||||
|
-- punch_start = 168, punch_end = 188,
|
||||||
|
},
|
||||||
|
})
|
||||||
mobs:alias_mob("mobs:zombie", "zombie:zombie")
|
mobs:alias_mob("mobs:zombie", "zombie:zombie")
|
||||||
|
|
||||||
-- spawn in nether forest between -1 and 5 light, 1 in 7000 change, 1 zombie in area up to 31000 in height
|
-- spawn in nether forest between -1 and 5 light, 1 in 7000 chance, 1 zombie in area up to 31000 in height
|
||||||
mobs:spawn_specific("zombie:zombie", {"nether:dirt_top", "default:dirt_with_grass", "default:stone"}, {"air"}, -1, 5, 30, 7000, 1, -31000, 31000, false)
|
mobs:spawn_specific("zombie:zombie", {"nether:dirt_top", "default:dirt_with_grass", "default:dirt", "default:stone"}, {"air"}, -1, 5, 30, 7000, 1, -31000, 31000, false)
|
||||||
-- register spawn egg
|
-- register spawn egg
|
||||||
mobs:register_egg("zombie:zombie", "Zombie", "mobs_zombie_inv.png", 1)
|
mobs:register_egg("zombie:zombie", "Zombie", "mobs_zombie_inv.png", 1)
|
||||||
|
|
||||||
minetest.register_craftitem("zombie:zombie_tibia", {
|
minetest.register_craftitem(
|
||||||
description = "Zombie Tibia",
|
"zombie:zombie_tibia",
|
||||||
inventory_image = "mobs_zombie_tibia.png",
|
{
|
||||||
groups = {magic = 1},
|
description = "Zombie Tibia",
|
||||||
})
|
inventory_image = "mobs_zombie_tibia.png",
|
||||||
|
groups = {magic = 1},
|
||||||
|
})
|
||||||
minetest.register_alias("mobs:zombie_tibia", "zombie:zombie_tibia")
|
minetest.register_alias("mobs:zombie_tibia", "zombie:zombie_tibia")
|
||||||
|
|
||||||
minetest.register_craftitem("zombie:rotten_flesh", {
|
minetest.register_craftitem(
|
||||||
description = "Rotten Flesh",
|
"zombie:rotten_flesh",
|
||||||
inventory_image = "mobs_rotten_flesh.png",
|
{
|
||||||
on_use = minetest.item_eat(1),
|
description = "Rotten Flesh",
|
||||||
|
inventory_image = "mobs_rotten_flesh.png",
|
||||||
|
|
||||||
|
on_use = function(itemstack, user) -- NALC : Augmente la faim de 5 points mais augmente la vie de 1 point
|
||||||
|
local inv = user:get_inventory()
|
||||||
|
if not inv then return end
|
||||||
|
itemstack:take_item()
|
||||||
|
|
||||||
|
-- Augmente la vie de 1 point
|
||||||
|
user:set_hp(user:get_hp() + 1)
|
||||||
|
|
||||||
|
-- Si hbhunger alors augmente la faim de 5 points (Réduction de la barre de faim)
|
||||||
|
if minetest.get_modpath("hbhunger") then
|
||||||
|
local p_hunger = tonumber(hbhunger.hunger[user:get_player_name()])
|
||||||
|
if not p_hunger then return end
|
||||||
|
p_hunger = p_hunger - 5
|
||||||
|
if p_hunger < 0 then p_hunger = 0 end
|
||||||
|
hbhunger.hunger[user:get_player_name()] = p_hunger
|
||||||
|
local save_hunger = hbhunger.save_hunger
|
||||||
|
if not save_hunger then save_hunger = hbhunger.set_hunger end
|
||||||
|
save_hunger(user)
|
||||||
|
end
|
||||||
|
|
||||||
|
return itemstack
|
||||||
|
end
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
type = "cooking",
|
||||||
|
output = "mobs:meat",
|
||||||
|
recipe = "zombie:rotten_flesh",
|
||||||
|
cooktime = 5,
|
||||||
})
|
})
|
||||||
|
Loading…
Reference in New Issue
Block a user