Compare commits
No commits in common. "master" and "master" have entirely different histories.
@ -2,6 +2,6 @@ PMobs by CProgrammerRU
|
|||||||
|
|
||||||
This mod uses the Mobs Redo Api to add new mobs to minetest.
|
This mod uses the Mobs Redo Api to add new mobs to minetest.
|
||||||
|
|
||||||
0.1 - Added Npc, Guard, Ninja, Wolf, Dog and Yeti
|
2.5 - Added Npc, Guard, Archer, Ninja, Wolf, Dog and Yeti
|
||||||
|
|
||||||
Special thanks to TenPlus1.
|
Special thanks to TenPlus1.
|
172
archer.lua
Normal file
@ -0,0 +1,172 @@
|
|||||||
|
|
||||||
|
-- Guard
|
||||||
|
|
||||||
|
mobs:register_mob("pmobs:archer", {
|
||||||
|
-- animal, monster, npc
|
||||||
|
type = "npc",
|
||||||
|
passive = true,
|
||||||
|
damage = 7,
|
||||||
|
attack_type = "shoot",
|
||||||
|
shoot_interval = 1,
|
||||||
|
arrow = "pmobs:arrow",
|
||||||
|
shoot_offset = 2,
|
||||||
|
attacks_monsters = true,
|
||||||
|
owner = "",
|
||||||
|
order = "follow",
|
||||||
|
-- health & armor
|
||||||
|
hp_min = 10, hp_max = 20, armor = 100,
|
||||||
|
-- textures and model
|
||||||
|
collisionbox = {-0.35,-1.0,-0.35, 0.35,0.8,0.35},
|
||||||
|
visual = "mesh",
|
||||||
|
mesh = "guard.x",
|
||||||
|
drawtype = "front",
|
||||||
|
textures = {
|
||||||
|
{"mobs_npc.png", "npcf_skin_armor.png", "pmobs_bow.png"},
|
||||||
|
},
|
||||||
|
visual_size = {x=1, y=1},
|
||||||
|
-- sounds
|
||||||
|
makes_footstep_sound = true,
|
||||||
|
sounds = {},
|
||||||
|
-- speed and jump
|
||||||
|
walk_velocity = 4,
|
||||||
|
run_velocity = 4,
|
||||||
|
floats = {x=0,y=0,z=0},
|
||||||
|
jump = true,
|
||||||
|
stepheight = 1.1,
|
||||||
|
-- drops wood and chance of apples when dead
|
||||||
|
drops = {
|
||||||
|
{name = "default:wood",
|
||||||
|
chance = 1, min = 1, max = 3},
|
||||||
|
{name = "default:apple",
|
||||||
|
chance = 2, min = 1, max = 2},
|
||||||
|
{name = "default:axe_stone",
|
||||||
|
chance = 3, min = 1, max = 1},
|
||||||
|
},
|
||||||
|
-- damaged by
|
||||||
|
water_damage = 0,
|
||||||
|
lava_damage = 2,
|
||||||
|
light_damage = 0,
|
||||||
|
|
||||||
|
view_range = 15,
|
||||||
|
-- model animation
|
||||||
|
animation = {
|
||||||
|
speed_normal = 30, speed_run = 30,
|
||||||
|
stand_start = 0, stand_end = 79,
|
||||||
|
walk_start = 168, walk_end = 187,
|
||||||
|
run_start = 168, run_end = 187,
|
||||||
|
punch_start = 200, punch_end = 219,
|
||||||
|
},
|
||||||
|
-- rotate arrows
|
||||||
|
do_custom = function(self)
|
||||||
|
local s = self.object:getpos()
|
||||||
|
local obj = nil
|
||||||
|
for _,oir in ipairs(minetest.get_objects_inside_radius(s, self.view_range)) do
|
||||||
|
obj = oir:get_luaentity()
|
||||||
|
if obj then
|
||||||
|
if obj.name == "pmobs:arrow" then
|
||||||
|
obj.object:setyaw(self.object:getyaw()-1.57)
|
||||||
|
break
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
-- right clicking with cooked meat will give npc more health
|
||||||
|
on_rightclick = function(self, clicker)
|
||||||
|
local item = clicker:get_wielded_item()
|
||||||
|
if item:get_name() == "mobs:meat" or item:get_name() == "farming:bread" then
|
||||||
|
local hp = self.object:get_hp()
|
||||||
|
if hp + 4 > self.hp_max then return end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
item:take_item()
|
||||||
|
clicker:set_wielded_item(item)
|
||||||
|
end
|
||||||
|
self.object:set_hp(hp+4)
|
||||||
|
|
||||||
|
|
||||||
|
-- right clicking with gold lump drops random item from mobs.npc_drops
|
||||||
|
elseif item:get_name() == "default:gold_lump" then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
item:take_item()
|
||||||
|
clicker:set_wielded_item(item)
|
||||||
|
end
|
||||||
|
local pos = self.object:getpos()
|
||||||
|
pos.y = pos.y + 0.5
|
||||||
|
minetest.add_item(pos, {name = mobs.npc_drops[math.random(1,#mobs.npc_drops)]})
|
||||||
|
else
|
||||||
|
if self.owner == "" then
|
||||||
|
self.owner = clicker:get_player_name()
|
||||||
|
else
|
||||||
|
local formspec = "size[8,4]"
|
||||||
|
formspec = formspec .. "textlist[2.85,0;2.1,0.5;dialog;What can I do for you?]"
|
||||||
|
formspec = formspec .. "button_exit[1,1;2,2;afollow;follow]"
|
||||||
|
formspec = formspec .. "button_exit[5,1;2,2;astand;stand]"
|
||||||
|
formspec = formspec .. "button_exit[0,2;4,4;afandp;follow and protect]"
|
||||||
|
formspec = formspec .. "button_exit[4,2;4,4;asandp;stand and protect]"
|
||||||
|
formspec = formspec .. "button_exit[1,2;2,2;agohome; go home]"
|
||||||
|
formspec = formspec .. "button_exit[5,2;2,2;asethome; sethome]"
|
||||||
|
minetest.show_formspec(clicker:get_player_name(), "order", formspec)
|
||||||
|
minetest.register_on_player_receive_fields(function(clicker, formname, fields)
|
||||||
|
if fields.afollow then
|
||||||
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = false
|
||||||
|
end
|
||||||
|
if fields.astand then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = false
|
||||||
|
end
|
||||||
|
if fields.afandp then
|
||||||
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = true
|
||||||
|
end
|
||||||
|
if fields.asandp then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = true
|
||||||
|
end
|
||||||
|
if fields.asethome then
|
||||||
|
self.floats = self.object:getpos()
|
||||||
|
end
|
||||||
|
if fields.agohome then
|
||||||
|
if self.floats then
|
||||||
|
self.order = "stand"
|
||||||
|
self.object:setpos(self.floats)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
mobs:register_egg("pmobs:archer", "Archer", "default_tree.png", 1)
|
||||||
|
|
||||||
|
|
||||||
|
mobs:register_arrow("pmobs:arrow", {
|
||||||
|
physical = false,
|
||||||
|
timer=0,
|
||||||
|
view_range = 15,
|
||||||
|
visual = "wielditem",
|
||||||
|
visual_size = {x=0.1, y=0.1},
|
||||||
|
textures = {"pmobs:arrow_box"},
|
||||||
|
lastpos={},
|
||||||
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
velocity = 6,
|
||||||
|
drop = true,
|
||||||
|
|
||||||
|
hit_player = function(self, player)
|
||||||
|
end,
|
||||||
|
|
||||||
|
hit_mob = function(self, player)
|
||||||
|
player:punch(self.object, 1.0, {
|
||||||
|
full_punch_interval=1.0,
|
||||||
|
damage_groups = {fleshy=3},
|
||||||
|
}, 0)
|
||||||
|
end,
|
||||||
|
|
||||||
|
hit_node = function(self, pos, node)
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
86
arrow.lua
Normal file
@ -0,0 +1,86 @@
|
|||||||
|
minetest.register_craftitem("pmobs:arrow", {
|
||||||
|
description = "Arrow",
|
||||||
|
inventory_image = "pmobs_arrow.png",
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("pmobs:arrow_box", {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
-- Shaft
|
||||||
|
{-6.5/17, -1.5/17, -1.5/17, 6.5/17, 1.5/17, 1.5/17},
|
||||||
|
--Spitze
|
||||||
|
{-4.5/17, 2.5/17, 2.5/17, -3.5/17, -2.5/17, -2.5/17},
|
||||||
|
{-8.5/17, 0.5/17, 0.5/17, -6.5/17, -0.5/17, -0.5/17},
|
||||||
|
--Federn
|
||||||
|
{6.5/17, 1.5/17, 1.5/17, 7.5/17, 2.5/17, 2.5/17},
|
||||||
|
{7.5/17, -2.5/17, 2.5/17, 6.5/17, -1.5/17, 1.5/17},
|
||||||
|
{7.5/17, 2.5/17, -2.5/17, 6.5/17, 1.5/17, -1.5/17},
|
||||||
|
{6.5/17, -1.5/17, -1.5/17, 7.5/17, -2.5/17, -2.5/17},
|
||||||
|
|
||||||
|
{7.5/17, 2.5/17, 2.5/17, 8.5/17, 3.5/17, 3.5/17},
|
||||||
|
{8.5/17, -3.5/17, 3.5/17, 7.5/17, -2.5/17, 2.5/17},
|
||||||
|
{8.5/17, 3.5/17, -3.5/17, 7.5/17, 2.5/17, -2.5/17},
|
||||||
|
{7.5/17, -2.5/17, -2.5/17, 8.5/17, -3.5/17, -3.5/17},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
tiles = {"pmobs_arrow.png", "pmobs_arrow.png", "pmobs_arrow_back.png", "pmobs_arrow_front.png", "pmobs_arrow_2.png", "pmobs_arrow.png"},
|
||||||
|
groups = {not_in_creative_inventory=1},
|
||||||
|
})
|
||||||
|
|
||||||
|
local pmobs_ARROW_ENTITY={
|
||||||
|
physical = false,
|
||||||
|
timer=0,
|
||||||
|
visual = "wielditem",
|
||||||
|
visual_size = {x=0.1, y=0.1},
|
||||||
|
textures = {"pmobs:arrow_box"},
|
||||||
|
lastpos={},
|
||||||
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
}
|
||||||
|
|
||||||
|
pmobs_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
|
self.timer=self.timer+dtime
|
||||||
|
local pos = self.object:getpos()
|
||||||
|
local node = minetest.env:get_node(pos)
|
||||||
|
|
||||||
|
if self.timer>0.2 then
|
||||||
|
local objs = minetest.env:get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
|
for k, obj in pairs(objs) do
|
||||||
|
if obj:get_luaentity() ~= nil then
|
||||||
|
if obj:get_luaentity().name ~= "pmobs:arrow_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
||||||
|
local damage = 3
|
||||||
|
obj:punch(self.object, 1.0, {
|
||||||
|
full_punch_interval=1.0,
|
||||||
|
damage_groups={fleshy=damage},
|
||||||
|
}, nil)
|
||||||
|
self.object:remove()
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local damage = 3
|
||||||
|
obj:punch(self.object, 1.0, {
|
||||||
|
full_punch_interval=1.0,
|
||||||
|
damage_groups={fleshy=damage},
|
||||||
|
}, nil)
|
||||||
|
self.object:remove()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if self.lastpos.x~=nil then
|
||||||
|
if node.name ~= "air" then
|
||||||
|
minetest.env:add_item(self.lastpos, 'pmobs:arrow')
|
||||||
|
self.object:remove()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_entity("pmobs:arrow_entity", pmobs_ARROW_ENTITY)
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'pmobs:arrow 16',
|
||||||
|
recipe = {
|
||||||
|
{'default:stick', 'default:stick', 'default:steel_ingot'},
|
||||||
|
}
|
||||||
|
})
|
3
depends.txt
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
default
|
||||||
|
mobs
|
||||||
|
sethome
|
42
dog.lua
@ -13,15 +13,16 @@ mobs:register_mob("pmobs:dog", {
|
|||||||
},
|
},
|
||||||
makes_footstep_sound = true,
|
makes_footstep_sound = true,
|
||||||
sounds = {
|
sounds = {
|
||||||
random = "mobs_wolf",
|
|
||||||
war_cry = "mobs_wolf_attack",
|
war_cry = "mobs_wolf_attack",
|
||||||
},
|
},
|
||||||
view_range = 15,
|
view_range = 15,
|
||||||
stepheight = 1.1,
|
stepheight = 1.1,
|
||||||
owner = "",
|
owner = "",
|
||||||
order = "follow",
|
order = "follow",
|
||||||
|
floats = {x=0,y=0,z=0},
|
||||||
walk_velocity = 4,
|
walk_velocity = 4,
|
||||||
run_velocity = 4,
|
run_velocity = 4,
|
||||||
|
stepheight = 1.1,
|
||||||
damage = 2,
|
damage = 2,
|
||||||
armor = 200,
|
armor = 200,
|
||||||
attacks_monsters = true,
|
attacks_monsters = true,
|
||||||
@ -50,11 +51,42 @@ mobs:register_mob("pmobs:dog", {
|
|||||||
if self.owner == "" then
|
if self.owner == "" then
|
||||||
self.owner = clicker:get_player_name()
|
self.owner = clicker:get_player_name()
|
||||||
else
|
else
|
||||||
if self.order == "follow" then
|
local formspec = "size[8,4]"
|
||||||
self.order = "stand"
|
formspec = formspec .. "textlist[2.85,0;2.1,0.5;dialog;What can I do for you?]"
|
||||||
else
|
formspec = formspec .. "button_exit[1,1;2,2;dfollow;follow]"
|
||||||
|
formspec = formspec .. "button_exit[5,1;2,2;dstand;stand]"
|
||||||
|
formspec = formspec .. "button_exit[0,2;4,4;dfandp;follow and protect]"
|
||||||
|
formspec = formspec .. "button_exit[4,2;4,4;dsandp;stand and protect]"
|
||||||
|
formspec = formspec .. "button_exit[1,2;2,2;dgohome; go home]"
|
||||||
|
formspec = formspec .. "button_exit[5,2;2,2;dsethome; sethome]"
|
||||||
|
minetest.show_formspec(clicker:get_player_name(), "order", formspec)
|
||||||
|
minetest.register_on_player_receive_fields(function(clicker, formname, fields)
|
||||||
|
if fields.dfollow then
|
||||||
self.order = "follow"
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = false
|
||||||
end
|
end
|
||||||
|
if fields.dstand then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = false
|
||||||
|
end
|
||||||
|
if fields.dfandp then
|
||||||
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = true
|
||||||
|
end
|
||||||
|
if fields.dsandp then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = true
|
||||||
|
end
|
||||||
|
if fields.dsethome then
|
||||||
|
self.floats = self.object:getpos()
|
||||||
|
end
|
||||||
|
if fields.dgohome then
|
||||||
|
if self.floats then
|
||||||
|
self.order = "stand"
|
||||||
|
self.object:setpos(self.floats)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
@ -75,5 +107,3 @@ mobs:register_mob("pmobs:dog", {
|
|||||||
blood_texture = "mobs_blood.png",
|
blood_texture = "mobs_blood.png",
|
||||||
})
|
})
|
||||||
mobs:register_egg("pmobs:dog", "Dog", "wool_brown.png", 1)
|
mobs:register_egg("pmobs:dog", "Dog", "wool_brown.png", 1)
|
||||||
|
|
||||||
mobs:alias_mob("mobs:dog", "pmobs:dog")
|
|
||||||
|
121
fire_arrow.lua
Normal file
@ -0,0 +1,121 @@
|
|||||||
|
minetest.register_craftitem("pmobs:arrow_fire", {
|
||||||
|
description = "Fire Arrow",
|
||||||
|
inventory_image = "pmobs_arrow_fire.png",
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("pmobs:arrow_fire_box", {
|
||||||
|
drawtype = "nodebox",
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
-- Shaft
|
||||||
|
{-6.5/17, -1.5/17, -1.5/17, 6.5/17, 1.5/17, 1.5/17},
|
||||||
|
--Spitze
|
||||||
|
{-4.5/17, 2.5/17, 2.5/17, -3.5/17, -2.5/17, -2.5/17},
|
||||||
|
{-8.5/17, 0.5/17, 0.5/17, -6.5/17, -0.5/17, -0.5/17},
|
||||||
|
--Federn
|
||||||
|
{6.5/17, 1.5/17, 1.5/17, 7.5/17, 2.5/17, 2.5/17},
|
||||||
|
{7.5/17, -2.5/17, 2.5/17, 6.5/17, -1.5/17, 1.5/17},
|
||||||
|
{7.5/17, 2.5/17, -2.5/17, 6.5/17, 1.5/17, -1.5/17},
|
||||||
|
{6.5/17, -1.5/17, -1.5/17, 7.5/17, -2.5/17, -2.5/17},
|
||||||
|
|
||||||
|
{7.5/17, 2.5/17, 2.5/17, 8.5/17, 3.5/17, 3.5/17},
|
||||||
|
{8.5/17, -3.5/17, 3.5/17, 7.5/17, -2.5/17, 2.5/17},
|
||||||
|
{8.5/17, 3.5/17, -3.5/17, 7.5/17, 2.5/17, -2.5/17},
|
||||||
|
{7.5/17, -2.5/17, -2.5/17, 8.5/17, -3.5/17, -3.5/17},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
tiles = {"pmobs_arrow_fire.png", "pmobs_arrow_fire.png", "pmobs_arrow_fire_back.png", "pmobs_arrow_fire_front.png", "pmobs_arrow_fire_2.png", "pmobs_arrow_fire.png"},
|
||||||
|
groups = {not_in_creative_inventory=1},
|
||||||
|
})
|
||||||
|
|
||||||
|
local pmobs_ARROW_ENTITY={
|
||||||
|
physical = false,
|
||||||
|
timer=0,
|
||||||
|
visual = "wielditem",
|
||||||
|
visual_size = {x=0.1, y=0.1},
|
||||||
|
textures = {"pmobs:arrow_fire_box"},
|
||||||
|
lastpos={},
|
||||||
|
collisionbox = {0,0,0,0,0,0},
|
||||||
|
}
|
||||||
|
|
||||||
|
pmobs_ARROW_ENTITY.on_step = function(self, dtime)
|
||||||
|
self.timer=self.timer+dtime
|
||||||
|
local pos = self.object:getpos()
|
||||||
|
local node = minetest.env:get_node(pos)
|
||||||
|
|
||||||
|
if self.timer>0.2 then
|
||||||
|
local objs = minetest.env:get_objects_inside_radius({x=pos.x,y=pos.y,z=pos.z}, 2)
|
||||||
|
for k, obj in pairs(objs) do
|
||||||
|
if obj:get_luaentity() ~= nil then
|
||||||
|
if obj:get_luaentity().name ~= "pmobs:arrow_fire_entity" and obj:get_luaentity().name ~= "__builtin:item" then
|
||||||
|
local damage = 5
|
||||||
|
obj:punch(self.object, 1.0, {
|
||||||
|
full_punch_interval=1.0,
|
||||||
|
damage_groups={fleshy=damage},
|
||||||
|
}, nil)
|
||||||
|
self.object:remove()
|
||||||
|
end
|
||||||
|
else
|
||||||
|
local damage = 5
|
||||||
|
obj:punch(self.object, 1.0, {
|
||||||
|
full_punch_interval=1.0,
|
||||||
|
damage_groups={fleshy=damage},
|
||||||
|
}, nil)
|
||||||
|
self.object:remove()
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
if self.lastpos.x~=nil then
|
||||||
|
if node.name ~= "air" and node.name ~= "pmobs:light" then
|
||||||
|
minetest.env:set_node(self.lastpos, {name="fire:basic_flame"})
|
||||||
|
self.object:remove()
|
||||||
|
end
|
||||||
|
if math.floor(self.lastpos.x+0.5) ~= math.floor(pos.x+0.5) or math.floor(self.lastpos.y+0.5) ~= math.floor(pos.y+0.5) or math.floor(self.lastpos.z+0.5) ~= math.floor(pos.z+0.5) then
|
||||||
|
if minetest.env:get_node(self.lastpos).name == "pmobs:light" then
|
||||||
|
minetest.env:remove_node(self.lastpos)
|
||||||
|
end
|
||||||
|
if minetest.env:get_node(pos).name == "air" then
|
||||||
|
minetest.env:set_node(pos, {name="pmobs:light"})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
self.lastpos={x=pos.x, y=pos.y, z=pos.z}
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_entity("pmobs:arrow_fire_entity", pmobs_ARROW_ENTITY)
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'pmobs:arrow_fire 4',
|
||||||
|
recipe = {
|
||||||
|
{'default:stick', 'default:stick', 'bucket:bucket_lava'},
|
||||||
|
},
|
||||||
|
replacements = {
|
||||||
|
{"bucket:bucket_lava", "bucket:bucket_empty"}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("pmobs:light", {
|
||||||
|
drawtype = "airlike",
|
||||||
|
paramtype = "light",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
tiles = {"pmobs_empty.png"},
|
||||||
|
light_source = LIGHT_MAX-4,
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
{0,0,0,0,0,0}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
groups = {not_in_creative_inventory=1}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_abm({
|
||||||
|
nodenames = {"pmobs:light"},
|
||||||
|
interval = 10,
|
||||||
|
chance = 1,
|
||||||
|
action = function(pos, node)
|
||||||
|
minetest.env:remove_node(pos)
|
||||||
|
end
|
||||||
|
})
|
44
guard.lua
@ -25,9 +25,11 @@ mobs:register_mob("pmobs:guard", {
|
|||||||
makes_footstep_sound = true,
|
makes_footstep_sound = true,
|
||||||
sounds = {},
|
sounds = {},
|
||||||
-- speed and jump
|
-- speed and jump
|
||||||
walk_velocity = 3,
|
walk_velocity = 4,
|
||||||
run_velocity = 3,
|
run_velocity = 4,
|
||||||
jump = true,
|
jump = true,
|
||||||
|
floats = {x=0,y=0,z=0},
|
||||||
|
stepheight = 1.1,
|
||||||
-- drops wood and chance of apples when dead
|
-- drops wood and chance of apples when dead
|
||||||
drops = {
|
drops = {
|
||||||
{name = "default:wood",
|
{name = "default:wood",
|
||||||
@ -77,11 +79,43 @@ mobs:register_mob("pmobs:guard", {
|
|||||||
if self.owner == "" then
|
if self.owner == "" then
|
||||||
self.owner = clicker:get_player_name()
|
self.owner = clicker:get_player_name()
|
||||||
else
|
else
|
||||||
if self.order == "follow" then
|
local formspec = "size[8,4]"
|
||||||
self.order = "stand"
|
formspec = formspec .. "textlist[2.85,0;2.1,0.5;dialog;What can I do for you?]"
|
||||||
else
|
formspec = formspec .. "button_exit[1,1;2,2;gfollow;follow]"
|
||||||
|
formspec = formspec .. "button_exit[5,1;2,2;gstand;stand]"
|
||||||
|
formspec = formspec .. "button_exit[0,2;4,4;gfandp;follow and protect]"
|
||||||
|
formspec = formspec .. "button_exit[4,2;4,4;gsandp;stand and protect]"
|
||||||
|
formspec = formspec .. "button_exit[1,2;2,2;ggohome; go home]"
|
||||||
|
formspec = formspec .. "button_exit[5,2;2,2;gsethome; sethome]"
|
||||||
|
minetest.show_formspec(clicker:get_player_name(), "order", formspec)
|
||||||
|
minetest.register_on_player_receive_fields(function(clicker, formname, fields)
|
||||||
|
if fields.gfollow then
|
||||||
self.order = "follow"
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = false
|
||||||
end
|
end
|
||||||
|
if fields.gstand then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = false
|
||||||
|
end
|
||||||
|
if fields.gfandp then
|
||||||
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = true
|
||||||
|
end
|
||||||
|
if fields.gsandp then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = true
|
||||||
|
end
|
||||||
|
if fields.gsethome then
|
||||||
|
self.floats = self.object:getpos()
|
||||||
|
end
|
||||||
|
if fields.ggohome then
|
||||||
|
if self.floats then
|
||||||
|
self.order = "stand"
|
||||||
|
self.object:setpos(self.floats)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
|
17
init.lua
@ -2,19 +2,26 @@
|
|||||||
-- Animals
|
-- Animals
|
||||||
|
|
||||||
dofile(minetest.get_modpath("pmobs").."/wolf.lua") -- KrupnoPavel
|
dofile(minetest.get_modpath("pmobs").."/wolf.lua") -- KrupnoPavel
|
||||||
dofile(minetest.get_modpath("pmobs").."/dog.lua")
|
dofile(minetest.get_modpath("pmobs").."/dog.lua") -- CProgrammerRU
|
||||||
|
|
||||||
-- Monsters
|
-- Monsters
|
||||||
|
|
||||||
--dofile(minetest.get_modpath("pmobs").."/ninja.lua") -- CProgrammingRU
|
dofile(minetest.get_modpath("pmobs").."/ninja.lua") -- CProgrammerRU
|
||||||
dofile(minetest.get_modpath("pmobs").."/yeti.lua") -- TenPlus1
|
dofile(minetest.get_modpath("pmobs").."/yeti.lua") -- TenPlus1
|
||||||
|
|
||||||
-- NPC
|
-- NPC
|
||||||
dofile(minetest.get_modpath("pmobs").."/npc.lua") -- TenPlus1
|
dofile(minetest.get_modpath("pmobs").."/npc.lua") -- TenPlus1
|
||||||
dofile(minetest.get_modpath("pmobs").."/npc_female.lua") -- NALC(sys4 fork MFF) nuttmeg20
|
dofile(minetest.get_modpath("pmobs").."/npc_women.lua") -- CProgrammerRU (texture by TenPlus1)
|
||||||
dofile(minetest.get_modpath("pmobs").."/guard.lua") -- CProgrammingRU
|
dofile(minetest.get_modpath("pmobs").."/npc_nurse.lua") -- CProgrammerRU
|
||||||
|
dofile(minetest.get_modpath("pmobs").."/guard.lua") -- CProgrammerRU
|
||||||
|
dofile(minetest.get_modpath("pmobs").."/archer.lua") -- CProgrammerRU
|
||||||
|
|
||||||
if minetest.settings:get("log_mods") then
|
dofile(minetest.get_modpath("pmobs").."/throwing.lua")
|
||||||
|
dofile(minetest.get_modpath("pmobs").."/arrow.lua")
|
||||||
|
dofile(minetest.get_modpath("pmobs").."/fire_arrow.lua")
|
||||||
|
|
||||||
|
|
||||||
|
if minetest.setting_get("log_mods") then
|
||||||
minetest.log("action", "pmobs loaded")
|
minetest.log("action", "pmobs loaded")
|
||||||
end
|
end
|
||||||
|
|
||||||
|
5
mod.conf
@ -1,5 +0,0 @@
|
|||||||
name = pmobs
|
|
||||||
title = PMobs
|
|
||||||
description = This mod uses the Mobs Redo Api to add new mobs to minetest.
|
|
||||||
depends = default,mobs
|
|
||||||
optional_depends = maptools,zombie,snow
|
|
@ -52,7 +52,7 @@ mobs:register_mob("pmobs:ninja", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
-- ninja spawn on top of trees
|
-- ninja spawn on top of trees
|
||||||
mobs:register_spawn("pmobs:ninja", {"default:leaves"}, 5, 0, 10000, 1, 31000)
|
mobs:register_spawn("pmobs:ninja", {"default:leaves"}, 20, 0, 15000, 1, 31000)
|
||||||
mobs:register_egg("pmobs:ninja", "Ninja", "default_leaves.png", 1)
|
mobs:register_egg("pmobs:ninja", "Ninja", "default_leaves.png", 1)
|
||||||
|
|
||||||
mobs:register_arrow("pmobs:shuriken", {
|
mobs:register_arrow("pmobs:shuriken", {
|
||||||
|
34
npc.lua
@ -1,12 +1,7 @@
|
|||||||
|
|
||||||
-- Npc by TenPlus1
|
-- Npc by TenPlus1
|
||||||
|
|
||||||
mobs.npc_drops = { "farming:meat", "farming:donut", "farming:bread", "default:apple", "default:sapling", "default:junglesapling",
|
mobs.npc_drops = { "default:pick_steel", "mobs:meat", "default:sword_steel", "default:shovel_steel", "farming:bread", "bucket:bucket_water" }
|
||||||
"shields:shield_enhanced_wood", "3d_armor:chestplate_cactus", "3d_armor:boots_bronze",
|
|
||||||
"default:sword_steel", "default:pick_steel", "default:shovel_steel", "default:bronze_ingot",
|
|
||||||
"bucket:bucket_water", "default:stick", "cavestuff:pebble_1", "building_blocks:stick",
|
|
||||||
"default:cobble", "default:gravel", "default:clay_lump", "default:sand", "default:dirt_with_grass",
|
|
||||||
"default:dirt", "default:chest", "default:torch"}
|
|
||||||
|
|
||||||
mobs:register_mob("pmobs:npc", {
|
mobs:register_mob("pmobs:npc", {
|
||||||
-- animal, monster, npc
|
-- animal, monster, npc
|
||||||
@ -26,18 +21,10 @@ mobs:register_mob("pmobs:npc", {
|
|||||||
textures = {
|
textures = {
|
||||||
{"mobs_npc.png"},
|
{"mobs_npc.png"},
|
||||||
},
|
},
|
||||||
child_texture = {
|
|
||||||
{"mobs_npc_baby.png"}, -- derpy baby by AmirDerAssassine
|
|
||||||
},
|
|
||||||
visual_size = {x=1, y=1},
|
visual_size = {x=1, y=1},
|
||||||
-- sounds
|
-- sounds
|
||||||
makes_footstep_sound = true,
|
makes_footstep_sound = true,
|
||||||
sounds = {
|
sounds = {},
|
||||||
random = "mobs_npc",
|
|
||||||
damage = "mobs_npc_hit",
|
|
||||||
attack = "mobs_npc_attack",
|
|
||||||
death = "mobs_npc_death",
|
|
||||||
},
|
|
||||||
-- speed and jump
|
-- speed and jump
|
||||||
walk_velocity = 3,
|
walk_velocity = 3,
|
||||||
run_velocity = 3,
|
run_velocity = 3,
|
||||||
@ -50,14 +37,12 @@ mobs:register_mob("pmobs:npc", {
|
|||||||
chance = 2, min = 1, max = 2},
|
chance = 2, min = 1, max = 2},
|
||||||
{name = "default:axe_stone",
|
{name = "default:axe_stone",
|
||||||
chance = 3, min = 1, max = 1},
|
chance = 3, min = 1, max = 1},
|
||||||
{name = "maptools:silver_coin", chance = 10, min = 1, max = 1,},
|
|
||||||
},
|
},
|
||||||
-- damaged by
|
-- damaged by
|
||||||
water_damage = 0,
|
water_damage = 0,
|
||||||
lava_damage = 2,
|
lava_damage = 2,
|
||||||
light_damage = 0,
|
light_damage = 0,
|
||||||
|
|
||||||
follow = {"farming:bread", "mobs:meat", "default:diamond"},
|
|
||||||
view_range = 15,
|
view_range = 15,
|
||||||
-- model animation
|
-- model animation
|
||||||
animation = {
|
animation = {
|
||||||
@ -70,10 +55,20 @@ mobs:register_mob("pmobs:npc", {
|
|||||||
-- right clicking with cooked meat will give npc more health
|
-- right clicking with cooked meat will give npc more health
|
||||||
on_rightclick = function(self, clicker)
|
on_rightclick = function(self, clicker)
|
||||||
local item = clicker:get_wielded_item()
|
local item = clicker:get_wielded_item()
|
||||||
|
local guard
|
||||||
|
local ent
|
||||||
if item:get_name() == "default:sword_steel" then
|
if item:get_name() == "default:sword_steel" then
|
||||||
minetest.add_entity(self.object:getpos(), "pmobs:guard")
|
guard = minetest.add_entity(self.object:getpos(), "pmobs:guard")
|
||||||
|
ent = guard:get_luaentity()
|
||||||
|
ent.owner = clicker:get_player_name()
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
clicker:get_inventory():remove_item("main", "default:sword_steel")
|
clicker:get_inventory():remove_item("main", "default:sword_steel")
|
||||||
|
elseif item:get_name() == "pmobs:bow_steel" then
|
||||||
|
guard = minetest.add_entity(self.object:getpos(), "pmobs:archer")
|
||||||
|
ent = guard:get_luaentity()
|
||||||
|
ent.owner = clicker:get_player_name()
|
||||||
|
self.object:remove()
|
||||||
|
clicker:get_inventory():remove_item("main", "pmobs:bow_steel")
|
||||||
elseif item:get_name() == "mobs:meat" or item:get_name() == "farming:bread" then
|
elseif item:get_name() == "mobs:meat" or item:get_name() == "farming:bread" then
|
||||||
local hp = self.object:get_hp()
|
local hp = self.object:get_hp()
|
||||||
if hp + 4 > self.hp_max then return end
|
if hp + 4 > self.hp_max then return end
|
||||||
@ -98,9 +93,8 @@ mobs:register_mob("pmobs:npc", {
|
|||||||
end,
|
end,
|
||||||
})
|
})
|
||||||
-- spawning disabled for now
|
-- spawning disabled for now
|
||||||
mobs:register_spawn("pmobs:npc", {"default:dirt_with_grass"}, 20, 0, 500000, 1, 31000)
|
mobs:register_spawn("pmobs:npc", {"default:dirt_with_grass"}, 20, 0, 15000, 1, 31000)
|
||||||
|
|
||||||
-- register spawn egg
|
-- register spawn egg
|
||||||
mobs:register_egg("pmobs:npc", "Npc", "default_brick.png", 1)
|
mobs:register_egg("pmobs:npc", "Npc", "default_brick.png", 1)
|
||||||
|
|
||||||
mobs:alias_mob("mobs:npc", "pmobs:npc")
|
|
||||||
|
137
npc_female.lua
@ -1,137 +0,0 @@
|
|||||||
|
|
||||||
-- Npc by TenPlus1
|
|
||||||
|
|
||||||
mobs.npc_drops = { "farming:meat", "farming:donut", "farming:bread", "default:apple", "default:sapling", "default:junglesapling",
|
|
||||||
"shields:shield_enhanced_wood", "3d_armor:chestplate_cactus", "3d_armor:boots_bronze",
|
|
||||||
"default:sword_steel", "default:pick_steel", "default:shovel_steel", "default:bronze_ingot",
|
|
||||||
"bucket:bucket_water", "default:stick", "cavestuff:pebble_1", "building_blocks:stick",
|
|
||||||
"default:cobble", "default:gravel", "default:clay_lump", "default:sand", "default:dirt_with_grass",
|
|
||||||
"default:dirt", "default:chest", "default:torch"}
|
|
||||||
|
|
||||||
|
|
||||||
mobs:register_mob("pmobs:npc_female", {
|
|
||||||
-- animal, monster, npc
|
|
||||||
type = "npc",
|
|
||||||
-- aggressive, deals 6 damage to player/monster when hit
|
|
||||||
passive = false,
|
|
||||||
group_attack = true,
|
|
||||||
damage = 4, -- 3 damages if tamed
|
|
||||||
attack_type = "dogfight",
|
|
||||||
attacks_monsters = true,
|
|
||||||
pathfinding = false,
|
|
||||||
-- health & armor
|
|
||||||
hp_min = 20,
|
|
||||||
hp_max = 20,
|
|
||||||
armor = 200,
|
|
||||||
-- textures and model
|
|
||||||
collisionbox = {-0.35,-1.0,-0.35, 0.35,0.8,0.35},
|
|
||||||
visual = "mesh",
|
|
||||||
mesh = "character.b3d",
|
|
||||||
drawtype = "front",
|
|
||||||
textures = {
|
|
||||||
{"mobs_npc_female.png"}, -- female by nuttmeg20
|
|
||||||
},
|
|
||||||
child_texture = {
|
|
||||||
{"mobs_npc_baby.png"}, -- derpy baby by AmirDerAssassine
|
|
||||||
},
|
|
||||||
-- sounds
|
|
||||||
makes_footstep_sound = true,
|
|
||||||
sounds = {
|
|
||||||
random = "mobs_fnpc", -- 2 sounds
|
|
||||||
damage = "mobs_fnpc_hit", -- 2 sounds
|
|
||||||
attack = "mobs_fnpc_attack", -- 1 sound
|
|
||||||
death = "mobs_fnpc_death", -- 1 sound
|
|
||||||
},
|
|
||||||
-- speed and jump
|
|
||||||
walk_velocity = 3,
|
|
||||||
run_velocity = 3,
|
|
||||||
jump = true,
|
|
||||||
-- drops wood and chance of apples when dead
|
|
||||||
drops = {
|
|
||||||
{name = "default:wood", chance = 1, min = 1, max = 3},
|
|
||||||
{name = "default:apple", chance = 2, min = 1, max = 2},
|
|
||||||
{name = "flowers:tulip", chance = 4, min = 1, max = 2},
|
|
||||||
{name = "flowers:rose", chance = 4, min = 1, max = 2},
|
|
||||||
{name = "default:axe_stone", chance = 6, min = 1, max = 1},
|
|
||||||
{name = "maptools:silver_coin", chance = 10, min = 1, max = 1,},
|
|
||||||
},
|
|
||||||
-- damaged by
|
|
||||||
water_damage = 0,
|
|
||||||
lava_damage = 6,
|
|
||||||
light_damage = 0,
|
|
||||||
-- follow diamond
|
|
||||||
follow = {"farming:bread", "mobs:meat", "default:diamond"},
|
|
||||||
view_range = 16,
|
|
||||||
-- set owner and order
|
|
||||||
owner = "",
|
|
||||||
order = "follow",
|
|
||||||
fear_height = 3,
|
|
||||||
-- model animation
|
|
||||||
animation = {
|
|
||||||
speed_normal = 30,
|
|
||||||
speed_run = 30,
|
|
||||||
stand_start = 0,
|
|
||||||
stand_end = 79,
|
|
||||||
walk_start = 168,
|
|
||||||
walk_end = 187,
|
|
||||||
run_start = 168,
|
|
||||||
run_end = 187,
|
|
||||||
punch_start = 200,
|
|
||||||
punch_end = 219,
|
|
||||||
},
|
|
||||||
-- right clicking with "cooked meat" or "bread" will give npc more health
|
|
||||||
on_rightclick = function(self, clicker)
|
|
||||||
|
|
||||||
local item = clicker:get_wielded_item()
|
|
||||||
local name = clicker:get_player_name()
|
|
||||||
if item:get_name() == "default:diamond" then --/MFF (Crabman|07/14/2015) tamed with diamond
|
|
||||||
if (self.diamond_count or 0) < 4 then
|
|
||||||
self.diamond_count = (self.diamond_count or 0) + 1
|
|
||||||
if not minetest.setting_getbool("creative_mode") then
|
|
||||||
item:take_item()
|
|
||||||
clicker:set_wielded_item(item)
|
|
||||||
end
|
|
||||||
if self.diamond_count >= 4 then
|
|
||||||
self.damages = 3
|
|
||||||
self.tamed = true
|
|
||||||
self.owner = clicker:get_player_name()
|
|
||||||
end
|
|
||||||
end
|
|
||||||
return
|
|
||||||
-- feed to heal npc
|
|
||||||
elseif not mobs:feed_tame(self, clicker, 8, true, true) then
|
|
||||||
-- right clicking with gold lump drops random item from mobs.npc_drops
|
|
||||||
if item:get_name() == "default:gold_lump" then
|
|
||||||
if not minetest.setting_getbool("creative_mode") then
|
|
||||||
item:take_item()
|
|
||||||
clicker:set_wielded_item(item)
|
|
||||||
end
|
|
||||||
|
|
||||||
local pos = self.object:getpos()
|
|
||||||
pos.y = pos.y + 0.5
|
|
||||||
minetest.add_item(pos, {
|
|
||||||
name = mobs.npc_drops[math.random(1, #mobs.npc_drops)]
|
|
||||||
})
|
|
||||||
return
|
|
||||||
-- if owner switch between follow and stand
|
|
||||||
elseif self.owner and self.owner == clicker:get_player_name() then
|
|
||||||
if self.order == "follow" then
|
|
||||||
self.order = "stand"
|
|
||||||
else
|
|
||||||
self.order = "follow"
|
|
||||||
end
|
|
||||||
end
|
|
||||||
mobs:capture_mob(self, clicker, 0, 5, 80, false, nil)
|
|
||||||
end
|
|
||||||
|
|
||||||
end,
|
|
||||||
})
|
|
||||||
|
|
||||||
-- spawning enable for now
|
|
||||||
--mobs:spawn_specific("pmobs:npc_female", {"default:dirt_with_grass"}, {"air"}, -1, 20, 30, 500000, 1, -31000, 31000, true, true)
|
|
||||||
mobs:register_spawn("pmobs:npc_female", {"default:dirt_with_grass"}, 20, 0, 500000, 1, 31000)
|
|
||||||
|
|
||||||
-- register spawn egg
|
|
||||||
mobs:register_egg("pmobs:npc_female", "Npc", "mobs_npc_female_inv.png", 1)
|
|
||||||
|
|
||||||
mobs:alias_mob("mobs:npc_female", "pmobs:npc_female")
|
|
125
npc_nurse.lua
Normal file
@ -0,0 +1,125 @@
|
|||||||
|
|
||||||
|
-- Npc by TenPlus1
|
||||||
|
|
||||||
|
mobs.npc_drops = { "default:pick_steel", "mobs:meat", "default:sword_steel", "default:shovel_steel", "farming:bread", "bucket:bucket_water" }
|
||||||
|
|
||||||
|
mobs:register_mob("pmobs:npc_nurse", {
|
||||||
|
-- animal, monster, npc
|
||||||
|
type = "npc",
|
||||||
|
-- aggressive, deals 2 damage to player/monster when hit
|
||||||
|
passive = false,
|
||||||
|
damage = 2,
|
||||||
|
attack_type = "dogfight",
|
||||||
|
attacks_monsters = false,
|
||||||
|
-- health & armor
|
||||||
|
hp_min = 10, hp_max = 20, armor = 100,
|
||||||
|
-- textures and model
|
||||||
|
collisionbox = {-0.35,-1.0,-0.35, 0.35,0.8,0.35},
|
||||||
|
visual = "mesh",
|
||||||
|
mesh = "character.b3d",
|
||||||
|
floats = {x=0,y=0,z=0},
|
||||||
|
drawtype = "front",
|
||||||
|
owner = "",
|
||||||
|
order = "follow",
|
||||||
|
textures = {
|
||||||
|
{"mobs_npc_nurse.png"},
|
||||||
|
},
|
||||||
|
visual_size = {x=1, y=1},
|
||||||
|
-- sounds
|
||||||
|
makes_footstep_sound = true,
|
||||||
|
sounds = {},
|
||||||
|
-- speed and jump
|
||||||
|
walk_velocity = 4,
|
||||||
|
run_velocity = 4,
|
||||||
|
jump = true,
|
||||||
|
stepheight = 1.1,
|
||||||
|
-- drops wood and chance of apples when dead
|
||||||
|
drops = {
|
||||||
|
{name = "default:wood",
|
||||||
|
chance = 1, min = 1, max = 3},
|
||||||
|
{name = "default:apple",
|
||||||
|
chance = 2, min = 1, max = 2},
|
||||||
|
{name = "default:axe_stone",
|
||||||
|
chance = 3, min = 1, max = 1},
|
||||||
|
},
|
||||||
|
-- damaged by
|
||||||
|
water_damage = 0,
|
||||||
|
lava_damage = 2,
|
||||||
|
light_damage = 0,
|
||||||
|
|
||||||
|
view_range = 15,
|
||||||
|
-- model animation
|
||||||
|
animation = {
|
||||||
|
speed_normal = 30, speed_run = 30,
|
||||||
|
stand_start = 0, stand_end = 79,
|
||||||
|
walk_start = 168, walk_end = 187,
|
||||||
|
run_start = 168, run_end = 187,
|
||||||
|
punch_start = 200, punch_end = 219,
|
||||||
|
},
|
||||||
|
-- right clicking with cooked meat will give npc more health
|
||||||
|
on_rightclick = function(self, clicker)
|
||||||
|
local item = clicker:get_wielded_item()
|
||||||
|
if item:get_name() == "mobs:meat" or item:get_name() == "farming:bread" then
|
||||||
|
local hp = self.object:get_hp()
|
||||||
|
if hp + 4 > self.hp_max then return end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
item:take_item()
|
||||||
|
clicker:set_wielded_item(item)
|
||||||
|
end
|
||||||
|
self.object:set_hp(hp+4)
|
||||||
|
|
||||||
|
|
||||||
|
-- right clicking with gold lump drops random item from mobs.npc_drops
|
||||||
|
elseif item:get_name() == "default:gold_lump" then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
item:take_item()
|
||||||
|
clicker:set_wielded_item(item)
|
||||||
|
end
|
||||||
|
local pos = self.object:getpos()
|
||||||
|
pos.y = pos.y + 0.5
|
||||||
|
minetest.add_item(pos, {name = mobs.npc_drops[math.random(1,#mobs.npc_drops)]})
|
||||||
|
else
|
||||||
|
if self.owner == "" then
|
||||||
|
self.owner = clicker:get_player_name()
|
||||||
|
else
|
||||||
|
local formspec = "size[8,4]"
|
||||||
|
formspec = formspec .. "textlist[2.85,0;2.1,0.5;dialog;What can I do for you?]"
|
||||||
|
formspec = formspec .. "button_exit[1,1;2,2;nfollow;follow]"
|
||||||
|
formspec = formspec .. "button_exit[5,1;2,2;nstand;stand]"
|
||||||
|
formspec = formspec .. "button_exit[3,1;2,2;nheal;heal]"
|
||||||
|
formspec = formspec .. "button_exit[1,2;2,2;ngohome; go home]"
|
||||||
|
formspec = formspec .. "button_exit[5,2;2,2;nsethome; sethome]"
|
||||||
|
minetest.show_formspec(clicker:get_player_name(), "order", formspec)
|
||||||
|
minetest.register_on_player_receive_fields(function(clicker, formname, fields)
|
||||||
|
if fields.nfollow then
|
||||||
|
self.order = "follow"
|
||||||
|
self.attacks_monsters = false
|
||||||
|
end
|
||||||
|
if fields.nstand then
|
||||||
|
self.order = "stand"
|
||||||
|
self.attacks_monsters = false
|
||||||
|
end
|
||||||
|
if fields.nheal then
|
||||||
|
clicker:set_hp(20)
|
||||||
|
end
|
||||||
|
if fields.nsethome then
|
||||||
|
self.floats = self.object:getpos()
|
||||||
|
end
|
||||||
|
if fields.ngohome then
|
||||||
|
if self.floats then
|
||||||
|
self.order = "stand"
|
||||||
|
self.object:setpos(self.floats)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end)
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
-- register spawn egg
|
||||||
|
mobs:register_egg("pmobs:npc_nurse", "Npc", "default_brick.png", 1)
|
||||||
|
|
||||||
|
|
94
npc_women.lua
Normal file
@ -0,0 +1,94 @@
|
|||||||
|
|
||||||
|
-- Npc by TenPlus1
|
||||||
|
|
||||||
|
mobs.npc_drops = { "default:pick_steel", "mobs:meat", "default:sword_steel", "default:shovel_steel", "farming:bread", "bucket:bucket_water" }
|
||||||
|
|
||||||
|
mobs:register_mob("pmobs:npc_women", {
|
||||||
|
-- animal, monster, npc
|
||||||
|
type = "npc",
|
||||||
|
-- aggressive, deals 2 damage to player/monster when hit
|
||||||
|
passive = false,
|
||||||
|
damage = 2,
|
||||||
|
attack_type = "dogfight",
|
||||||
|
attacks_monsters = false,
|
||||||
|
-- health & armor
|
||||||
|
hp_min = 10, hp_max = 20, armor = 100,
|
||||||
|
-- textures and model
|
||||||
|
collisionbox = {-0.35,-1.0,-0.35, 0.35,0.8,0.35},
|
||||||
|
visual = "mesh",
|
||||||
|
mesh = "character.b3d",
|
||||||
|
drawtype = "front",
|
||||||
|
textures = {
|
||||||
|
{"mobs_npc_women.png"},
|
||||||
|
},
|
||||||
|
visual_size = {x=1, y=1},
|
||||||
|
-- sounds
|
||||||
|
makes_footstep_sound = true,
|
||||||
|
sounds = {},
|
||||||
|
-- speed and jump
|
||||||
|
walk_velocity = 3,
|
||||||
|
run_velocity = 3,
|
||||||
|
jump = true,
|
||||||
|
-- drops wood and chance of apples when dead
|
||||||
|
drops = {
|
||||||
|
{name = "default:wood",
|
||||||
|
chance = 1, min = 1, max = 3},
|
||||||
|
{name = "default:apple",
|
||||||
|
chance = 2, min = 1, max = 2},
|
||||||
|
{name = "default:axe_stone",
|
||||||
|
chance = 3, min = 1, max = 1},
|
||||||
|
},
|
||||||
|
-- damaged by
|
||||||
|
water_damage = 0,
|
||||||
|
lava_damage = 2,
|
||||||
|
light_damage = 0,
|
||||||
|
|
||||||
|
view_range = 15,
|
||||||
|
-- model animation
|
||||||
|
animation = {
|
||||||
|
speed_normal = 30, speed_run = 30,
|
||||||
|
stand_start = 0, stand_end = 79,
|
||||||
|
walk_start = 168, walk_end = 187,
|
||||||
|
run_start = 168, run_end = 187,
|
||||||
|
punch_start = 200, punch_end = 219,
|
||||||
|
},
|
||||||
|
-- right clicking with cooked meat will give npc more health
|
||||||
|
on_rightclick = function(self, clicker)
|
||||||
|
local item = clicker:get_wielded_item()
|
||||||
|
local guard
|
||||||
|
local ent
|
||||||
|
if item:get_name() == "default:diamond" then
|
||||||
|
guard = minetest.add_entity(self.object:getpos(), "pmobs:npc_nurse")
|
||||||
|
ent = guard:get_luaentity()
|
||||||
|
ent.owner = clicker:get_player_name()
|
||||||
|
self.object:remove()
|
||||||
|
clicker:get_inventory():remove_item("main", "default:diamond")
|
||||||
|
elseif item:get_name() == "mobs:meat" or item:get_name() == "farming:bread" then
|
||||||
|
local hp = self.object:get_hp()
|
||||||
|
if hp + 4 > self.hp_max then return end
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
item:take_item()
|
||||||
|
clicker:set_wielded_item(item)
|
||||||
|
end
|
||||||
|
self.object:set_hp(hp+4)
|
||||||
|
|
||||||
|
|
||||||
|
-- right clicking with gold lump drops random item from mobs.npc_drops
|
||||||
|
elseif item:get_name() == "default:gold_lump" then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
item:take_item()
|
||||||
|
clicker:set_wielded_item(item)
|
||||||
|
end
|
||||||
|
local pos = self.object:getpos()
|
||||||
|
pos.y = pos.y + 0.5
|
||||||
|
minetest.add_item(pos, {name = mobs.npc_drops[math.random(1,#mobs.npc_drops)]})
|
||||||
|
|
||||||
|
end
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
mobs:register_spawn("pmobs:npc_women", {"default:dirt_with_grass"}, 20, 0, 15000, 1, 31000)
|
||||||
|
|
||||||
|
-- register spawn egg
|
||||||
|
mobs:register_egg("pmobs:npc_women", "Npc", "default_brick.png", 1)
|
||||||
|
|
BIN
sounds/throwing_sound.ogg
Normal file
4
textures/.directory
Normal file
@ -0,0 +1,4 @@
|
|||||||
|
[Dolphin]
|
||||||
|
PreviewsShown=true
|
||||||
|
Timestamp=2015,7,18,22,17,28
|
||||||
|
Version=3
|
Before Width: | Height: | Size: 643 B |
Before Width: | Height: | Size: 998 B |
Before Width: | Height: | Size: 1.7 KiB |
BIN
textures/mobs_npc_nurse.png
Normal file
After Width: | Height: | Size: 746 B |
BIN
textures/mobs_npc_women.png
Normal file
After Width: | Height: | Size: 1018 B |
BIN
textures/pmobs_arrow.png
Normal file
After Width: | Height: | Size: 213 B |
BIN
textures/pmobs_arrow_2.png
Normal file
After Width: | Height: | Size: 208 B |
BIN
textures/pmobs_arrow_back.png
Normal file
After Width: | Height: | Size: 228 B |
BIN
textures/pmobs_arrow_fire.png
Normal file
After Width: | Height: | Size: 266 B |
BIN
textures/pmobs_arrow_fire_2.png
Normal file
After Width: | Height: | Size: 266 B |
BIN
textures/pmobs_arrow_fire_back.png
Normal file
After Width: | Height: | Size: 268 B |
BIN
textures/pmobs_arrow_fire_front.png
Normal file
After Width: | Height: | Size: 306 B |
BIN
textures/pmobs_arrow_front.png
Normal file
After Width: | Height: | Size: 190 B |
BIN
textures/pmobs_bow.png
Normal file
After Width: | Height: | Size: 623 B |
BIN
textures/pmobs_bow_steel.png
Normal file
After Width: | Height: | Size: 623 B |
BIN
textures/pmobs_bow_stone.png
Normal file
After Width: | Height: | Size: 622 B |
BIN
textures/pmobs_bow_wood.png
Normal file
After Width: | Height: | Size: 621 B |
BIN
textures/pmobs_empty.png
Normal file
After Width: | Height: | Size: 178 B |
101
throwing.lua
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
arrows = {
|
||||||
|
{"pmobs:arrow", "pmobs:arrow_entity"},
|
||||||
|
{"pmobs:arrow_fire", "pmobs:arrow_fire_entity"},
|
||||||
|
}
|
||||||
|
|
||||||
|
local pmobs_shoot_arrow = function(itemstack, player)
|
||||||
|
for _,arrow in ipairs(arrows) do
|
||||||
|
if player:get_inventory():get_stack("main", player:get_wield_index()+1):get_name() == arrow[1] then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
player:get_inventory():remove_item("main", arrow[1])
|
||||||
|
end
|
||||||
|
local playerpos = player:getpos()
|
||||||
|
local obj = minetest.env:add_entity({x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}, arrow[2])
|
||||||
|
local dir = player:get_look_dir()
|
||||||
|
obj:setvelocity({x=dir.x*19, y=dir.y*19, z=dir.z*19})
|
||||||
|
obj:setacceleration({x=dir.x*-3, y=-10, z=dir.z*-3})
|
||||||
|
obj:setyaw(player:get_look_yaw()+math.pi)
|
||||||
|
minetest.sound_play("throwing_sound", {pos=playerpos})
|
||||||
|
if obj:get_luaentity().player == "" then
|
||||||
|
obj:get_luaentity().player = player
|
||||||
|
end
|
||||||
|
obj:get_luaentity().node = player:get_inventory():get_stack("main", 1):get_name()
|
||||||
|
return true
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_tool("pmobs:bow_wood", {
|
||||||
|
description = "Wood Bow",
|
||||||
|
inventory_image = "pmobs_bow_wood.png",
|
||||||
|
stack_max = 1,
|
||||||
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
|
if pmobs_shoot_arrow(itemstack, user, pointed_thing) then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
itemstack:add_wear(65535/50)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'pmobs:bow_wood',
|
||||||
|
recipe = {
|
||||||
|
{'farming:string', 'default:wood', ''},
|
||||||
|
{'farming:string', '', 'default:wood'},
|
||||||
|
{'farming:string', 'default:wood', ''},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_tool("pmobs:bow_stone", {
|
||||||
|
description = "Stone Bow",
|
||||||
|
inventory_image = "pmobs_bow_stone.png",
|
||||||
|
stack_max = 1,
|
||||||
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
|
if pmobs_shoot_arrow(item, user, pointed_thing) then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
itemstack:add_wear(65535/100)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'pmobs:bow_stone',
|
||||||
|
recipe = {
|
||||||
|
{'farming:string', 'default:cobble', ''},
|
||||||
|
{'farming:string', '', 'default:cobble'},
|
||||||
|
{'farming:string', 'default:cobble', ''},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_tool("pmobs:bow_steel", {
|
||||||
|
description = "Steel Bow",
|
||||||
|
inventory_image = "pmobs_bow_steel.png",
|
||||||
|
stack_max = 1,
|
||||||
|
on_use = function(itemstack, user, pointed_thing)
|
||||||
|
if pmobs_shoot_arrow(item, user, pointed_thing) then
|
||||||
|
if not minetest.setting_getbool("creative_mode") then
|
||||||
|
itemstack:add_wear(65535/200)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
return itemstack
|
||||||
|
end,
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = 'pmobs:bow_steel',
|
||||||
|
recipe = {
|
||||||
|
{'farming:string', 'default:steel_ingot', ''},
|
||||||
|
{'farming:string', '', 'default:steel_ingot'},
|
||||||
|
{'farming:string', 'default:steel_ingot', ''},
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
|
|
||||||
|
if minetest.setting_get("log_mods") then
|
||||||
|
minetest.log("action", "pmobs loaded")
|
||||||
|
end
|
52
wolf.lua
@ -1,25 +1,9 @@
|
|||||||
|
|
||||||
-- Wolf by KrupnoPavel
|
-- Wolf by KrupnoPavel
|
||||||
|
|
||||||
local drop_coin = nil -- NALC : Drop silver coin by chance if maptools mod loaded
|
mobs:register_mob("pmobs:wolf", {
|
||||||
if minetest.get_modpath("maptools") then
|
type = "animal",
|
||||||
drop_coin = {
|
hp_max = 5,
|
||||||
name = "maptools:silver_coin",
|
|
||||||
chance = 4, min = 1, max = 1,
|
|
||||||
}
|
|
||||||
end
|
|
||||||
|
|
||||||
mobs:register_mob(
|
|
||||||
"pmobs:wolf",
|
|
||||||
{
|
|
||||||
type = "monster",
|
|
||||||
docile_by_day = true,
|
|
||||||
passive = false,
|
|
||||||
pathfinding = false,
|
|
||||||
reach = 2,
|
|
||||||
hp_min = 15,
|
|
||||||
hp_max = 20,
|
|
||||||
armor = 200,
|
|
||||||
passive = false,
|
passive = false,
|
||||||
collisionbox = {-0.4, -0.01, -0.4, 0.4, 1, 0.4},
|
collisionbox = {-0.4, -0.01, -0.4, 0.4, 1, 0.4},
|
||||||
visual = "mesh",
|
visual = "mesh",
|
||||||
@ -29,34 +13,34 @@ mobs:register_mob(
|
|||||||
},
|
},
|
||||||
makes_footstep_sound = true,
|
makes_footstep_sound = true,
|
||||||
sounds = {
|
sounds = {
|
||||||
random = "mobs_wolf",
|
|
||||||
war_cry = "mobs_wolf_attack",
|
war_cry = "mobs_wolf_attack",
|
||||||
},
|
},
|
||||||
view_range = 7,
|
view_range = 7,
|
||||||
walk_velocity = 2,
|
walk_velocity = 2,
|
||||||
run_velocity = 3,
|
run_velocity = 3,
|
||||||
stepheight = 1.1,
|
stepheight = 1.1,
|
||||||
damage = 3,
|
damage = 2,
|
||||||
|
armor = 200,
|
||||||
attack_type = "dogfight",
|
attack_type = "dogfight",
|
||||||
drops = {
|
drops = {
|
||||||
{
|
{name = "mobs:meat_raw",
|
||||||
name = "mobs:meat_raw",
|
|
||||||
chance = 1,
|
chance = 1,
|
||||||
min = 2,
|
min = 2,
|
||||||
max = 3,
|
max = 3,},
|
||||||
},
|
|
||||||
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():get_name()
|
tool = clicker:get_wielded_item()
|
||||||
if tool == "mobs:meat_raw" or
|
local dog
|
||||||
(minetest.get_modpath("zombie") and tool == "zombie:rotten_flesh") then
|
local ent
|
||||||
clicker:get_inventory():remove_item("main", tool)
|
if tool:get_name() == "mobs:meat_raw" then
|
||||||
minetest.add_entity(self.object:getpos(), "pmobs:dog")
|
clicker:get_inventory():remove_item("main", "mobs:meat_raw")
|
||||||
|
dog = minetest.add_entity(self.object:getpos(), "pmobs:dog")
|
||||||
|
ent = dog:get_luaentity()
|
||||||
|
ent.owner = clicker:get_player_name()
|
||||||
self.object:remove()
|
self.object:remove()
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
@ -75,8 +59,6 @@ mobs:register_mob(
|
|||||||
jump = true,
|
jump = true,
|
||||||
step = 0.5,
|
step = 0.5,
|
||||||
blood_texture = "mobs_blood.png",
|
blood_texture = "mobs_blood.png",
|
||||||
})
|
})
|
||||||
mobs:register_spawn("pmobs:wolf", {"default:dirt_with_grass","default:dirt","default:snow", "default:snowblock"}, 20, -1, 100000, 1, 31000)
|
mobs:register_spawn("pmobs:wolf", {"default:dirt_with_grass","default:dirt","default:snow", "default:snowblock"}, 20, 0, 15000, 5, 31000)
|
||||||
mobs:register_egg("pmobs:wolf", "Wolf", "wool_grey.png", 1)
|
mobs:register_egg("pmobs:wolf", "Wolf", "wool_grey.png", 1)
|
||||||
|
|
||||||
mobs:alias_mob("mobs:wolf", "pmobs:wolf")
|
|
||||||
|
32
yeti.lua
@ -14,8 +14,6 @@ mobs:register_mob("pmobs:yeti", {
|
|||||||
visual_size = {x=1, y=1},
|
visual_size = {x=1, y=1},
|
||||||
makes_footstep_sound = true,
|
makes_footstep_sound = true,
|
||||||
sounds = {
|
sounds = {
|
||||||
shoot_attack = "mobs_stonemonster_attack",
|
|
||||||
death = "mobs_zombie_death",
|
|
||||||
random = "mobs_stonemonster",
|
random = "mobs_stonemonster",
|
||||||
},
|
},
|
||||||
view_range = 15,
|
view_range = 15,
|
||||||
@ -23,12 +21,10 @@ mobs:register_mob("pmobs:yeti", {
|
|||||||
run_velocity = 3,
|
run_velocity = 3,
|
||||||
damage = 2,
|
damage = 2,
|
||||||
drops = {
|
drops = {
|
||||||
{name = "default:ice",
|
{name = "default:snow",
|
||||||
chance = 1,
|
chance = 1,
|
||||||
min = 1,
|
min = 1,
|
||||||
max = 3,},
|
max = 3,},
|
||||||
{name = "maptools:silver_coin",
|
|
||||||
chance = 2, min = 1, max = 1,},
|
|
||||||
},
|
},
|
||||||
armor = 100,
|
armor = 100,
|
||||||
drawtype = "front",
|
drawtype = "front",
|
||||||
@ -50,7 +46,7 @@ mobs:register_mob("pmobs:yeti", {
|
|||||||
jump = true,
|
jump = true,
|
||||||
floats = 0,
|
floats = 0,
|
||||||
})
|
})
|
||||||
mobs:register_spawn("pmobs:yeti", {"default:dirt_with_snow", "default:snowblock", "default:ice"}, 10, -1, 7000, 1, 31000)
|
mobs:register_spawn("pmobs:yeti", {"default:dirt_with_snow", "default:snowblock", "default:ice"}, 20, 0, 15000, 5, 31000)
|
||||||
|
|
||||||
mobs:register_egg("pmobs:yeti", "Yeti", "default_snow.png", 1)
|
mobs:register_egg("pmobs:yeti", "Yeti", "default_snow.png", 1)
|
||||||
|
|
||||||
@ -64,14 +60,14 @@ mobs:register_arrow("pmobs:snowball", {
|
|||||||
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)
|
}, 0)
|
||||||
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)
|
}, 0)
|
||||||
end,
|
end,
|
||||||
|
|
||||||
hit_node = function(self, pos, node)
|
hit_node = function(self, pos, node)
|
||||||
@ -79,12 +75,12 @@ mobs:register_arrow("pmobs:snowball", {
|
|||||||
})
|
})
|
||||||
|
|
||||||
-- snowball throwing item
|
-- snowball throwing item
|
||||||
if not minetest.get_modpath("snow") then
|
|
||||||
local snowball_GRAVITY=9
|
|
||||||
local snowball_VELOCITY=19
|
|
||||||
|
|
||||||
-- shoot snowball
|
local snowball_GRAVITY=9
|
||||||
local mobs_shoot_snowball=function (item, player, pointed_thing)
|
local snowball_VELOCITY=19
|
||||||
|
|
||||||
|
-- shoot snowball
|
||||||
|
local mobs_shoot_snowball=function (item, player, pointed_thing)
|
||||||
local playerpos=player:getpos()
|
local playerpos=player:getpos()
|
||||||
local obj=minetest.add_entity({x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}, "pmobs:snowball")
|
local obj=minetest.add_entity({x=playerpos.x,y=playerpos.y+1.5,z=playerpos.z}, "pmobs:snowball")
|
||||||
local dir=player:get_look_dir()
|
local dir=player:get_look_dir()
|
||||||
@ -93,10 +89,10 @@ if not minetest.get_modpath("snow") then
|
|||||||
obj:setacceleration({x=dir.x*-3, y=-snowball_GRAVITY, z=dir.z*-3})
|
obj:setacceleration({x=dir.x*-3, y=-snowball_GRAVITY, z=dir.z*-3})
|
||||||
item:take_item()
|
item:take_item()
|
||||||
return item
|
return item
|
||||||
end
|
end
|
||||||
|
|
||||||
-- override default snow to shoot snowballs
|
-- override default snow to shoot snowballs
|
||||||
minetest.override_item("default:snow", {
|
minetest.override_item("default:snow", {
|
||||||
|
|
||||||
--Disable placement prediction for snow.
|
--Disable placement prediction for snow.
|
||||||
node_placement_prediction = "",
|
node_placement_prediction = "",
|
||||||
@ -107,6 +103,4 @@ if not minetest.get_modpath("snow") then
|
|||||||
end,
|
end,
|
||||||
|
|
||||||
on_use = mobs_shoot_snowball
|
on_use = mobs_shoot_snowball
|
||||||
})
|
})
|
||||||
end
|
|
||||||
mobs:alias_mob("mobs:yeti", "pmobs:yeti")
|
|
||||||
|