updated script

This commit is contained in:
Chr1Z93 2024-06-02 02:00:38 +02:00
parent 37a1f71ecf
commit 1f75ac5012
8 changed files with 211 additions and 2344 deletions

View File

@ -17,7 +17,7 @@
},
{
"Position": {
"x": -0.865,
"x": -0.86,
"y": 0.1,
"z": -0.28
},
@ -27,7 +27,7 @@
},
{
"Position": {
"x": -1,
"x": -1.03,
"y": 0.1,
"z": -0.28
},
@ -37,7 +37,7 @@
},
{
"Position": {
"x": -1.18,
"x": -1.20,
"y": 0.1,
"z": -0.28
},
@ -47,7 +47,17 @@
},
{
"Position": {
"x": -1.36,
"x": -1.37,
"y": 0.1,
"z": -0.28
},
"Tags": [
"UniversalToken"
]
},
{
"Position": {
"x": -1.54,
"y": 0.1,
"z": -0.28
},

View File

@ -17,7 +17,7 @@
},
{
"Position": {
"x": -0.865,
"x": -0.86,
"y": 0.1,
"z": -0.28
},
@ -27,7 +27,7 @@
},
{
"Position": {
"x": -1,
"x": -1.03,
"y": 0.1,
"z": -0.28
},
@ -37,7 +37,7 @@
},
{
"Position": {
"x": -1.18,
"x": -1.20,
"y": 0.1,
"z": -0.28
},
@ -47,7 +47,17 @@
},
{
"Position": {
"x": -1.36,
"x": -1.37,
"y": 0.1,
"z": -0.28
},
"Tags": [
"UniversalToken"
]
},
{
"Position": {
"x": -1.54,
"y": 0.1,
"z": -0.28
},

View File

@ -17,7 +17,7 @@
},
{
"Position": {
"x": -0.865,
"x": -0.86,
"y": 0.1,
"z": -0.28
},
@ -27,7 +27,7 @@
},
{
"Position": {
"x": -1,
"x": -1.03,
"y": 0.1,
"z": -0.28
},
@ -37,7 +37,7 @@
},
{
"Position": {
"x": -1.18,
"x": -1.20,
"y": 0.1,
"z": -0.28
},
@ -47,7 +47,17 @@
},
{
"Position": {
"x": -1.36,
"x": -1.37,
"y": 0.1,
"z": -0.28
},
"Tags": [
"UniversalToken"
]
},
{
"Position": {
"x": -1.54,
"y": 0.1,
"z": -0.28
},

View File

@ -17,7 +17,7 @@
},
{
"Position": {
"x": -0.865,
"x": -0.86,
"y": 0.1,
"z": -0.28
},
@ -27,7 +27,7 @@
},
{
"Position": {
"x": -1,
"x": -1.03,
"y": 0.1,
"z": -0.28
},
@ -37,7 +37,7 @@
},
{
"Position": {
"x": -1.18,
"x": -1.20,
"y": 0.1,
"z": -0.28
},
@ -47,7 +47,17 @@
},
{
"Position": {
"x": -1.36,
"x": -1.37,
"y": 0.1,
"z": -0.28
},
"Tags": [
"UniversalToken"
]
},
{
"Position": {
"x": -1.54,
"y": 0.1,
"z": -0.28
},

File diff suppressed because it is too large Load Diff

View File

@ -29,9 +29,9 @@
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612020427973/0E2846A1A2FBD43301CA7639214066FC7D6DA639/"
},
{
"Name": "Border",
"Name": "Engage",
"Type": 0,
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612020428096/AE301C4B18B881FEC97AA208905520B35C906696/"
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612028466079/0F82B3F654CCC43846A2FB49D30277EA6BD6F638/"
},
{
"Name": "Evade",
@ -51,13 +51,18 @@
{
"Name": "FreeTrigger",
"Type": 0,
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612020428391/1AD72AF8D5B24171146B712109B20E27EF02F192/"
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612028469131/89E84A750CEBE4FD056DB0479465F6DF9341D8B7/"
},
{
"Name": "Investigate",
"Type": 0,
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612020428669/E96AF92A07C94429A9E2D68A63C6E489E000EE0E/"
},
{
"Name": "Move",
"Type": 0,
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612028309124/F23B2D2DDAF7B929004CB4E2ADA7524D5FCCA7D9/"
},
{
"Name": "Parley",
"Type": 0,
@ -88,6 +93,11 @@
"Type": 0,
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612020429879/3DE13BD6A88637B0D114B38A18F3F997AA553820/"
},
{
"Name": "Ring",
"Type": 0,
"URL": "http://cloud-3.steamusercontent.com/ugc/2447222612028155966/8A83450BA18BC7E000474C065EFB6E6BB2AE081F/"
},
{
"Name": "GuardianClass",
"Type": 0,
@ -165,7 +175,7 @@
"MeasureMovement": false,
"Memo": "universalActionAbility",
"Name": "Custom_Tile",
"Nickname": "Universal Action Ability Token",
"Nickname": "Universal Action / Ability Token",
"Snap": true,
"Sticky": true,
"Tags": [
@ -178,7 +188,7 @@
"posZ": 7.323,
"rotX": 0,
"rotY": 270,
"rotZ": 180,
"rotZ": 0,
"scaleX": 0.45,
"scaleY": 1,
"scaleZ": 0.45

View File

@ -11,11 +11,13 @@ local listOfClasses = {
local listOfSymbols = {
"Activate",
"Engage",
"Evade",
"Explore",
"Fight",
"FreeTrigger",
"Investigate",
"Move",
"Parley",
"PlayItem",
"Reaction",
@ -30,6 +32,14 @@ local listOfSymbols = {
"Survivor"
}
local colorsForClasses = {
Guardian = Color.new(19 / 255, 84 / 255, 165 / 255),
Mystic = Color.new(82 / 255, 18 / 255, 97 / 255),
Neutral = Color.new(108 / 255, 110 / 255, 112 / 255),
Rogue = Color.new(17 / 255, 72 / 255, 54 / 255),
Seeker = Color.new(228 / 255, 148 / 255, 74 / 255),
Survivor = Color.new(190 / 255, 30 / 255, 45 / 255)
}
function onSave()
return JSON.encode({ class = class, symbol = symbol })
@ -42,6 +52,7 @@ function onLoad(savedData)
updateDisplay()
addContextMenu()
math.randomseed(os.time())
end
function updateDisplay()
@ -52,21 +63,23 @@ function updateDisplay()
attributes = {
id = "ClassFront",
image = class .. "Class",
height = "200",
width = "200",
position = "0 0 0.1",
rotation = "0 180 180"
height = "2000",
width = "2000",
scale = "0.1 0.1 1",
position = "0 0 -10.1",
rotation = "0 0 180"
}
},
-- circular border on the front
-- ring on the front
{
tag = "Image",
attributes = {
image = "Border",
height = "200",
width = "200",
position = "0 0 0.2",
rotation = "0 180 180"
image = "Ring",
height = "2000",
width = "2000",
scale = "0.1 0.1 1",
position = "0 0 -10.2",
rotation = "0 0 180"
}
},
-- symbol on the front
@ -75,10 +88,11 @@ function updateDisplay()
attributes = {
id = "SymbolFront",
image = symbol,
height = "200",
width = "200",
position = "0 0 0.3",
rotation = "0 180 180"
height = "2000",
width = "2000",
scale = "0.1 0.1 1",
position = "0 0 -10.3",
rotation = "0 0 180"
}
},
-- background on the back
@ -87,23 +101,24 @@ function updateDisplay()
attributes = {
id = "ClassBack",
image = "NeutralClass",
height = "200",
width = "200",
position = "0 0 -10.1",
rotation = "0 0 180"
height = "2000",
width = "2000",
scale = "0.1 0.1 1",
position = "0 0 0.1",
rotation = "0 180 180"
}
},
-- circular border on the back
-- ring on the back
{
tag = "Image",
attributes = {
image = "Border",
-- update color on the back for neutral
color = (class == "Neutral") and "#000000" or "#FFFFFF",
height = "200",
width = "200",
position = "0 0 -10.2",
rotation = "0 0 180"
image = "Ring",
color = "#000000",
height = "2000",
width = "2000",
scale = "0.1 0.1 1",
position = "0 0 0.2",
rotation = "0 180 180"
}
},
-- symbol on the back
@ -112,17 +127,53 @@ function updateDisplay()
attributes = {
id = "SymbolBack",
image = symbol,
-- update color on the back for neutral
color = (class == "Neutral") and "#000000" or "#FFFFFF",
height = "200",
width = "200",
position = "0 0 -10.3",
rotation = "0 0 180"
color = "#000000",
height = "2000",
width = "2000",
scale = "0.1 0.1 1",
position = "0 0 0.3",
rotation = "0 180 180"
}
}
}
-- handling for double symbols
if string.contains(symbol, "/") then
local symbols = {}
for str in string.gmatch(symbol, "([^/]+)") do
table.insert(symbols, str)
end
-- update front image
xml[3].attributes.image = symbols[1]
xml[3].attributes.height = xml[3].attributes.height / 2
xml[3].attributes.width = xml[3].attributes.width / 2
xml[3].attributes.position = "35 0 -10.3"
-- add 2nd image element to front
local frontSymbolXml = deepcopy(xml[3])
frontSymbolXml.attributes.image = symbols[2]
frontSymbolXml.attributes.position = "-35 0 -10.3"
table.insert(xml, frontSymbolXml)
-- update back image
xml[6].attributes.image = symbols[1]
xml[6].attributes.height = xml[6].attributes.height / 2
xml[6].attributes.width = xml[6].attributes.width / 2
xml[6].attributes.position = "35 0 0.3"
-- add 2nd image element to back
local backSymbolXml = deepcopy(xml[6])
backSymbolXml.attributes.image = symbols[2]
backSymbolXml.attributes.position = "-35 0 0.3"
table.insert(xml, backSymbolXml)
end
self.UI.setXmlTable(xml)
-- set color tint
self.setColorTint(colorsForClasses[class])
-- update name (only show symbol name if it isn't the class name)
if isClassName(symbol) then
self.setName(class)
@ -143,12 +194,33 @@ function addContextMenu()
Player[playerColor].showOptionsDialog("Choose class", listOfClasses, class, updateClass)
end)
-- get display symbol from potential list
local symbols = {}
for str in string.gmatch(symbol, "([^/]+)") do
table.insert(symbols, str)
end
self.addContextMenuItem("Change symbol", function(playerColor)
Player[playerColor].showOptionsDialog("Choose symbol", listOfSymbols, symbol, updateSymbol)
Player[playerColor].showOptionsDialog("Choose symbol", listOfSymbols, symbols[1], updateSymbol)
end)
self.addContextMenuItem("Add 2nd symbol", function(playerColor)
if string.contains(symbol, "/") then
broadcastToColor("Two symbols is the maximum!", playerColor, "Orange")
else
Player[playerColor].showOptionsDialog("Choose 2nd symbol", listOfSymbols, symbol, function(additionalSymbol)
symbol = symbol .. "/" .. additionalSymbol
updateDisplay()
end)
end
end)
end
function updateClass(newClass)
-- also update the symbol if it matches the class
if class == symbol then
symbol = newClass or "Neutral"
end
class = newClass or "Neutral"
updateDisplay()
end
@ -172,3 +244,28 @@ function isClassName(str)
end
return false
end
function onRandomize()
local newSymbol = listOfSymbols[math.random(1, #listOfSymbols)]
-- if the new symbol is a class symbol, don't get a random class
if isClassName(newSymbol) then
updateClassAndSymbol({ class = newSymbol, symbol = newSymbol })
else
updateClassAndSymbol({ class = listOfClasses[math.random(1, #listOfClasses)], symbol = newSymbol })
end
end
function deepcopy(orig)
local copy
if type(orig) == 'table' then
copy = {}
for orig_key, orig_value in next, orig, nil do
copy[deepcopy(orig_key)] = deepcopy(orig_value)
end
setmetatable(copy, deepcopy(getmetatable(orig)))
else -- number, string, boolean, etc
copy = orig
end
return copy
end

View File

@ -876,7 +876,7 @@ function maybeUpdateActiveInvestigator(card)
-- spawn three regular action tokens (investigator specific one in the bottom spot)
for i = 1, 3 do
-- get position
local pos = self.positionToWorld(Vector(-1.54 + i * 0.18, 0, -0.28)):setAt("y", 0.1)
local pos = self.positionToWorld(Vector(-1.54 + i * 0.17, 0, -0.28)):add(Vector(0, 0.2, 0))
tokenManager.spawnToken(pos, "universalActionAbility", self.getRotation(), function(spawned)
spawned.call("updateClassAndSymbol", { class = class, symbol = class })
@ -888,8 +888,13 @@ function maybeUpdateActiveInvestigator(card)
-- set value to class if currently "nil"
extraToken = extraToken or class
-- get position
local pos = self.positionToWorld(Vector(-1, 0, 0.118)):setAt("y", 0.1)
-- get position (on the investigator card for abilities)
local pos
if extraToken == "FreeTrigger" or extraToken == "Reaction" then
pos = self.positionToWorld(Vector(-1, 0, 0.118)):add(Vector(0, 0.2, 0))
else
pos = self.positionToWorld(Vector(-1.54 + 4 * 0.17, 0, -0.28)):add(Vector(0, 0.2, 0))
end
tokenManager.spawnToken(pos, "universalActionAbility", self.getRotation(), function(spawned)
spawned.call("updateClassAndSymbol", { class = class, symbol = extraToken })