commit
49c3c170ef
@ -83,5 +83,25 @@
|
|||||||
"Name": "option_image2",
|
"Name": "option_image2",
|
||||||
"Type": 0,
|
"Type": 0,
|
||||||
"URL": "http://cloud-3.steamusercontent.com/ugc/2027213118470839572/FB133C41A6D8915A44C138BCF947ECFE3D111813/"
|
"URL": "http://cloud-3.steamusercontent.com/ugc/2027213118470839572/FB133C41A6D8915A44C138BCF947ECFE3D111813/"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Name": "SpeechBubble",
|
||||||
|
"Type": 0,
|
||||||
|
"URL": "https://i.imgur.com/6MReiEO.png"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Name": "Roland",
|
||||||
|
"Type": 0,
|
||||||
|
"URL": "https://i.imgur.com/lx6unDY.png"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Name": "NextArrow",
|
||||||
|
"Type": 0,
|
||||||
|
"URL": "https://i.imgur.com/gXRiKmu.png"
|
||||||
|
},
|
||||||
|
{
|
||||||
|
"Name": "Exit",
|
||||||
|
"Type": 0,
|
||||||
|
"URL": "https://i.imgur.com/i0VMjPD.png"
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
|
@ -7,7 +7,7 @@ tourCardTemplate = {
|
|||||||
attributes = {
|
attributes = {
|
||||||
id = "tourCard",
|
id = "tourCard",
|
||||||
height = 195,
|
height = 195,
|
||||||
width = 270,
|
width = 300,
|
||||||
rotation = "0 0 0",
|
rotation = "0 0 0",
|
||||||
position = "0 300 30",
|
position = "0 300 30",
|
||||||
showAnimation = "FadeIn",
|
showAnimation = "FadeIn",
|
||||||
@ -22,7 +22,7 @@ tourCardTemplate = {
|
|||||||
height=75,
|
height=75,
|
||||||
width=50,
|
width=50,
|
||||||
rectAlignment="UpperLeft",
|
rectAlignment="UpperLeft",
|
||||||
offsetXY = "-65 0",
|
offsetXY = "-50 0",
|
||||||
-- Image will be set when the card is updated
|
-- Image will be set when the card is updated
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
@ -34,57 +34,57 @@ tourCardTemplate = {
|
|||||||
height=75,
|
height=75,
|
||||||
width=50,
|
width=50,
|
||||||
rectAlignment="UpperRight",
|
rectAlignment="UpperRight",
|
||||||
offsetXY = "65 0"
|
offsetXY = "50 0"
|
||||||
-- Image will be set when the card is updated
|
-- Image will be set when the card is updated
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
tag = "Panel",
|
tag = "Image",
|
||||||
attributes = {
|
attributes = {
|
||||||
|
id = "tourSpeechBubble",
|
||||||
color = "#F5F5DC",
|
color = "#F5F5DC",
|
||||||
height = 195,
|
height = 195,
|
||||||
width = 270,
|
width = 300,
|
||||||
rectAlignment = "MiddleCenter"
|
rectAlignment = "MiddleCenter",
|
||||||
},
|
image = "SpeechBubble",
|
||||||
children = {
|
|
||||||
{
|
|
||||||
tag = "Text",
|
|
||||||
attributes = {
|
|
||||||
id = "tourText",
|
|
||||||
height = 150,
|
|
||||||
width = 230,
|
|
||||||
rectAlignment = "UpperCenter",
|
|
||||||
offsetXY = "0 -10",
|
|
||||||
resizeTextForBestFit = true,
|
|
||||||
resizeTextMinSize = 10,
|
|
||||||
resizeTextMaxSize = 16,
|
|
||||||
color = "#050505",
|
|
||||||
alignment = "UpperLeft",
|
|
||||||
horizontalOverflow = "wrap",
|
|
||||||
}
|
|
||||||
}
|
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
tag = "Text",
|
||||||
|
attributes = {
|
||||||
|
id = "tourText",
|
||||||
|
height = 150,
|
||||||
|
width = 230,
|
||||||
|
rectAlignment = "UpperCenter",
|
||||||
|
offsetXY = "15 -15",
|
||||||
|
resizeTextForBestFit = true,
|
||||||
|
resizeTextMinSize = 10,
|
||||||
|
resizeTextMaxSize = 16,
|
||||||
|
color = "#050505",
|
||||||
|
alignment = "UpperLeft",
|
||||||
|
horizontalOverflow = "wrap",
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
tag = "Button",
|
tag = "Button",
|
||||||
attributes = {
|
attributes = {
|
||||||
id = "tourNext",
|
id = "tourNext",
|
||||||
height = 30,
|
height = 40,
|
||||||
width = 50,
|
width = 40,
|
||||||
color = "#FF0000",
|
|
||||||
rectAlignment = "LowerRight",
|
rectAlignment = "LowerRight",
|
||||||
offsetXY = "-5 5",
|
offsetXY = "-5 -45",
|
||||||
|
image = "NextArrow"
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
tag = "Button",
|
tag = "Button",
|
||||||
attributes = {
|
attributes = {
|
||||||
id = "tourStop",
|
id = "tourStop",
|
||||||
height = 30,
|
height = 40,
|
||||||
width = 50,
|
width = 40,
|
||||||
color = "#FF0000",
|
|
||||||
rectAlignment = "LowerLeft",
|
rectAlignment = "LowerLeft",
|
||||||
offsetXY = "5 5",
|
offsetXY = "35 -45",
|
||||||
|
image = "Exit"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
@ -8,18 +8,27 @@ do
|
|||||||
local CARD_ID = "tourCard"
|
local CARD_ID = "tourCard"
|
||||||
local LEFT_NARRATOR_ID = "tourNarratorImageLeft"
|
local LEFT_NARRATOR_ID = "tourNarratorImageLeft"
|
||||||
local RIGHT_NARRATOR_ID = "tourNarratorImageRight"
|
local RIGHT_NARRATOR_ID = "tourNarratorImageRight"
|
||||||
|
local BUBBLE_ID = "tourSpeechBubble"
|
||||||
local TEXT_ID = "tourText"
|
local TEXT_ID = "tourText"
|
||||||
local NEXT_BUTTON_ID = "tourNext"
|
local NEXT_BUTTON_ID = "tourNext"
|
||||||
local STOP_BUTTON_ID = "tourStop"
|
local STOP_BUTTON_ID = "tourStop"
|
||||||
|
|
||||||
-- Table centerpoint for the camera hook object. Camera handling is a bit erratic so it doesn't
|
-- Table centerpoint for the camera hook object. Camera handling is a bit erratic so it doesn't
|
||||||
-- always land right where you think it's going to, but it's close
|
-- always land right where you think it's going to, but it's close
|
||||||
local CAMERA_HOME = {
|
local HOOK_CAMERA_HOME = {
|
||||||
x = -30.2,
|
x = -30.2,
|
||||||
y = 60,
|
y = 60,
|
||||||
z = 0,
|
z = 0,
|
||||||
}
|
}
|
||||||
|
|
||||||
|
-- Default (0) position for the camera, as defined in the mod. If we don't recreate this position
|
||||||
|
-- EXACTLY when exiting the tour then camera controls get weird
|
||||||
|
local DEFAULT_CAMERA_POS = {
|
||||||
|
position = { x = -22.265, y = -2.5, z = 5.2575},
|
||||||
|
pitch=64.343,
|
||||||
|
yaw=90.333,
|
||||||
|
distance=104.7}
|
||||||
|
|
||||||
-- Global XML coordinates where we can present a card
|
-- Global XML coordinates where we can present a card
|
||||||
local SCREEN_POSITIONS = {
|
local SCREEN_POSITIONS = {
|
||||||
center = "0 0 0",
|
center = "0 0 0",
|
||||||
@ -46,9 +55,16 @@ do
|
|||||||
}
|
}
|
||||||
-- Camera gets really screwy when we finalize if we don't start settled in ThirdPerson at the
|
-- Camera gets really screwy when we finalize if we don't start settled in ThirdPerson at the
|
||||||
-- default position before attaching to the hook. Unfortunately there are no callbacks for when
|
-- default position before attaching to the hook. Unfortunately there are no callbacks for when
|
||||||
-- the movement is done, but the 2 sec seems to handle it
|
-- the movement is done, but the delay seems to handle it
|
||||||
Player[playerColor].setCameraMode("ThirdPerson")
|
Player[playerColor].setCameraMode("ThirdPerson")
|
||||||
Player[playerColor].lookAt({position={-22.265,-2.5,5.2575},pitch=64.343,yaw=90.333,distance=104.7})
|
Player[playerColor].lookAt(DEFAULT_CAMERA_POS)
|
||||||
|
-- Initial camera rotation is painfully slow. White and Orange players are likely oriented
|
||||||
|
-- correctly, but need a longer start delay for Green and Red
|
||||||
|
local delay = 0.5
|
||||||
|
if playerColor ~= "White" and playerColor ~= "Orange" then
|
||||||
|
delay = 2
|
||||||
|
broadcastToColor("Starting the tour, please wait...", playerColor)
|
||||||
|
end
|
||||||
Wait.time(function()
|
Wait.time(function()
|
||||||
internal.createTourCard(playerColor)
|
internal.createTourCard(playerColor)
|
||||||
-- XML update to add the new card takes a few frames to load, wait for it to finish then
|
-- XML update to add the new card takes a few frames to load, wait for it to finish then
|
||||||
@ -61,7 +77,7 @@ do
|
|||||||
return not Global.UI.loading
|
return not Global.UI.loading
|
||||||
end
|
end
|
||||||
)
|
)
|
||||||
end, 2)
|
end, delay)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Shows the next card in the tour script. This method is exposed (rather than being part of
|
-- Shows the next card in the tour script. This method is exposed (rather than being part of
|
||||||
@ -95,7 +111,7 @@ do
|
|||||||
internal.showCurrentCard = function(playerColor)
|
internal.showCurrentCard = function(playerColor)
|
||||||
internal.updateCardDisplay(playerColor)
|
internal.updateCardDisplay(playerColor)
|
||||||
local hook = getObjectFromGUID(tourState[playerColor].cameraHookGuid)
|
local hook = getObjectFromGUID(tourState[playerColor].cameraHookGuid)
|
||||||
hook.setPositionSmooth(CAMERA_HOME, false, false)
|
hook.setPositionSmooth(HOOK_CAMERA_HOME, false, false)
|
||||||
local delay = 0.5
|
local delay = 0.5
|
||||||
local cardIndex = tourState[playerColor].currentCardIndex
|
local cardIndex = tourState[playerColor].currentCardIndex
|
||||||
local lookPos
|
local lookPos
|
||||||
@ -136,13 +152,11 @@ do
|
|||||||
Player[playerColor].setCameraMode("ThirdPerson")
|
Player[playerColor].setCameraMode("ThirdPerson")
|
||||||
tourState[playerColor] = nil
|
tourState[playerColor] = nil
|
||||||
Wait.frames(function()
|
Wait.frames(function()
|
||||||
-- This resets to the default camera position. If we don't place the camera exactly at the
|
Player[playerColor].lookAt(DEFAULT_CAMERA_POS)
|
||||||
-- default, camera controls get weird
|
|
||||||
Player[playerColor].lookAt({position={-22.265,-2.5,5.2575},pitch=64.343,yaw=90.333,distance=104.7})
|
|
||||||
end, 3)
|
end, 3)
|
||||||
end
|
end
|
||||||
|
|
||||||
-- Updates the card UI to show the appropriate narrator and text.
|
-- Updates the card UI to show the appropriate card configuration.
|
||||||
---@param playerColor Player color to update card for
|
---@param playerColor Player color to update card for
|
||||||
internal.updateCardDisplay = function(playerColor)
|
internal.updateCardDisplay = function(playerColor)
|
||||||
local index = tourState[playerColor].currentCardIndex
|
local index = tourState[playerColor].currentCardIndex
|
||||||
@ -156,11 +170,17 @@ do
|
|||||||
if TOUR_SCRIPT[index].speakerSide == "right" then
|
if TOUR_SCRIPT[index].speakerSide == "right" then
|
||||||
Global.UI.setAttribute(internal.getUiId(LEFT_NARRATOR_ID, playerColor), "active", false)
|
Global.UI.setAttribute(internal.getUiId(LEFT_NARRATOR_ID, playerColor), "active", false)
|
||||||
Global.UI.setAttribute(internal.getUiId(RIGHT_NARRATOR_ID, playerColor), "active", true)
|
Global.UI.setAttribute(internal.getUiId(RIGHT_NARRATOR_ID, playerColor), "active", true)
|
||||||
Global.UI.setAttribute(internal.getUiId(TEXT_ID, playerColor), "rotation", "0 180 0")
|
Global.UI.setAttribute(internal.getUiId(BUBBLE_ID, playerColor), "rotation", "0 180 0")
|
||||||
|
Global.UI.setAttribute(internal.getUiId(TEXT_ID, playerColor), "offsetXY", "-15 -15")
|
||||||
|
Global.UI.setAttribute(internal.getUiId(NEXT_BUTTON_ID, playerColor), "offsetXY", "-35 -45")
|
||||||
|
Global.UI.setAttribute(internal.getUiId(STOP_BUTTON_ID, playerColor), "offsetXY", "5 -45")
|
||||||
else
|
else
|
||||||
Global.UI.setAttribute(internal.getUiId(LEFT_NARRATOR_ID, playerColor), "active", true)
|
Global.UI.setAttribute(internal.getUiId(LEFT_NARRATOR_ID, playerColor), "active", true)
|
||||||
Global.UI.setAttribute(internal.getUiId(RIGHT_NARRATOR_ID, playerColor), "active", false)
|
Global.UI.setAttribute(internal.getUiId(RIGHT_NARRATOR_ID, playerColor), "active", false)
|
||||||
Global.UI.setAttribute(internal.getUiId(TEXT_ID, playerColor), "rotation", "0 0 0")
|
Global.UI.setAttribute(internal.getUiId(BUBBLE_ID, playerColor), "rotation", "0 0 0")
|
||||||
|
Global.UI.setAttribute(internal.getUiId(TEXT_ID, playerColor), "offsetXY", "15 -15")
|
||||||
|
Global.UI.setAttribute(internal.getUiId(NEXT_BUTTON_ID, playerColor), "offsetXY", "-5 -45")
|
||||||
|
Global.UI.setAttribute(internal.getUiId(STOP_BUTTON_ID, playerColor), "offsetXY", "35 -45")
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -173,9 +193,9 @@ do
|
|||||||
local hookData = {
|
local hookData = {
|
||||||
Name = "BlockSquare",
|
Name = "BlockSquare",
|
||||||
Transform = {
|
Transform = {
|
||||||
posX = CAMERA_HOME.x,
|
posX = HOOK_CAMERA_HOME.x,
|
||||||
posY = CAMERA_HOME.y,
|
posY = HOOK_CAMERA_HOME.y,
|
||||||
posZ = CAMERA_HOME.z,
|
posZ = HOOK_CAMERA_HOME.z,
|
||||||
rotX = 0,
|
rotX = 0,
|
||||||
rotY = 270.0,
|
rotY = 270.0,
|
||||||
rotZ = 0,
|
rotZ = 0,
|
||||||
@ -220,11 +240,12 @@ do
|
|||||||
tourCardTemplate.attributes.id = internal.getUiId(CARD_ID, playerColor)
|
tourCardTemplate.attributes.id = internal.getUiId(CARD_ID, playerColor)
|
||||||
tourCardTemplate.children[1].attributes.id = internal.getUiId(LEFT_NARRATOR_ID, playerColor)
|
tourCardTemplate.children[1].attributes.id = internal.getUiId(LEFT_NARRATOR_ID, playerColor)
|
||||||
tourCardTemplate.children[2].attributes.id = internal.getUiId(RIGHT_NARRATOR_ID, playerColor)
|
tourCardTemplate.children[2].attributes.id = internal.getUiId(RIGHT_NARRATOR_ID, playerColor)
|
||||||
tourCardTemplate.children[3].children[1].attributes.id = internal.getUiId(TEXT_ID, playerColor)
|
tourCardTemplate.children[3].attributes.id = internal.getUiId(BUBBLE_ID, playerColor)
|
||||||
tourCardTemplate.children[4].attributes.id = internal.getUiId(NEXT_BUTTON_ID, playerColor)
|
tourCardTemplate.children[4].attributes.id = internal.getUiId(TEXT_ID, playerColor)
|
||||||
tourCardTemplate.children[4].attributes.onClick = self.getGUID().."/nextCard"
|
tourCardTemplate.children[5].attributes.id = internal.getUiId(NEXT_BUTTON_ID, playerColor)
|
||||||
tourCardTemplate.children[5].attributes.id = internal.getUiId(STOP_BUTTON_ID, playerColor)
|
tourCardTemplate.children[5].attributes.onClick = self.getGUID().."/nextCard"
|
||||||
tourCardTemplate.children[5].attributes.onClick = self.getGUID().."/stopTour"
|
tourCardTemplate.children[6].attributes.id = internal.getUiId(STOP_BUTTON_ID, playerColor)
|
||||||
|
tourCardTemplate.children[6].attributes.onClick = self.getGUID().."/stopTour"
|
||||||
internal.setDeepVisibility(tourCardTemplate, playerColor)
|
internal.setDeepVisibility(tourCardTemplate, playerColor)
|
||||||
|
|
||||||
local globalXml = Global.UI.getXmlTable()
|
local globalXml = Global.UI.getXmlTable()
|
||||||
|
@ -3,7 +3,7 @@
|
|||||||
TOUR_SCRIPT = {
|
TOUR_SCRIPT = {
|
||||||
{
|
{
|
||||||
narrator = "Roland",
|
narrator = "Roland",
|
||||||
text = "Despite my best efforts, looks like you found us. You may live to regret that. As long as you're here though we might as well show you around.\n\nUse the arrow to move forrward, and if the horrors get to be too much you can quit whenever you like. Ready to get started?",
|
text = "Despite my best efforts, looks like you found us. You may live to regret that. As long as you're here though we might as well show you around.\n\nUse the arrow to move forward, and if the horrors get to be too much you can quit whenever you like. Ready to get started?",
|
||||||
position = "center"
|
position = "center"
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
|
Loading…
x
Reference in New Issue
Block a user