commit
6c4586704a
@ -155,10 +155,10 @@ end
|
|||||||
function endSearch(_, _, isRightClick)
|
function endSearch(_, _, isRightClick)
|
||||||
local handCards = Player[handColor].getHandObjects()
|
local handCards = Player[handColor].getHandObjects()
|
||||||
|
|
||||||
local j = 0
|
local handCount = #handCards
|
||||||
for i = #handCards, 1, -1 do
|
for i = handCount, 1, -1 do
|
||||||
j = j + 1
|
Wait.time(function() deckLib.placeOrMergeIntoDeck(handCards[i], drawDeckPosition, setAsideRotation) end,
|
||||||
Wait.time(function() deckLib.placeOrMergeIntoDeck(handCards[i], drawDeckPosition, setAsideRotation) end, j * 0.1)
|
(handCount - i + 1) * 0.1)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- draw set aside cards (from the ground!)
|
-- draw set aside cards (from the ground!)
|
||||||
|
@ -256,13 +256,11 @@ function discardListOfObjects(objList)
|
|||||||
else
|
else
|
||||||
deckLib.placeOrMergeIntoDeck(obj, ENCOUNTER_DISCARD_POSITION, { x = 0, y = -90, z = 0 })
|
deckLib.placeOrMergeIntoDeck(obj, ENCOUNTER_DISCARD_POSITION, { x = 0, y = -90, z = 0 })
|
||||||
end
|
end
|
||||||
|
|
||||||
-- put chaos tokens back into bag (e.g. Unrelenting)
|
|
||||||
elseif tokenChecker.isChaosToken(obj) then
|
elseif tokenChecker.isChaosToken(obj) then
|
||||||
|
-- put chaos tokens back into bag (e.g. Unrelenting)
|
||||||
chaosBagApi.returnChaosTokenToBag(obj)
|
chaosBagApi.returnChaosTokenToBag(obj)
|
||||||
|
|
||||||
-- don't touch locked objects (like the table etc.) or specific objects (like key tokens)
|
|
||||||
elseif not obj.getLock() and not obj.hasTag("DontDiscard") then
|
elseif not obj.getLock() and not obj.hasTag("DontDiscard") then
|
||||||
|
-- don't touch locked objects (like the table etc.) or specific objects (like key tokens)
|
||||||
ownedObjects.Trash.putObject(obj)
|
ownedObjects.Trash.putObject(obj)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
@ -390,25 +388,24 @@ function doUpkeep(_, clickedByColor, isRightClick)
|
|||||||
local cardsToDiscard = {}
|
local cardsToDiscard = {}
|
||||||
|
|
||||||
for i = 1, #handCards do
|
for i = 1, #handCards do
|
||||||
local metadata = JSON.decode(handCards[i].getGMNotes())
|
local md = JSON.decode(handCards[i].getGMNotes())
|
||||||
if metadata ~= nil and (not metadata.weakness and not metadata.hidden) then
|
if md ~= nil and (not md.weakness and not md.hidden and md.type ~= "Enemy") then
|
||||||
table.insert(cardsToDiscard, handCards[i])
|
table.insert(cardsToDiscard, handCards[i])
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
local j = 0
|
-- perform discarding 1 by 1
|
||||||
local k = 0
|
local pos = returnGlobalDiscardPosition()
|
||||||
|
local count = #cardsToDiscard
|
||||||
for i = #cardsToDiscard, 1, -1 do
|
for i = count, 1, -1 do
|
||||||
j = j + 1
|
Wait.time(function() deckLib.placeOrMergeIntoDeck(cardsToDiscard[i], pos, rot) end,
|
||||||
Wait.time(function() deckLib.placeOrMergeIntoDeck(cardsToDiscard[i], returnGlobalDiscardPosition(), self.getRotation()) end, j * 0.1)
|
(count - i + 1) * 0.1)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- add some time if there are any cards to discard, if not, draw up to 5 immediately
|
-- add some time if there are any cards to discard, if not, draw up to 5 immediately
|
||||||
if j > 0 then
|
local k = 0
|
||||||
k = 0.7 + (j * 0.1)
|
if count > 0 then
|
||||||
else
|
k = 0.5 + (count * 0.1)
|
||||||
k = 0
|
|
||||||
end
|
end
|
||||||
|
|
||||||
Wait.time(function()
|
Wait.time(function()
|
||||||
@ -577,7 +574,8 @@ function doDiscardOne()
|
|||||||
-- get a random non-hidden card (from the "choices" table)
|
-- get a random non-hidden card (from the "choices" table)
|
||||||
local num = math.random(1, #choices)
|
local num = math.random(1, #choices)
|
||||||
deckLib.placeOrMergeIntoDeck(hand[choices[num]], returnGlobalDiscardPosition(), self.getRotation())
|
deckLib.placeOrMergeIntoDeck(hand[choices[num]], returnGlobalDiscardPosition(), self.getRotation())
|
||||||
broadcastToAll(getColoredName(playerColor) .. " randomly discarded card " .. choices[num] .. "/" .. #hand .. ".", "White")
|
broadcastToAll(getColoredName(playerColor) .. " randomly discarded card "
|
||||||
|
.. choices[num] .. "/" .. #hand .. ".", "White")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
@ -39,7 +39,7 @@ do
|
|||||||
function()
|
function()
|
||||||
obj.use_hands = true
|
obj.use_hands = true
|
||||||
-- this avoids a TTS bug that merges unrelated cards that are not resting
|
-- this avoids a TTS bug that merges unrelated cards that are not resting
|
||||||
if #searchResult == 1 and searchResult[1] ~= obj then
|
if #searchResult == 1 and searchResult[1] ~= obj and searchResult[1] ~= nil then
|
||||||
-- call this with avoiding errors (physics is sometimes too fast so the object doesn't exist for the put)
|
-- call this with avoiding errors (physics is sometimes too fast so the object doesn't exist for the put)
|
||||||
pcall(function() searchResult[1].putObject(obj) end)
|
pcall(function() searchResult[1].putObject(obj) end)
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user