situation handling
This commit is contained in:
@@ -4,6 +4,7 @@
|
|||||||
globals = {
|
globals = {
|
||||||
"Util",
|
"Util",
|
||||||
"Decision",
|
"Decision",
|
||||||
|
"Situation",
|
||||||
"Screen",
|
"Screen",
|
||||||
"UI",
|
"UI",
|
||||||
"Print",
|
"Print",
|
||||||
|
|||||||
@@ -5,7 +5,10 @@ init/init.minigames.lua
|
|||||||
init/init.meters.lua
|
init/init.meters.lua
|
||||||
system/system.util.lua
|
system/system.util.lua
|
||||||
init/init.windows.lua
|
init/init.windows.lua
|
||||||
|
situation/situation.manager.lua
|
||||||
|
situation/situation.drink_coffee.lua
|
||||||
decision/decision.manager.lua
|
decision/decision.manager.lua
|
||||||
|
decision/decision.have_a_coffee.lua
|
||||||
decision/decision.go_to_home.lua
|
decision/decision.go_to_home.lua
|
||||||
decision/decision.go_to_toilet.lua
|
decision/decision.go_to_toilet.lua
|
||||||
decision/decision.go_to_walking_to_office.lua
|
decision/decision.go_to_walking_to_office.lua
|
||||||
|
|||||||
8
inc/decision/decision.have_a_coffee.lua
Normal file
8
inc/decision/decision.have_a_coffee.lua
Normal file
@@ -0,0 +1,8 @@
|
|||||||
|
Decision.register({
|
||||||
|
id = "have_a_coffee",
|
||||||
|
label = "Have a Coffee",
|
||||||
|
handle = function()
|
||||||
|
Situation.apply("drink_coffee")
|
||||||
|
end,
|
||||||
|
condition = function() return true end
|
||||||
|
})
|
||||||
@@ -12,6 +12,7 @@ Util = {}
|
|||||||
Meters = {}
|
Meters = {}
|
||||||
Minigames = {}
|
Minigames = {}
|
||||||
Decision = {}
|
Decision = {}
|
||||||
|
Situation = {}
|
||||||
Screen = {}
|
Screen = {}
|
||||||
Map = {}
|
Map = {}
|
||||||
UI = {}
|
UI = {}
|
||||||
|
|||||||
@@ -1,17 +1,12 @@
|
|||||||
local _screens = {}
|
local _screens = {}
|
||||||
|
|
||||||
function Screen.get_screens_array()
|
|
||||||
local screens_array = {}
|
|
||||||
for _, screen_data in pairs(_screens) do
|
|
||||||
table.insert(screens_array, screen_data)
|
|
||||||
end
|
|
||||||
return screens_array
|
|
||||||
end
|
|
||||||
|
|
||||||
function Screen.register(screen_data)
|
function Screen.register(screen_data)
|
||||||
if _screens[screen_data.id] then
|
if _screens[screen_data.id] then
|
||||||
trace("Warning: Overwriting screen with id: " .. screen_data.id)
|
trace("Warning: Overwriting screen with id: " .. screen_data.id)
|
||||||
end
|
end
|
||||||
|
if not screen_data.situations then
|
||||||
|
screen_data.situations = {}
|
||||||
|
end
|
||||||
_screens[screen_data.id] = screen_data
|
_screens[screen_data.id] = screen_data
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -6,5 +6,9 @@ Screen.register({
|
|||||||
"play_rhythm",
|
"play_rhythm",
|
||||||
"play_ddr",
|
"play_ddr",
|
||||||
"go_to_walking_to_home",
|
"go_to_walking_to_home",
|
||||||
}
|
"have_a_coffee",
|
||||||
|
},
|
||||||
|
situations = {
|
||||||
|
"drink_coffee",
|
||||||
|
},
|
||||||
})
|
})
|
||||||
|
|||||||
6
inc/situation/situation.drink_coffee.lua
Normal file
6
inc/situation/situation.drink_coffee.lua
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
Situation.register({
|
||||||
|
id = "drink_coffee",
|
||||||
|
handle = function()
|
||||||
|
Audio.sfx_select()
|
||||||
|
end,
|
||||||
|
})
|
||||||
36
inc/situation/situation.manager.lua
Normal file
36
inc/situation/situation.manager.lua
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
local _situations = {}
|
||||||
|
|
||||||
|
function Situation.register(situation)
|
||||||
|
if not situation or not situation.id then
|
||||||
|
PopupWindow.show({"Error: Invalid situation object registered (missing id)!"})
|
||||||
|
return
|
||||||
|
end
|
||||||
|
if not situation.handle then
|
||||||
|
situation.handle = function() end
|
||||||
|
end
|
||||||
|
if _situations[situation.id] then
|
||||||
|
trace("Warning: Overwriting situation with id: " .. situation.id)
|
||||||
|
end
|
||||||
|
_situations[situation.id] = situation
|
||||||
|
end
|
||||||
|
|
||||||
|
function Situation.get(id)
|
||||||
|
return _situations[id]
|
||||||
|
end
|
||||||
|
|
||||||
|
function Situation.apply(id)
|
||||||
|
local situation = Situation.get(id)
|
||||||
|
if not situation then
|
||||||
|
trace("Error: No situation found with id: " .. id)
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
local current_screen_obj = Screen.get_by_id(Context.current_screen)
|
||||||
|
if current_screen_obj and not current_screen_obj.situations[id] then
|
||||||
|
trace("Info: Situation " .. id .. " cannot be applied to current screen (id: " .. Context.current_screen .. ").")
|
||||||
|
return
|
||||||
|
end
|
||||||
|
|
||||||
|
situation.handle()
|
||||||
|
end
|
||||||
|
|
||||||
Reference in New Issue
Block a user