updated doom counters
This commit is contained in:
parent
bc01f28c29
commit
d22c4d5806
@ -34,7 +34,7 @@
|
|||||||
"LayoutGroupSortIndex": 0,
|
"LayoutGroupSortIndex": 0,
|
||||||
"Locked": true,
|
"Locked": true,
|
||||||
"LuaScript": "require(\"core/AgendaDeck\")",
|
"LuaScript": "require(\"core/AgendaDeck\")",
|
||||||
"LuaScriptState": "[true,0]",
|
"LuaScriptState": "0",
|
||||||
"MeasureMovement": false,
|
"MeasureMovement": false,
|
||||||
"Name": "Custom_Token",
|
"Name": "Custom_Token",
|
||||||
"Nickname": "Agenda Deck",
|
"Nickname": "Agenda Deck",
|
||||||
|
@ -1,132 +1,62 @@
|
|||||||
MIN_VALUE = -99
|
-- Doom Counter with Print
|
||||||
MAX_VALUE = 999
|
-- original by: -
|
||||||
|
-- changed by: Chr1Z
|
||||||
|
-- description: Clickable counter for doom on the agenda, changing the value prints the new value, reset button added
|
||||||
|
information = {
|
||||||
|
version = "1.4",
|
||||||
|
last_updated = "12.11.2022"
|
||||||
|
}
|
||||||
|
|
||||||
function onload(saved_data)
|
function onSave() return JSON.encode(val) end
|
||||||
light_mode = false
|
|
||||||
val = 0
|
|
||||||
|
|
||||||
|
function onLoad(saved_data)
|
||||||
if saved_data ~= "" then
|
if saved_data ~= "" then
|
||||||
local loaded_data = JSON.decode(saved_data)
|
val = JSON.decode(saved_data)
|
||||||
light_mode = loaded_data[1]
|
|
||||||
val = loaded_data[2]
|
|
||||||
end
|
|
||||||
|
|
||||||
createAll()
|
|
||||||
end
|
|
||||||
|
|
||||||
function updateSave()
|
|
||||||
local data_to_save = {light_mode, val}
|
|
||||||
saved_data = JSON.encode(data_to_save)
|
|
||||||
self.script_state = saved_data
|
|
||||||
end
|
|
||||||
|
|
||||||
function createAll()
|
|
||||||
s_color = {0.5, 0.5, 0.5, 95}
|
|
||||||
|
|
||||||
if light_mode then
|
|
||||||
f_color = {1,1,1,95}
|
|
||||||
else
|
else
|
||||||
f_color = {0,0,0,100}
|
val = 0
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
self.createButton({
|
self.createButton({
|
||||||
label=tostring(val),
|
label = tostring(val),
|
||||||
click_function="add_subtract",
|
click_function = "add_subtract",
|
||||||
function_owner=self,
|
function_owner = self,
|
||||||
position={0,0.05,0},
|
position = { 0, 0.06, 0 },
|
||||||
height=600,
|
height = 800,
|
||||||
width=1000,
|
width = 800,
|
||||||
alignment = 3,
|
font_size = 650,
|
||||||
scale={x=1.5, y=1.5, z=1.5},
|
scale = { 1.5, 1.5, 1.5 },
|
||||||
font_size=600,
|
font_color = { 1, 1, 1, 95 },
|
||||||
font_color=f_color,
|
color = { 0, 0, 0, 0 }
|
||||||
color={0,0,0,0}
|
})
|
||||||
})
|
|
||||||
|
|
||||||
|
self.createButton({
|
||||||
|
label = "Reset",
|
||||||
|
click_function = "setToZero",
|
||||||
|
function_owner = self,
|
||||||
|
position = { 0, -0.04, 2.7 },
|
||||||
|
height = 600,
|
||||||
|
width = 1250,
|
||||||
|
font_size = 425
|
||||||
|
})
|
||||||
|
|
||||||
|
self.addContextMenuItem("More Information", function()
|
||||||
|
printToAll("------------------------------", "White")
|
||||||
if light_mode then
|
printToAll("Doom Counter v" .. information["version"] .. " by Chr1Z", "Orange")
|
||||||
lightButtonText = "[ Set dark ]"
|
printToAll("last updated: " .. information["last_updated"], "White")
|
||||||
else
|
end)
|
||||||
lightButtonText = "[ Set light ]"
|
|
||||||
end
|
|
||||||
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function removeAll()
|
function setToZero() updateVal(0) end
|
||||||
self.removeInput(0)
|
|
||||||
self.removeInput(1)
|
|
||||||
self.removeButton(0)
|
|
||||||
self.removeButton(1)
|
|
||||||
self.removeButton(2)
|
|
||||||
end
|
|
||||||
|
|
||||||
function reloadAll()
|
|
||||||
removeAll()
|
|
||||||
createAll()
|
|
||||||
|
|
||||||
updateSave()
|
|
||||||
end
|
|
||||||
|
|
||||||
function swap_fcolor(_obj, _color, alt_click)
|
|
||||||
light_mode = not light_mode
|
|
||||||
reloadAll()
|
|
||||||
end
|
|
||||||
|
|
||||||
function swap_align(_obj, _color, alt_click)
|
|
||||||
center_mode = not center_mode
|
|
||||||
reloadAll()
|
|
||||||
end
|
|
||||||
|
|
||||||
function editName(_obj, _string, value)
|
|
||||||
self.setName(value)
|
|
||||||
setTooltips()
|
|
||||||
end
|
|
||||||
|
|
||||||
function add_subtract(_obj, _color, alt_click)
|
function add_subtract(_obj, _color, alt_click)
|
||||||
mod = alt_click and -1 or 1
|
new_value = math.min(math.max(val + (alt_click and -1 or 1), 0), 99)
|
||||||
new_value = math.min(math.max(val + mod, MIN_VALUE), MAX_VALUE)
|
if val ~= new_value then updateVal(new_value) end
|
||||||
if val ~= new_value then
|
|
||||||
val = new_value
|
|
||||||
updateVal()
|
|
||||||
updateSave()
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function updateVal()
|
function updateVal(number)
|
||||||
|
val = number or 0
|
||||||
self.editButton({
|
self.editButton({ index = 0, label = tostring(val) })
|
||||||
index = 0,
|
printToAll("Doom on agenda set to: " .. val)
|
||||||
label = tostring(val),
|
|
||||||
|
|
||||||
})
|
|
||||||
end
|
end
|
||||||
|
|
||||||
function reset_val()
|
function updateSave() end
|
||||||
val = 0
|
|
||||||
updateVal()
|
|
||||||
updateSave()
|
|
||||||
end
|
|
||||||
|
|
||||||
function setTooltips()
|
|
||||||
self.editInput({
|
|
||||||
index = 0,
|
|
||||||
value = self.getName(),
|
|
||||||
tooltip = ttText
|
|
||||||
})
|
|
||||||
self.editButton({
|
|
||||||
index = 0,
|
|
||||||
value = tostring(val),
|
|
||||||
tooltip = ttText
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
function null()
|
|
||||||
end
|
|
||||||
|
|
||||||
function keepSample(_obj, _string, value)
|
|
||||||
reloadAll()
|
|
||||||
end
|
|
||||||
|
@ -1,132 +1,105 @@
|
|||||||
MIN_VALUE = -99
|
-- Doom-in-Play Counter
|
||||||
MAX_VALUE = 999
|
-- made by: Chr1Z
|
||||||
|
-- description: counts the doom tokens in play periodically (excluding the agenda), ignores objects with specified tag
|
||||||
|
information = {
|
||||||
|
version = "1.1",
|
||||||
|
last_updated = "12.11.2022"
|
||||||
|
}
|
||||||
|
|
||||||
function onload(saved_data)
|
-- common parameters
|
||||||
light_mode = false
|
local CAST_PARAMETERS = {}
|
||||||
val = 0
|
CAST_PARAMETERS.direction = { 0, 1, 0 }
|
||||||
|
CAST_PARAMETERS.type = 3
|
||||||
if saved_data ~= "" then
|
CAST_PARAMETERS.max_distance = 0
|
||||||
local loaded_data = JSON.decode(saved_data)
|
|
||||||
light_mode = loaded_data[1]
|
|
||||||
val = loaded_data[2]
|
|
||||||
end
|
|
||||||
|
|
||||||
createAll()
|
|
||||||
end
|
|
||||||
|
|
||||||
function updateSave()
|
|
||||||
local data_to_save = {light_mode, val}
|
|
||||||
saved_data = JSON.encode(data_to_save)
|
|
||||||
self.script_state = saved_data
|
|
||||||
end
|
|
||||||
|
|
||||||
function createAll()
|
|
||||||
s_color = {0.5, 0.5, 0.5, 95}
|
|
||||||
|
|
||||||
if light_mode then
|
|
||||||
f_color = {1,1,1,95}
|
|
||||||
else
|
|
||||||
f_color = {0,0,0,100}
|
|
||||||
end
|
|
||||||
|
|
||||||
|
local ypos = 1.6
|
||||||
|
local zone = getObjectFromGUID("a2f932")
|
||||||
|
local doom_url = "https://i.imgur.com/EoL7yaZ.png"
|
||||||
|
local IGNORE_TAG = "DoomCounter_ignore"
|
||||||
|
|
||||||
|
-- playermats 1 to 4
|
||||||
|
local originAndSize = {
|
||||||
|
{ origin = { -55, ypos, 16.5 }, size = { 12, 1, 25 } },
|
||||||
|
{ origin = { -55, ypos, -16.5 }, size = { 12, 1, 25 } },
|
||||||
|
{ origin = { -25, ypos, 27 }, size = { 25, 1, 12 } },
|
||||||
|
{ origin = { -25, ypos, -27 }, size = { 25, 1, 12 } }
|
||||||
|
}
|
||||||
|
|
||||||
|
-- create button, context menu and start loop
|
||||||
|
function onLoad()
|
||||||
self.createButton({
|
self.createButton({
|
||||||
label=tostring(val),
|
label = tostring(0),
|
||||||
click_function="add_subtract",
|
click_function = "moreInformation",
|
||||||
function_owner=self,
|
function_owner = self,
|
||||||
position={0,0.05,0},
|
position = { 0, 0.06, 0 },
|
||||||
height=600,
|
height = 600,
|
||||||
width=1000,
|
width = 1000,
|
||||||
alignment = 3,
|
scale = { 1.5, 1.5, 1.5 },
|
||||||
scale={x=1.5, y=1.5, z=1.5},
|
font_size = 600,
|
||||||
font_size=600,
|
font_color = { 1, 1, 1, 100 },
|
||||||
font_color=f_color,
|
color = { 0, 0, 0, 0 }
|
||||||
color={0,0,0,0}
|
})
|
||||||
})
|
|
||||||
|
|
||||||
|
-- context menu
|
||||||
|
self.addContextMenuItem("More Information", moreInformation)
|
||||||
|
self.addContextMenuItem("Remove Doom", function()
|
||||||
|
removeDoom = true
|
||||||
|
Wait.stop(loopID)
|
||||||
|
countDoom()
|
||||||
|
Wait.time(function()
|
||||||
|
removeDoom = false
|
||||||
|
loopID = Wait.time(countDoom, 2, -1)
|
||||||
|
end, 2)
|
||||||
|
end)
|
||||||
|
|
||||||
|
loopID = Wait.time(countDoom, 2, -1)
|
||||||
|
end
|
||||||
|
|
||||||
|
function moreInformation()
|
||||||
|
printToAll("------------------------------", "White")
|
||||||
|
printToAll("Doom-in-Play Counter v" .. information["version"] .. " by Chr1Z", "Orange")
|
||||||
|
printToAll("last updated: " .. information["last_updated"], "White")
|
||||||
|
printToAll("Automatically counts the doom in play (exluding the agenda and objects with the ignore tag).", "Green")
|
||||||
|
printToAll("ignore tag: " .. IGNORE_TAG, "White")
|
||||||
|
end
|
||||||
|
|
||||||
if light_mode then
|
-- main function
|
||||||
lightButtonText = "[ Set dark ]"
|
function countDoom()
|
||||||
|
local doom = 0
|
||||||
|
for i = 1, 5 do doom = doom + search(i) end
|
||||||
|
self.editButton({ index = 0, label = tostring(doom) })
|
||||||
|
end
|
||||||
|
|
||||||
|
-- searches playermats (num = 1-4) or the scripting zone (num = 5)
|
||||||
|
function search(num)
|
||||||
|
local val = 0
|
||||||
|
if num == 5 then
|
||||||
|
for _, obj in ipairs(zone.getObjects()) do
|
||||||
|
val = val + getResult(obj)
|
||||||
|
end
|
||||||
else
|
else
|
||||||
lightButtonText = "[ Set light ]"
|
CAST_PARAMETERS.origin = originAndSize[num].origin
|
||||||
|
CAST_PARAMETERS.size = originAndSize[num].size
|
||||||
|
|
||||||
|
for _, obj in ipairs(Physics.cast(CAST_PARAMETERS)) do
|
||||||
|
val = val + getResult(obj.hit_object)
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
return val
|
||||||
end
|
end
|
||||||
|
|
||||||
function removeAll()
|
-- checks an object for the doom image and gets quantity (for stacks)
|
||||||
self.removeInput(0)
|
function getResult(obj)
|
||||||
self.removeInput(1)
|
if (obj.is_face_down and obj.getCustomObject().image_bottom == doom_url) or
|
||||||
self.removeButton(0)
|
(obj.name == "Custom_Token" and obj.getCustomObject().image == doom_url) then
|
||||||
self.removeButton(1)
|
if not obj.hasTag(IGNORE_TAG) then
|
||||||
self.removeButton(2)
|
if removeDoom then
|
||||||
end
|
obj.destruct()
|
||||||
|
return 0
|
||||||
function reloadAll()
|
else
|
||||||
removeAll()
|
return math.abs(obj.getQuantity())
|
||||||
createAll()
|
end
|
||||||
|
end
|
||||||
updateSave()
|
|
||||||
end
|
|
||||||
|
|
||||||
function swap_fcolor(_obj, _color, alt_click)
|
|
||||||
light_mode = not light_mode
|
|
||||||
reloadAll()
|
|
||||||
end
|
|
||||||
|
|
||||||
function swap_align(_obj, _color, alt_click)
|
|
||||||
center_mode = not center_mode
|
|
||||||
reloadAll()
|
|
||||||
end
|
|
||||||
|
|
||||||
function editName(_obj, _string, value)
|
|
||||||
self.setName(value)
|
|
||||||
setTooltips()
|
|
||||||
end
|
|
||||||
|
|
||||||
function add_subtract(_obj, _color, alt_click)
|
|
||||||
mod = alt_click and -1 or 1
|
|
||||||
new_value = math.min(math.max(val + mod, MIN_VALUE), MAX_VALUE)
|
|
||||||
if val ~= new_value then
|
|
||||||
val = new_value
|
|
||||||
updateVal()
|
|
||||||
updateSave()
|
|
||||||
end
|
end
|
||||||
end
|
return 0
|
||||||
|
|
||||||
function updateVal()
|
|
||||||
|
|
||||||
self.editButton({
|
|
||||||
index = 0,
|
|
||||||
label = tostring(val),
|
|
||||||
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
function reset_val()
|
|
||||||
val = 0
|
|
||||||
updateVal()
|
|
||||||
updateSave()
|
|
||||||
end
|
|
||||||
|
|
||||||
function setTooltips()
|
|
||||||
self.editInput({
|
|
||||||
index = 0,
|
|
||||||
value = self.getName(),
|
|
||||||
tooltip = ttText
|
|
||||||
})
|
|
||||||
self.editButton({
|
|
||||||
index = 0,
|
|
||||||
value = tostring(val),
|
|
||||||
tooltip = ttText
|
|
||||||
})
|
|
||||||
end
|
|
||||||
|
|
||||||
function null()
|
|
||||||
end
|
|
||||||
|
|
||||||
function keepSample(_obj, _string, value)
|
|
||||||
reloadAll()
|
|
||||||
end
|
end
|
||||||
|
Loading…
x
Reference in New Issue
Block a user