Farmer: Add other schedule entries for commonplace tasks.
Priest: Fixed missing dialogue issue. Miner: Fixed indentation.
This commit is contained in:
parent
175d07476d
commit
cf77ab5299
@ -8,7 +8,6 @@
|
||||
-- afternoon.
|
||||
|
||||
local farming_plants = {
|
||||
cotton = {
|
||||
"farming:cotton_1",
|
||||
"farming:cotton_2",
|
||||
"farming:cotton_3",
|
||||
@ -16,8 +15,15 @@ local farming_plants = {
|
||||
"farming:cotton_5",
|
||||
"farming:cotton_6",
|
||||
"farming:cotton_7",
|
||||
"farming:cotton_8"
|
||||
}
|
||||
"farming:cotton_8",
|
||||
"farming:wheat_1",
|
||||
"farming:wheat_2",
|
||||
"farming:wheat_3",
|
||||
"farming:wheat_4",
|
||||
"farming:wheat_5",
|
||||
"farming:wheat_6",
|
||||
"farming:wheat_7",
|
||||
"farming:wheat_8"
|
||||
}
|
||||
|
||||
local farmer_def = {
|
||||
@ -29,9 +35,28 @@ local farmer_def = {
|
||||
surrounding_building_types = {
|
||||
{type="field", origin_building_types={"hut", "house", "lumberjack"}}
|
||||
},
|
||||
walkable_nodes = farming_plants.cotton,
|
||||
walkable_nodes = farming_plants,
|
||||
initial_inventory = {},
|
||||
schedules_entries = {
|
||||
[6] = {
|
||||
-- Get out of bed
|
||||
[1] = {
|
||||
task = npc.actions.cmd.USE_BED, args = {
|
||||
pos = npc.places.PLACE_TYPE.BED.PRIMARY,
|
||||
action = npc.actions.const.beds.GET_UP
|
||||
}
|
||||
},
|
||||
-- Walk to home inside
|
||||
[2] = {
|
||||
task = npc.actions.cmd.WALK_TO_POS, args = {
|
||||
end_pos = npc.places.PLACE_TYPE.OTHER.HOME_INSIDE,
|
||||
walkable = {}
|
||||
},
|
||||
chance = 75
|
||||
},
|
||||
-- Allow mobs_redo wandering
|
||||
[3] = {action = npc.actions.cmd.FREEZE, args = {freeze = false}}
|
||||
},
|
||||
[7] = {
|
||||
[1] =
|
||||
{
|
||||
@ -48,9 +73,9 @@ local farmer_def = {
|
||||
random_execution_times = true,
|
||||
min_count = 20,
|
||||
max_count = 25,
|
||||
nodes = farming_plants.cotton,
|
||||
nodes = farming_plants,
|
||||
prefer_last_acted_upon_node = true,
|
||||
walkable_nodes = farming_plants.cotton,
|
||||
walkable_nodes = farming_plants,
|
||||
actions =
|
||||
{
|
||||
-- Actions for cotton - harvest and replant
|
||||
@ -61,7 +86,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -98,7 +123,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -135,7 +160,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -172,7 +197,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -209,7 +234,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -246,7 +271,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -283,7 +308,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -320,7 +345,7 @@ local farmer_def = {
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants.cotton
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
@ -349,35 +374,42 @@ local farmer_def = {
|
||||
action = npc.actions.cmd.STAND,
|
||||
args = {}
|
||||
}
|
||||
}
|
||||
},
|
||||
[3] =
|
||||
{
|
||||
check = true,
|
||||
range = 3,
|
||||
random_execution_times = true,
|
||||
min_count = 8,
|
||||
max_count = 8,
|
||||
nodes = {"farming:wheat_8"},
|
||||
actions =
|
||||
{
|
||||
["farming:wheat_8"] =
|
||||
{
|
||||
[1] =
|
||||
{
|
||||
action = npc.actions.cmd.WALK_STEP,
|
||||
task = npc.actions.cmd.WALK_TO_POS,
|
||||
args = {
|
||||
end_pos = npc.places.PLACE_TYPE.SCHEDULE.TARGET,
|
||||
walkable = farming_plants
|
||||
}
|
||||
},
|
||||
[2] =
|
||||
{
|
||||
action = npc.actions.cmd.DIG,
|
||||
args = {
|
||||
bypass_protection = true
|
||||
}
|
||||
},
|
||||
[3] =
|
||||
{
|
||||
action = npc.actions.cmd.STAND,
|
||||
args = {}
|
||||
},
|
||||
[4] =
|
||||
{
|
||||
action = npc.actions.cmd.PLACE,
|
||||
args =
|
||||
{
|
||||
node = "farming:wheat_1"
|
||||
node = "farming:wheat_1",
|
||||
bypass_protection = true
|
||||
}
|
||||
},
|
||||
[5] =
|
||||
{
|
||||
action = npc.actions.cmd.STAND,
|
||||
args = {}
|
||||
}
|
||||
}
|
||||
},
|
||||
@ -397,9 +429,117 @@ local farmer_def = {
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
[13] = {
|
||||
-- Walk to a sittable node
|
||||
[1] = {
|
||||
task = npc.actions.cmd.WALK_TO_POS, args = {
|
||||
end_pos = {place_type=npc.places.PLACE_TYPE.SITTABLE.PRIMARY, use_access_node=true},
|
||||
walkable = {"cottages:bench"}
|
||||
},
|
||||
chance = 75
|
||||
},
|
||||
-- Sit on the node
|
||||
[2] = {
|
||||
task = npc.actions.cmd.USE_SITTABLE, args = {
|
||||
pos = npc.places.PLACE_TYPE.SITTABLE.PRIMARY,
|
||||
action = npc.actions.const.sittable.SIT
|
||||
},
|
||||
depends = {1}
|
||||
},
|
||||
-- Stay put into place
|
||||
[3] = {
|
||||
action = npc.actions.cmd.SET_INTERVAL, args = {
|
||||
freeze = true,
|
||||
interval = 35
|
||||
},
|
||||
depends = {2}
|
||||
},
|
||||
[4] = {
|
||||
action = npc.actions.cmd.SET_INTERVAL, args = {
|
||||
freeze = true,
|
||||
interval = npc.actions.default_interval
|
||||
},
|
||||
depends = {3}
|
||||
},
|
||||
-- Get up from sit
|
||||
[5] = {
|
||||
action = npc.actions.cmd.USE_SITTABLE, args = {
|
||||
pos = npc.places.PLACE_TYPE.SITTABLE.PRIMARY,
|
||||
action = npc.actions.const.sittable.GET_UP
|
||||
},
|
||||
depends = {4}
|
||||
}
|
||||
},
|
||||
[14] = {
|
||||
-- Give NPC money to buy from player
|
||||
[1] = {
|
||||
property = npc.schedule_properties.put_multiple_items, args = {
|
||||
itemlist = {
|
||||
{name="default:iron_lump", random=true, min=2, max=4}
|
||||
}
|
||||
},
|
||||
chance = 50
|
||||
},
|
||||
-- Change trader status to "trader"
|
||||
[2] = {
|
||||
property = npc.schedule_properties.trader_status, args = {
|
||||
status = npc.trade.TRADER
|
||||
},
|
||||
chance = 90
|
||||
},
|
||||
[3] = {
|
||||
property = npc.schedule_properties.can_receive_gifts, args = {
|
||||
can_receive_gifts = false
|
||||
},
|
||||
depends = {1}
|
||||
},
|
||||
-- Allow mobs_redo wandering
|
||||
[4] = {action = npc.actions.cmd.FREEZE, args = {freeze = false}}
|
||||
},
|
||||
-- Schedule entry for 6 in the evening
|
||||
[18] = {
|
||||
-- Change trader status to "none"
|
||||
[1] = {
|
||||
property = npc.schedule_properties.trader_status, args = {
|
||||
status = npc.trade.NONE
|
||||
}
|
||||
},
|
||||
-- Enable gift receiving again
|
||||
[2] = {
|
||||
property = npc.schedule_properties.can_receive_gifts, args = {
|
||||
can_receive_gifts = true
|
||||
}
|
||||
},
|
||||
-- Get inside home
|
||||
[3] = {
|
||||
task = npc.actions.cmd.WALK_TO_POS, args = {
|
||||
end_pos = npc.places.PLACE_TYPE.BED.PRIMARY,
|
||||
walkable = {}
|
||||
}
|
||||
},
|
||||
-- Allow mobs_redo wandering
|
||||
[4] = {action = npc.actions.cmd.FREEZE, args = {freeze = false}}
|
||||
},
|
||||
[22] = {
|
||||
[1] = {
|
||||
task = npc.actions.cmd.WALK_TO_POS, args = {
|
||||
end_pos = {place_type=npc.places.PLACE_TYPE.BED.PRIMARY, use_access_node=true},
|
||||
walkable = {}
|
||||
}
|
||||
},
|
||||
-- Use bed
|
||||
[2] = {
|
||||
task = npc.actions.cmd.USE_BED, args = {
|
||||
pos = npc.places.PLACE_TYPE.BED.PRIMARY,
|
||||
action = npc.actions.const.beds.LAY
|
||||
}
|
||||
},
|
||||
-- Stay put on bed
|
||||
[3] = {action = npc.actions.cmd.FREEZE, args = {freeze = true} }
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
-- Register occupation
|
||||
npc.occupations.register_occupation("farmer", farmer_def)
|
||||
npc.occupations.register_occupation("default_farmer", farmer_def)
|
||||
|
@ -1,4 +1,5 @@
|
||||
-- WIP miner by NewbProgrammer101 or roboto
|
||||
|
||||
local miner_def = {
|
||||
dialogues = {},
|
||||
textures = {"miner.png"},
|
||||
@ -21,7 +22,7 @@ local miner_def = {
|
||||
random_execution_times = true,
|
||||
min_count = 20,
|
||||
max_count = 99,
|
||||
nodes = {"default:dirt", "default:dirt_with_grass", "default:sand", "default:desert_sand", "default:silver_sand", "default:gravel", "default:clay", "default:snow", "default:snowblock", "default:},
|
||||
nodes = {"default:dirt", "default:dirt_with_grass", "default:sand", "default:desert_sand", "default:silver_sand", "default:gravel", "default:clay", "default:snow", "default:snowblock"},
|
||||
actions = {
|
||||
["default:dirt"] = {
|
||||
[1] = {
|
||||
@ -33,24 +34,7 @@ local miner_def = {
|
||||
}
|
||||
}
|
||||
},
|
||||
[3] = {
|
||||
check = true,
|
||||
range = 3,
|
||||
random_execution_times = true,
|
||||
min_count = 20,
|
||||
max_count = 99,
|
||||
nodes = {"default:stone", "default:stonebrick", "default:stone_block", "default:mossycobble", "default:desert_stone", "default:desert_cobble", "default:desert_stonebrick", "default:desert_stone_block"},
|
||||
actions = {
|
||||
["default:stone"] = {
|
||||
[1] = {
|
||||
action = npc.actions.cmd.WALK_STEP
|
||||
},
|
||||
[2] = {
|
||||
action = npc.actions.cmd.DIG
|
||||
}
|
||||
}
|
||||
}
|
||||
},
|
||||
|
||||
none_actions = {
|
||||
[1] = {
|
||||
action = npc.actions.cmd.WALK_STEP,
|
||||
@ -61,8 +45,7 @@ local miner_def = {
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
-- Occupation registration
|
||||
npc.occupations.register_occupation("miner", miner_def)
|
||||
npc.occupations.register_occupation("default_miner", miner_def)
|
||||
|
@ -13,6 +13,7 @@
|
||||
local priest_def = {
|
||||
dialogues = {
|
||||
type = "given",
|
||||
max_count = 5,
|
||||
data = {
|
||||
{
|
||||
text = "Blessings be upon you, my child!",
|
||||
@ -20,6 +21,7 @@ local priest_def = {
|
||||
},
|
||||
{
|
||||
text = "The temple will always open the doors to everyone.",
|
||||
flag = {name="on_church", value=true},
|
||||
tags = {"unisex"}
|
||||
},
|
||||
{
|
||||
@ -28,6 +30,7 @@ local priest_def = {
|
||||
},
|
||||
{
|
||||
text = "Thanks for coming to greet me, I hope you have a blessed day! ",
|
||||
flag = {name="on_church", value=false},
|
||||
tags = {"unisex"}
|
||||
},
|
||||
{
|
||||
@ -57,7 +60,7 @@ local priest_def = {
|
||||
else
|
||||
npc.chat(self.npc_name, player:get_player_name(),
|
||||
"Receive the blessings of the Creator!")
|
||||
effect(self.object:getpos(), 20, "default_coral_skeleton.png", 0.1, 0.3, 3, 10)
|
||||
npc.effect(self.object:getpos(), 20, "default_coral_skeleton.png", 0.1, 0.3, 3, 10)
|
||||
-- Heal one heart
|
||||
player:set_hp(player:get_hp() + 2)
|
||||
end
|
||||
@ -117,7 +120,8 @@ local priest_def = {
|
||||
},
|
||||
properties = {
|
||||
initial_trader_status = npc.trade.NONE,
|
||||
enable_gift_items_hints = false
|
||||
enable_gift_items_hints = false,
|
||||
can_receive_gifts = false
|
||||
},
|
||||
building_types = {},
|
||||
surrounding_building_types = {
|
||||
@ -208,4 +212,4 @@ local priest_def = {
|
||||
}
|
||||
|
||||
-- Register occupation
|
||||
npc.occupations.register_occupation("priest", priest_def)
|
||||
npc.occupations.register_occupation("default_priest", priest_def)
|
||||
|
Loading…
Reference in New Issue
Block a user