updated code for better functionality part 3
This commit is contained in:
parent
7122135ebc
commit
b6abd43345
@ -73,6 +73,9 @@ local RESOURCE_OPTIONS = {
|
|||||||
local handVisibility = {}
|
local handVisibility = {}
|
||||||
local blurseVisibility = {}
|
local blurseVisibility = {}
|
||||||
|
|
||||||
|
-- track cards' settings
|
||||||
|
cardSetting = {}
|
||||||
|
|
||||||
---------------------------------------------------------
|
---------------------------------------------------------
|
||||||
-- data for tokens
|
-- data for tokens
|
||||||
---------------------------------------------------------
|
---------------------------------------------------------
|
||||||
@ -206,14 +209,7 @@ function tryObjectEnterContainer(container, object)
|
|||||||
if object.hasTag("Minicard") and container.hasTag("Minicard") then
|
if object.hasTag("Minicard") and container.hasTag("Minicard") then
|
||||||
return false
|
return false
|
||||||
elseif object.getName() ~= "Atlach-Nacha" and next(object.getAttachments()) ~= nil then
|
elseif object.getName() ~= "Atlach-Nacha" and next(object.getAttachments()) ~= nil then
|
||||||
local removedTokens = object.removeAttachments()
|
handleTokenDetaching({ card = object })
|
||||||
if object.is_face_down then
|
|
||||||
for _, token in ipairs(removedTokens) do
|
|
||||||
--token.setRotation(token.getRotation() + Vector(0, 0, 180))
|
|
||||||
local sizeY = object.getBounds().size.y
|
|
||||||
token.setPosition(token.getPosition() + Vector(0, 2 * sizeY, 0))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
playAreaApi.tryObjectEnterContainer(container, object)
|
playAreaApi.tryObjectEnterContainer(container, object)
|
||||||
@ -315,7 +311,15 @@ function onPlayerAction(player, action, targets)
|
|||||||
end
|
end
|
||||||
if #pickedCards < 6 then
|
if #pickedCards < 6 then
|
||||||
for _, pickedCard in ipairs(pickedCards) do
|
for _, pickedCard in ipairs(pickedCards) do
|
||||||
local searchResult = searchLib.onObject(pickedCard, "isTileOrToken")
|
local searchResult = searchLib.onObject(pickedCard, "isTileOrToken", 0.95)
|
||||||
|
if pickedCard.is_face_down and next(searchResult) ~= nil then
|
||||||
|
cardSetting[pickedCard] = {
|
||||||
|
hideFacedown = pickedCard.hide_when_face_down,
|
||||||
|
tooltip = pickedCard.tooltip
|
||||||
|
}
|
||||||
|
pickedCard.hide_when_face_down = false
|
||||||
|
pickedCard.tooltip = false
|
||||||
|
end
|
||||||
for _, token in ipairs(searchResult) do
|
for _, token in ipairs(searchResult) do
|
||||||
if not token.locked then
|
if not token.locked then
|
||||||
pickedCard.addAttachment(token)
|
pickedCard.addAttachment(token)
|
||||||
@ -324,7 +328,7 @@ function onPlayerAction(player, action, targets)
|
|||||||
Wait.condition(
|
Wait.condition(
|
||||||
function()
|
function()
|
||||||
if pickedCard ~= nil then
|
if pickedCard ~= nil then
|
||||||
pickedCard.removeAttachments()
|
handleTokenDetaching({ card = pickedCard })
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
function()
|
function()
|
||||||
@ -2871,3 +2875,20 @@ function tableContains(thisTable, thisElement)
|
|||||||
end
|
end
|
||||||
return false
|
return false
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function handleTokenDetaching(params)
|
||||||
|
local pickedCard = params["card"]
|
||||||
|
if cardSetting[pickedCard] ~= nil then
|
||||||
|
local pickedCardSetting = cardSetting[pickedCard]
|
||||||
|
pickedCard.hide_when_face_down = pickedCardSetting["hideFacedown"]
|
||||||
|
pickedCard.tooltip = pickedCardSetting["tooltip"]
|
||||||
|
cardSetting[pickedCard] = nil
|
||||||
|
end
|
||||||
|
local removedTokens = pickedCard.removeAttachments()
|
||||||
|
for _, token in ipairs(removedTokens) do
|
||||||
|
if token.getPosition().y < pickedCard.getPosition().y then
|
||||||
|
local posY = pickedCard.getPosition().y + 0.05
|
||||||
|
token.setPosition(token.getPosition():setAt("y", posY))
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
@ -98,14 +98,7 @@ function onCollisionEnter(collisionInfo)
|
|||||||
-- reset spawned tokens and remove tokens from cards in encounter deck / discard area
|
-- reset spawned tokens and remove tokens from cards in encounter deck / discard area
|
||||||
Wait.frames(function() tokenSpawnTrackerApi.resetTokensSpawned(object) end, 1)
|
Wait.frames(function() tokenSpawnTrackerApi.resetTokensSpawned(object) end, 1)
|
||||||
if next(object.getAttachments()) ~= nil then
|
if next(object.getAttachments()) ~= nil then
|
||||||
local removedTokens = object.removeAttachments()
|
Global.call("handleTokenDetaching", { card = object })
|
||||||
if object.is_face_down then
|
|
||||||
for _, token in ipairs(removedTokens) do
|
|
||||||
--token.setRotation(token.getRotation() + Vector(0, 0, 180))
|
|
||||||
local sizeY = object.getBounds().size.y
|
|
||||||
token.setPosition(token.getPosition() + Vector(0, 2 * sizeY, 0))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
removeTokensFromObject(object)
|
removeTokensFromObject(object)
|
||||||
|
|
||||||
|
@ -1275,14 +1275,7 @@ function onCollisionEnter(collisionInfo)
|
|||||||
|
|
||||||
elseif inArea(localCardPos, DECK_DISCARD_AREA) then
|
elseif inArea(localCardPos, DECK_DISCARD_AREA) then
|
||||||
if next(object.getAttachments()) ~= nil then
|
if next(object.getAttachments()) ~= nil then
|
||||||
local removedTokens = object.removeAttachments()
|
Global.call("handleTokenDetaching", { card = object })
|
||||||
if object.is_face_down then
|
|
||||||
for _, token in ipairs(removedTokens) do
|
|
||||||
--token.setRotation(token.getRotation() + Vector(0, 0, 180))
|
|
||||||
local sizeY = object.getBounds().size.y
|
|
||||||
token.setPosition(token.getPosition() + Vector(0, 2 * sizeY, 0))
|
|
||||||
end
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
tokenSpawnTrackerApi.resetTokensSpawned(object)
|
tokenSpawnTrackerApi.resetTokensSpawned(object)
|
||||||
removeTokensFromObject(object)
|
removeTokensFromObject(object)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user