fix usage of shiftDown
This commit is contained in:
parent
5511c57bf3
commit
eac84f583d
@ -150,7 +150,7 @@ do
|
|||||||
---@param shiftDown Number An offset for the z-value of this group of tokens
|
---@param shiftDown Number An offset for the z-value of this group of tokens
|
||||||
TokenManager.spawnTokenGroup = function(card, tokenType, tokenCount, shiftDown)
|
TokenManager.spawnTokenGroup = function(card, tokenType, tokenCount, shiftDown)
|
||||||
if tokenType == "damage" or tokenType == "horror" then
|
if tokenType == "damage" or tokenType == "horror" then
|
||||||
TokenManager.spawnCounterToken(card, tokenType, tokenCount)
|
TokenManager.spawnCounterToken(card, tokenType, tokenCount, shiftDown)
|
||||||
else
|
else
|
||||||
TokenManager.spawnMultipleTokens(card, tokenType, tokenCount, shiftDown)
|
TokenManager.spawnMultipleTokens(card, tokenType, tokenCount, shiftDown)
|
||||||
end
|
end
|
||||||
@ -162,10 +162,10 @@ do
|
|||||||
---@param tokenType String type of token to spawn, valid values are "damage" and "horror". Other
|
---@param tokenType String type of token to spawn, valid values are "damage" and "horror". Other
|
||||||
-- types should use spawnMultipleTokens()
|
-- types should use spawnMultipleTokens()
|
||||||
---@param tokenValue Number Value to set the damage/horror to
|
---@param tokenValue Number Value to set the damage/horror to
|
||||||
TokenManager.spawnCounterToken = function(card, tokenType, tokenValue)
|
TokenManager.spawnCounterToken = function(card, tokenType, tokenValue, shiftDown)
|
||||||
if tokenValue < 1 or tokenValue > 50 then return end
|
if tokenValue < 1 or tokenValue > 50 then return end
|
||||||
|
|
||||||
local pos = card.getPosition() + Vector(0, 0.2, 0)
|
local pos = card.positionToWorld(card.positionToLocal(card.getPosition()) + Vector(0, 0.2, shiftDown))
|
||||||
local rot = card.getRotation()
|
local rot = card.getRotation()
|
||||||
TokenManager.spawnToken(pos, tokenType, rot, function(spawned)
|
TokenManager.spawnToken(pos, tokenType, rot, function(spawned)
|
||||||
spawned.setState(tokenValue)
|
spawned.setState(tokenValue)
|
||||||
@ -175,18 +175,17 @@ do
|
|||||||
-- Spawns a number of tokens.
|
-- Spawns a number of tokens.
|
||||||
---@param tokenType String type of token to spawn, valid values are resource", "doom", or "clue".
|
---@param tokenType String type of token to spawn, valid values are resource", "doom", or "clue".
|
||||||
-- Other types should use spawnCounterToken()
|
-- Other types should use spawnCounterToken()
|
||||||
---@param tokenCount How many tokens to spawn. For damage or horror this value will be set to the
|
---@param tokenCount Number How many tokens to spawn
|
||||||
-- spawned state object rather than spawning multiple tokens
|
---@param shiftDown Number An offset for the z-value of this group of tokens
|
||||||
---@param shiftDown An offset for the z-value of this group of tokens
|
|
||||||
TokenManager.spawnMultipleTokens = function(card, tokenType, tokenCount, shiftDown)
|
TokenManager.spawnMultipleTokens = function(card, tokenType, tokenCount, shiftDown)
|
||||||
if tokenCount < 1 or tokenCount > 12 then
|
if tokenCount < 1 or tokenCount > 12 then
|
||||||
return
|
return
|
||||||
end
|
end
|
||||||
local offsets
|
|
||||||
|
local offsets = {}
|
||||||
if tokenType == "clue" then
|
if tokenType == "clue" then
|
||||||
offsets = internal.buildClueOffsets(card, tokenCount)
|
offsets = internal.buildClueOffsets(card, tokenCount)
|
||||||
else
|
else
|
||||||
offsets = { }
|
|
||||||
for i = 1, tokenCount do
|
for i = 1, tokenCount do
|
||||||
offsets[i] = card.positionToWorld(PLAYER_CARD_TOKEN_OFFSETS[tokenCount][i])
|
offsets[i] = card.positionToWorld(PLAYER_CARD_TOKEN_OFFSETS[tokenCount][i])
|
||||||
-- Fix the y-position for the spawn, since positionToWorld considers rotation which can
|
-- Fix the y-position for the spawn, since positionToWorld considers rotation which can
|
||||||
@ -194,7 +193,7 @@ do
|
|||||||
offsets[i].y = card.getPosition().y + 0.15
|
offsets[i].y = card.getPosition().y + 0.15
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
-- end
|
|
||||||
if shiftDown ~= nil then
|
if shiftDown ~= nil then
|
||||||
-- Copy the offsets to make sure we don't change the static values
|
-- Copy the offsets to make sure we don't change the static values
|
||||||
local baseOffsets = offsets
|
local baseOffsets = offsets
|
||||||
@ -204,8 +203,10 @@ do
|
|||||||
offsets[i][3] = offsets[i][3] + shiftDown
|
offsets[i][3] = offsets[i][3] + shiftDown
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
if offsets == nil then
|
if offsets == nil then
|
||||||
error("couldn't find offsets for " .. tokenCount .. ' tokens')
|
error("couldn't find offsets for " .. tokenCount .. ' tokens')
|
||||||
|
return
|
||||||
end
|
end
|
||||||
|
|
||||||
for i = 1, tokenCount do
|
for i = 1, tokenCount do
|
||||||
@ -219,7 +220,7 @@ do
|
|||||||
-- "resource", "doom", or "clue"
|
-- "resource", "doom", or "clue"
|
||||||
---@param rotation Vector Rotation to be used for the new token. Only the y-value will be used,
|
---@param rotation Vector Rotation to be used for the new token. Only the y-value will be used,
|
||||||
-- x and z will use the default rotation from the source bag
|
-- x and z will use the default rotation from the source bag
|
||||||
---@param callback A callback function triggered after the new token is spawned
|
---@param callback function A callback function triggered after the new token is spawned
|
||||||
TokenManager.spawnToken = function(position, tokenType, rotation, callback)
|
TokenManager.spawnToken = function(position, tokenType, rotation, callback)
|
||||||
internal.initTokenTemplates()
|
internal.initTokenTemplates()
|
||||||
if tokenTemplates[tokenType] == nil then
|
if tokenTemplates[tokenType] == nil then
|
||||||
@ -227,19 +228,12 @@ do
|
|||||||
return
|
return
|
||||||
end
|
end
|
||||||
local tokenTemplate = tokenTemplates[tokenType]
|
local tokenTemplate = tokenTemplates[tokenType]
|
||||||
|
|
||||||
-- Take ONLY the Y-value for rotation, so we don't flip the token coming out of the bag
|
-- Take ONLY the Y-value for rotation, so we don't flip the token coming out of the bag
|
||||||
local rot = Vector(tokenTemplate.Transform.rotX,
|
|
||||||
tokenTemplate.Transform.rotY,
|
|
||||||
tokenTemplate.Transform.rotZ)
|
|
||||||
if rotation ~= nil then
|
|
||||||
rot.y = rotation.y
|
|
||||||
else
|
|
||||||
rot.y = 270
|
|
||||||
end
|
|
||||||
return spawnObjectData({
|
return spawnObjectData({
|
||||||
data = tokenTemplate,
|
data = tokenTemplate,
|
||||||
position = position,
|
position = position,
|
||||||
rotation = rot,
|
rotation = Vector(tokenTemplate.Transform.rotX, rotation.y or 270, tokenTemplate.Transform.rotZ),
|
||||||
callback_function = callback
|
callback_function = callback
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user