2022-12-29 15:36:02 -05:00
|
|
|
local playArea = require("core/PlayAreaApi")
|
2022-12-28 05:57:43 -05:00
|
|
|
local tokenSpawnTracker = require("core/token/TokenSpawnTrackerApi")
|
|
|
|
|
|
|
|
local ENCOUNTER_DECK_AREA = {
|
|
|
|
upperLeft = { x = 0.9, z = 0.42 },
|
|
|
|
lowerRight = { x = 0.86, z = 0.38 },
|
|
|
|
}
|
|
|
|
local ENCOUNTER_DISCARD_AREA = {
|
|
|
|
upperLeft = { x = 1.62, z = 0.42 },
|
|
|
|
lowerRight = { x = 1.58, z = 0.38 },
|
|
|
|
}
|
2022-12-15 03:29:56 -05:00
|
|
|
|
|
|
|
local currentScenario
|
|
|
|
|
|
|
|
function onLoad(saveState)
|
|
|
|
if saveState ~= nil then
|
|
|
|
local loadedState = JSON.decode(saveState) or { }
|
|
|
|
currentScenario = loadedState.currentScenario
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
function onSave()
|
|
|
|
return JSON.encode({
|
|
|
|
currentScenario = currentScenario
|
|
|
|
})
|
|
|
|
end
|
|
|
|
|
2022-12-28 05:57:43 -05:00
|
|
|
-- TTS event handler. Handles scenario name event triggering and encounter card token resets.
|
2022-12-15 03:29:56 -05:00
|
|
|
function onCollisionEnter(collisionInfo)
|
|
|
|
local object = collisionInfo.collision_object
|
|
|
|
if object.getName() == "Scenario" then
|
2022-12-15 16:08:32 -05:00
|
|
|
if currentScenario ~= object.getDescription() then
|
|
|
|
currentScenario = object.getDescription()
|
|
|
|
fireScenarioChangedEvent()
|
|
|
|
end
|
2022-12-15 03:29:56 -05:00
|
|
|
end
|
2022-12-28 05:57:43 -05:00
|
|
|
|
|
|
|
local localPos = self.positionToLocal(object.getPosition())
|
|
|
|
if inArea(localPos, ENCOUNTER_DECK_AREA) or inArea(localPos, ENCOUNTER_DISCARD_AREA) then
|
|
|
|
tokenSpawnTracker.resetTokensSpawned(object.getGUID())
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
-- Listens for cards entering the encounter deck or encounter discard, and resets the spawn state
|
|
|
|
-- for the cards when they do.
|
|
|
|
function onObjectEnterContainer(container, object)
|
|
|
|
Wait.frames(function() resetTokensIfInDeckZone(container, object) end, 1)
|
|
|
|
end
|
|
|
|
|
|
|
|
function resetTokensIfInDeckZone(container, object)
|
|
|
|
local localPos = self.positionToLocal(container.getPosition())
|
|
|
|
if inArea(localPos, ENCOUNTER_DECK_AREA) or inArea(localPos, ENCOUNTER_DISCARD_AREA) then
|
|
|
|
tokenSpawnTracker.resetTokensSpawned(object.getGUID())
|
|
|
|
end
|
2022-12-15 03:29:56 -05:00
|
|
|
end
|
|
|
|
|
|
|
|
function fireScenarioChangedEvent()
|
2023-01-01 17:10:50 -05:00
|
|
|
Global.call('titleSplash', currentScenario)
|
2022-12-29 15:36:02 -05:00
|
|
|
playArea.onScenarioChanged(currentScenario)
|
2022-12-15 03:29:56 -05:00
|
|
|
end
|
2022-12-28 05:57:43 -05:00
|
|
|
|
|
|
|
-- Simple method to check if the given point is in a specified area. Local use only,
|
|
|
|
---@param point Vector. Point to check, only x and z values are relevant
|
|
|
|
---@param bounds Table. Defined area to see if the point is within. See MAIN_PLAY_AREA for sample
|
|
|
|
-- bounds definition.
|
|
|
|
---@return Boolean. True if the point is in the area defined by bounds
|
|
|
|
function inArea(point, bounds)
|
|
|
|
return (point.x < bounds.upperLeft.x
|
|
|
|
and point.x > bounds.lowerRight.x
|
|
|
|
and point.z < bounds.upperLeft.z
|
|
|
|
and point.z > bounds.lowerRight.z)
|
|
|
|
end
|