game(ui): very-close-to-done ui

This commit is contained in:
sippy-thinks 2024-08-11 19:57:50 +08:00
parent 417ee5393d
commit 537d2173a3
15 changed files with 322 additions and 211 deletions

View file

@ -264,7 +264,11 @@ PrefabInstance:
m_RemovedComponents: []
m_RemovedGameObjects: []
m_AddedGameObjects: []
m_AddedComponents: []
m_AddedComponents:
- targetCorrespondingSourceObject: {fileID: 974238578668270704, guid: c708a3b79cd542b42bbfedb17e213bc1,
type: 3}
insertIndex: -1
addedObject: {fileID: 491771526}
m_SourcePrefab: {fileID: 100100000, guid: c708a3b79cd542b42bbfedb17e213bc1, type: 3}
--- !u!1 &13596640
GameObject:
@ -7346,6 +7350,29 @@ Mesh:
offset: 0
size: 0
path:
--- !u!1 &491771518 stripped
GameObject:
m_CorrespondingSourceObject: {fileID: 974238578668270704, guid: c708a3b79cd542b42bbfedb17e213bc1,
type: 3}
m_PrefabInstance: {fileID: 1120089}
m_PrefabAsset: {fileID: 0}
--- !u!114 &491771526
MonoBehaviour:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 491771518}
m_Enabled: 1
m_EditorHideFlags: 0
m_Script: {fileID: 11500000, guid: 4995ad0b66292c144ab3819605824571, type: 3}
m_Name:
m_EditorClassIdentifier:
playerPosition: {fileID: 1013448445}
interactableDistance: 2
raycastLayers:
serializedVersion: 2
m_Bits: 439
--- !u!43 &554144876
Mesh:
m_ObjectHideFlags: 0
@ -8474,7 +8501,7 @@ MonoBehaviour:
m_Name:
m_EditorClassIdentifier:
associatedState: 2
mixer: {fileID: 24100000, guid: 7cbb70bac0ada294e87675a4a804cde7, type: 2}
mixer: {fileID: 0}
--- !u!43 &852189891
Mesh:
m_ObjectHideFlags: 0
@ -9137,6 +9164,12 @@ Mesh:
offset: 0
size: 0
path:
--- !u!4 &1013448445 stripped
Transform:
m_CorrespondingSourceObject: {fileID: 5542111180780342647, guid: c708a3b79cd542b42bbfedb17e213bc1,
type: 3}
m_PrefabInstance: {fileID: 1120089}
m_PrefabAsset: {fileID: 0}
--- !u!1 &1060921175
GameObject:
m_ObjectHideFlags: 0
@ -12925,135 +12958,6 @@ MonoBehaviour:
m_SelectedFaces:
m_SelectedEdges: []
m_SelectedVertices:
--- !u!1 &1332885280
GameObject:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
serializedVersion: 6
m_Component:
- component: {fileID: 1332885282}
- component: {fileID: 1332885281}
m_Layer: 0
m_Name: music
m_TagString: Untagged
m_Icon: {fileID: 0}
m_NavMeshLayer: 0
m_StaticEditorFlags: 0
m_IsActive: 1
--- !u!82 &1332885281
AudioSource:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 1332885280}
m_Enabled: 1
serializedVersion: 4
OutputAudioMixerGroup: {fileID: 164311610216181747, guid: 7cbb70bac0ada294e87675a4a804cde7,
type: 2}
m_audioClip: {fileID: 8300000, guid: 5e07e339ddf1eea44b3c4db9a02dd75c, type: 3}
m_PlayOnAwake: 1
m_Volume: 1
m_Pitch: 1
Loop: 1
Mute: 0
Spatialize: 0
SpatializePostEffects: 0
Priority: 128
DopplerLevel: 1
MinDistance: 1
MaxDistance: 500
Pan2D: 0
rolloffMode: 0
BypassEffects: 0
BypassListenerEffects: 0
BypassReverbZones: 0
rolloffCustomCurve:
serializedVersion: 2
m_Curve:
- serializedVersion: 3
time: 0
value: 1
inSlope: 0
outSlope: 0
tangentMode: 0
weightedMode: 0
inWeight: 0.33333334
outWeight: 0.33333334
- serializedVersion: 3
time: 1
value: 0
inSlope: 0
outSlope: 0
tangentMode: 0
weightedMode: 0
inWeight: 0.33333334
outWeight: 0.33333334
m_PreInfinity: 2
m_PostInfinity: 2
m_RotationOrder: 4
panLevelCustomCurve:
serializedVersion: 2
m_Curve:
- serializedVersion: 3
time: 0
value: 0
inSlope: 0
outSlope: 0
tangentMode: 0
weightedMode: 0
inWeight: 0.33333334
outWeight: 0.33333334
m_PreInfinity: 2
m_PostInfinity: 2
m_RotationOrder: 4
spreadCustomCurve:
serializedVersion: 2
m_Curve:
- serializedVersion: 3
time: 0
value: 0
inSlope: 0
outSlope: 0
tangentMode: 0
weightedMode: 0
inWeight: 0.33333334
outWeight: 0.33333334
m_PreInfinity: 2
m_PostInfinity: 2
m_RotationOrder: 4
reverbZoneMixCustomCurve:
serializedVersion: 2
m_Curve:
- serializedVersion: 3
time: 0
value: 1
inSlope: 0
outSlope: 0
tangentMode: 0
weightedMode: 0
inWeight: 0.33333334
outWeight: 0.33333334
m_PreInfinity: 2
m_PostInfinity: 2
m_RotationOrder: 4
--- !u!4 &1332885282
Transform:
m_ObjectHideFlags: 0
m_CorrespondingSourceObject: {fileID: 0}
m_PrefabInstance: {fileID: 0}
m_PrefabAsset: {fileID: 0}
m_GameObject: {fileID: 1332885280}
serializedVersion: 2
m_LocalRotation: {x: 0, y: 0, z: 0, w: 1}
m_LocalPosition: {x: 483.05478, y: 0.9047287, z: 496.26224}
m_LocalScale: {x: 1, y: 1, z: 1}
m_ConstrainProportionsScale: 0
m_Children: []
m_Father: {fileID: 0}
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
--- !u!43 &1466442468
Mesh:
m_ObjectHideFlags: 0
@ -26462,13 +26366,13 @@ Transform:
m_LocalScale: {x: 1, y: 1, z: 1}
m_ConstrainProportionsScale: 0
m_Children:
- {fileID: 1226619923}
- {fileID: 618797800}
- {fileID: 1794617895}
- {fileID: 785883831}
- {fileID: 1625449502}
- {fileID: 395649655}
- {fileID: 1826378110}
- {fileID: 618797800}
- {fileID: 1226619923}
m_Father: {fileID: 0}
m_LocalEulerAnglesHint: {x: 0, y: 0, z: 0}
--- !u!1 &1805235905
@ -27246,4 +27150,3 @@ SceneRoots:
- {fileID: 1060921176}
- {fileID: 596429548}
- {fileID: 897146492}
- {fileID: 1332885282}

View file

@ -58,6 +58,7 @@ public class AerialFaithDeathTrigger : MonoBehaviour
linkedLeapTrigger1.isPlayerInAir = false;
if (linkedLeapTrigger2 != null) linkedLeapTrigger2.isPlayerInAir = false;
if (linkedLeapTrigger3 != null) linkedLeapTrigger3.isPlayerInAir = false;
// TODO: kill player
GameManager.Instance.SetDisplayState(GameManager.DisplayState.OverlayFailedOverTimeMenu);
}
}

View file

@ -7,6 +7,7 @@
using System;
using UnityEngine;
using UnityEngine.InputSystem;
using UnityEngine.SceneManagement;
using UnityEngine.UIElements;
using Cursor = UnityEngine.Cursor;
@ -44,6 +45,16 @@ public class GameManager : MonoBehaviour
/// </summary>
[SerializeField] private GameObject guiHudObject;
/// <summary>
/// float to keep track of the elapsed play/run/speeder time
/// </summary>
private float _elapsedRunTime;
/// <summary>
/// checked when the scene is loaded to restart the game and skip the main menu
/// </summary>
private bool _restarting;
/// <summary>
/// the current state of the game
/// </summary>
@ -98,12 +109,6 @@ public class GameManager : MonoBehaviour
// destroy the new instance if it's not the singleton instance
Destroy(gameObject);
}
if (guiInteractionPromptObject == null)
throw new NullReferenceException("GameManager: guiInteractionPromptObject not set");
if (guiHudObject == null)
throw new NullReferenceException("GameManager: guiHudObject not set");
}
/// <summary>
@ -112,25 +117,53 @@ public class GameManager : MonoBehaviour
// /// <exception cref="Exception">generic exception it couldn't verify a safe state when starting the game</exception>
private void Start()
{
// set to the main menu state
SetDisplayState(DisplayState.ScreenMainMenu);
// pause the game
PauseGameHelper(DisplayState.ScreenMainMenu);
if (guiInteractionPromptObject == null)
throw new NullReferenceException("GameManager: guiInteractionPromptObject not set");
if (guiHudObject == null)
throw new NullReferenceException("GameManager: guiHudObject not set");
// if we're restarting, skip the main menu
if (_restarting)
{
Debug.Log("GameManager.Start: inherited _restarting, honouring it rn");
NewGame();
}
else
{
Debug.Log("GameManager.Start: setting to main menu and pausing");
SetDisplayState(DisplayState.ScreenMainMenu);
PauseGameHelper(DisplayState.ScreenMainMenu);
}
}
/// <summary>
/// game run speed run stopwatch logic
/// </summary>
// TODO: implement this (speed-run stopwatch)
private void Update()
{
if (Paused) return;
_elapsedRunTime += Time.deltaTime;
var minutes = _elapsedRunTime / 60;
var seconds = _elapsedRunTime % 60;
var milliseconds = _elapsedRunTime * 1000 % 1000;
_uiLabelStopwatch.text = $"{minutes:00}:{seconds:00}.{milliseconds:000}";
}
/// <summary>
/// called when the game object is enabled
/// </summary>
private void OnEnable()
{
InitialiseInterfaceElements();
}
/// <summary>
/// initialise ui elements used by the game[ manager]
/// </summary>
/// >
private void OnEnable()
private void InitialiseInterfaceElements()
{
_ui = guiInteractionPromptObject.GetComponent<UIDocument>()?.rootVisualElement;
_uiLabelInteractionPrompt = _ui.Q<Label>("InteractionPromptLabel");
@ -145,9 +178,9 @@ public class GameManager : MonoBehaviour
/// </summary>
private void HideMenuHelper()
{
// get all child menus in the "Menus" parent object
foreach (var menu in GameObject.FindGameObjectsWithTag("Interfaces"))
foreach (Transform menuChild in menu.transform)
// get all children in the "Menus" parent object
foreach (var child in GameObject.FindGameObjectsWithTag("Interfaces"))
foreach (Transform menuChild in child.transform)
{
// skip if it is 'GameInterface' object
if (menuChild.gameObject.CompareTag("GameInterface")) continue;
@ -160,6 +193,24 @@ public class GameManager : MonoBehaviour
}
}
/// <summary>
/// helper function to hide any game interfaces that are currently showing
/// </summary>
private void SetInterfaceActive(bool active)
{
// foreach (var inter in GameObject.FindGameObjectsWithTag("GameInterface"))
foreach (var child in GameObject.FindGameObjectsWithTag("Interfaces"))
foreach (Transform inter in child.transform)
{
if (!inter.gameObject.CompareTag("GameInterface")) continue;
Debug.Log($"GameManager.SetInterfaceActive: setting interface '{inter}' {active}");
inter.gameObject.SetActive(active);
}
if (active)
InitialiseInterfaceElements();
}
/// <summary>
/// helper function for <c>SetDisplayState()</c> to pause the game,
/// called before the incoming game state is set
@ -182,12 +233,14 @@ public class GameManager : MonoBehaviour
Debug.Log("GameManager.PauseGameHelper: freeing cursor for main menu");
Cursor.lockState = CursorLockMode.None;
Cursor.visible = true;
// only hide interfaces if we're transitioning to the main menu
SetInterfaceActive(false);
}
// freeze player input/control if we're not transitioning to a game state
if (incomingState != DisplayState.Game)
{
Debug.Log(GameObject.FindGameObjectWithTag("Player"));
var playerInput = GameObject.Find("PlayerArmature")?.GetComponent<PlayerInput>();
if (playerInput != null)
{
@ -255,6 +308,9 @@ public class GameManager : MonoBehaviour
// hide any menu that is currently showing
HideMenuHelper();
// show game interfaces
SetInterfaceActive(true);
// free the character controller
var playerInput = GameObject.Find("PlayerArmature")?.GetComponent<PlayerInput>();
if (playerInput == null) return;
@ -369,8 +425,17 @@ public class GameManager : MonoBehaviour
/// </summary>
public void RestartRun()
{
// TODO: implement this
throw new NotImplementedException();
_restarting = true;
SceneManager.LoadScene(SceneManager.GetActiveScene().name);
}
/// <summary>
/// function to restart the game
/// </summary>
public void RestartGame()
{
SceneManager.LoadScene(SceneManager.GetActiveScene().name);
Destroy(this);
}
/// <summary>

View file

@ -21,26 +21,32 @@ public class LiftController : MonoBehaviour
/// the time it takes for the lift to move from one floor to another
/// </summary>
public float duration;
/// <summary>
/// a bool to check if the lift is moving
/// </summary>
[HideInInspector] public bool moving;
/// <summary>
/// the current time of the lift moving for lerps
/// </summary>
private float _currentTime;
/// <summary>
/// the door of the lift
/// the door of the lift
/// </summary>
private Door _liftDoor;
/// <summary>
/// the start position of the lift
/// </summary>
private Vector3 _start;
/// <summary>
/// the target position of the lift
/// </summary>
private Vector3 _target;
/// <summary>
/// initialisation function
/// </summary>
@ -49,6 +55,7 @@ public class LiftController : MonoBehaviour
_liftDoor = transform.parent.GetComponentInChildren<Door>();
DoorCloser();
}
/// <summary>
/// to check if the door is open and call a function to close it
/// </summary>
@ -59,15 +66,17 @@ public class LiftController : MonoBehaviour
Invoke(nameof(CloseDoor), 2f);
Invoke(nameof(DoorCloser), 2f);
}
/// <summary>
/// to close the door
/// to close the door
/// </summary>
public void CloseDoor()
{
_liftDoor.Interact();
}
/// <summary>
/// to move the lift
/// to move the lift
/// </summary>
public IEnumerator Move(int floorsMoved)
{

View file

@ -17,10 +17,10 @@ public class OverlayPauseMenu : CommonMenu
/// </summary>
private Button _buttonResume;
/// <summary>
/// button to retry the run
/// </summary>
private Button _buttonRetry;
// /// <summary>
// /// button to retry the run
// /// </summary>
// private Button _buttonRetry;
/// <summary>
/// button to return to the main menu
@ -42,10 +42,10 @@ public class OverlayPauseMenu : CommonMenu
_buttonResume.clicked += PlayClick;
_buttonResume.clicked += OptionResumeGame;
// get the retry button from the ui root and subscribe appropriate functions
_buttonRetry = UI.Q<Button>("ButtonRetry");
_buttonRetry.clicked += PlayClick;
_buttonRetry.clicked += OptionRetryGame;
// // get the retry button from the ui root and subscribe appropriate functions
// _buttonRetry = UI.Q<Button>("ButtonRetry");
// _buttonRetry.clicked += PlayClick;
// _buttonRetry.clicked += OptionRetryGame;z
// get the return button from the ui root and subscribe appropriate functions
_buttonReturn = UI.Q<Button>("ButtonReturn");
@ -80,6 +80,6 @@ public class OverlayPauseMenu : CommonMenu
public static void OptionReturnToMainMenu()
{
Debug.Log("OverlayPauseMenu.OptionReturnToMainMenu (static shared): clicked, returning to main menu");
GameManager.Instance.SetDisplayState(GameManager.DisplayState.ScreenMainMenu);
GameManager.Instance.RestartGame();
}
}

View file

@ -36,16 +36,16 @@ public class Player : MonoBehaviour
/// </summary>
private GameManager _game;
/// <summary>
/// the raycast hit information
/// </summary>
private RaycastHit _hit;
/// <summary>
/// whether the player is looking at an interactable object
/// </summary>
private bool _raycast;
/// <summary>
/// the raycast hit information
/// </summary>
public RaycastHit Hit;
/// <summary>
/// initialisation function
/// </summary>
@ -62,7 +62,7 @@ public class Player : MonoBehaviour
_raycast = Physics.Raycast(
playerPosition.position,
playerPosition.TransformDirection(Vector3.forward),
out Hit,
out _hit,
interactableDistance,
raycastLayers
);
@ -75,7 +75,7 @@ public class Player : MonoBehaviour
if (!_raycast) return;
// show an interaction prompt if we're looking at an interactable object
var prompt = Hit.collider.GetComponent<CommonInteractable>()?.interactionPrompt;
var prompt = _hit.collider.GetComponent<CommonInteractable>()?.interactionPrompt;
if (prompt != "") Debug.Log(prompt);
}
@ -85,7 +85,7 @@ public class Player : MonoBehaviour
private void OnAction()
{
if (!_raycast) return;
Hit.collider.GetComponent<CommonInteractable>()?.Interact();
_hit.collider.GetComponent<CommonInteractable>()?.Interact();
// _currentInteractable?.Interact();
}

View file

@ -4,7 +4,6 @@
* description: interaction prompt demo with a probuilder donut
*/
using System;
using UnityEngine;
/// <summary>

View file

@ -4,7 +4,6 @@
* description: game run completion trigger collision
*/
using System;
using UnityEngine;
/// <summary>
@ -12,9 +11,8 @@ using UnityEngine;
/// </summary>
public class RunCompletionTrigger : MonoBehaviour
{
private void OnTriggerEnter(Collider other)
{
{
GameManager.Instance.SetDisplayState(GameManager.DisplayState.OverlayCompleteUnderTimeMenu);
}
}

View file

@ -4,7 +4,6 @@
* description: game run failure trigger collision
*/
using System;
using UnityEngine;
/// <summary>

View file

@ -7,7 +7,6 @@
using Unity.Mathematics;
using UnityEngine;
using UnityEngine.Audio;
using UnityEngine.Serialization;
using UnityEngine.UIElements;
/// <summary>
@ -20,22 +19,26 @@ public class ScreenOptionsMenu : CommonMenu
/// <summary>
/// button to return to the main menu
/// </summary>
public Button ButtonReturn;
private Button _buttonReturn;
/// <summary>
/// slider for master (music + sfx) volume
/// </summary>
public Slider SliderAudioMaster;
private Slider _sliderAudioMaster;
/// <summary>
/// slider for music volume
/// </summary>
public Slider SliderAudioMusic;
private Slider _sliderAudioMusic;
/// <summary>
/// slider for sfx volume
/// </summary>
public Slider SliderAudioSfx;
private Slider _sliderAudioSfx;
public void Start()
{
}
/// <summary>
/// function to associate a display state with the menu,
@ -48,35 +51,24 @@ public class ScreenOptionsMenu : CommonMenu
base.OnEnable();
// get the start button from the ui root and subscribe appropriate functions
ButtonReturn = UI.Q<Button>("ButtonReturn");
ButtonReturn.clicked += PlayClick;
ButtonReturn.clicked += OverlayPauseMenu.OptionReturnToMainMenu;
_buttonReturn = UI.Q<Button>("ButtonReturn");
_buttonReturn.clicked += PlayClick;
_buttonReturn.clicked += OverlayPauseMenu.OptionReturnToMainMenu;
// get the music slider from the ui root
SliderAudioMaster = UI.Q<Slider>("MasterSlider");
// TODO: and set the initial value to the current music volume
// SliderAudioMusic.value = Audio.GetMusicVolume() * 100;
// and subscribe appropriate functions
SliderAudioMaster.RegisterCallback<ChangeEvent<float>>(OptionSetMasterVolume);
// get the music slider from the ui root and subscribe appropriate functions
_sliderAudioMaster = UI.Q<Slider>("MasterSlider");
_sliderAudioMaster.RegisterCallback<ChangeEvent<float>>(OptionSetMasterVolume);
// get the music slider from the ui root
SliderAudioMusic = UI.Q<Slider>("MusicSlider");
// TODO: and set the initial value to the current music volume
// get the music slider from the ui root and subscribe appropriate functions
_sliderAudioMusic = UI.Q<Slider>("MusicSlider");
_sliderAudioMusic.RegisterCallback<ChangeEvent<float>>(OptionSetMusicVolume);
// and subscribe appropriate functions
SliderAudioMusic.RegisterCallback<ChangeEvent<float>>(OptionSetMusicVolume);
// get the sfx slider from the ui root
SliderAudioSfx = UI.Q<Slider>("SFXSlider");
// TODO: and set the initial value to the current sfx volume
// SliderAudioSfx.value = Audio.GetSfxVolume() * 100;
// and subscribe appropriate functions
SliderAudioSfx.RegisterCallback<ChangeEvent<float>>(OptionSetSfxVolume);
}
public void Start()
{
// get the sfx slider from the ui root and subscribe appropriate functions
_sliderAudioSfx = UI.Q<Slider>("SFXSlider");
_sliderAudioSfx.RegisterCallback<ChangeEvent<float>>(OptionSetSfxVolume);
}
private static float ConvertVolume(float linearVolume)

View file

@ -2,8 +2,8 @@
<Style src="project://database/Assets/UI%20Toolkit/Interfaces/Common.uss?fileID=7433441132597879392&amp;guid=7e22eeee55627cf478c5e125a8197039&amp;type=3#Common" />
<ui:VisualElement name="Root" style="flex-grow: 1; justify-content: space-around; align-items: center;">
<ui:VisualElement name="VertHolder" style="flex-grow: 1; justify-content: flex-start; align-items: center; align-self: auto; margin-top: 2%;">
<ui:Label tabindex="-1" parse-escape-sequences="true" display-tooltip-when-elided="true" text="00:53.47" name="CurrentStopwatchLabel" style="color: rgb(255, 255, 255); -unity-text-align: upper-center; white-space: normal; -unity-font: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold.otf?fileID=12800000&amp;guid=505dfbc18d2d4604db47ff55755f9dc8&amp;type=3#Fervojo-Bold&quot;); -unity-font-definition: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold%20SDF.asset?fileID=11400000&amp;guid=1abb65c0bf74b1649863fc75b2b83ac1&amp;type=2#Fervojo-Bold SDF&quot;); font-size: 64px; margin-bottom: 0; padding-bottom: 0;" />
<ui:Label tabindex="-1" parse-escape-sequences="true" display-tooltip-when-elided="true" text="1,000" name="CurrentScoreLabel" style="color: rgb(255, 255, 255); -unity-text-align: upper-center; white-space: normal; -unity-font: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold.otf?fileID=12800000&amp;guid=505dfbc18d2d4604db47ff55755f9dc8&amp;type=3#Fervojo-Bold&quot;); -unity-font-definition: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold%20SDF.asset?fileID=11400000&amp;guid=1abb65c0bf74b1649863fc75b2b83ac1&amp;type=2#Fervojo-Bold SDF&quot;); font-size: 32px; margin-top: 0; padding-top: 0;" />
<ui:Label tabindex="-1" parse-escape-sequences="true" display-tooltip-when-elided="true" text="00:53.47" name="CurrentStopwatchLabel" enable-rich-text="false" style="color: rgb(255, 255, 255); -unity-text-align: upper-center; white-space: normal; -unity-font: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold.otf?fileID=12800000&amp;guid=505dfbc18d2d4604db47ff55755f9dc8&amp;type=3#Fervojo-Bold&quot;); -unity-font-definition: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold%20SDF.asset?fileID=11400000&amp;guid=1abb65c0bf74b1649863fc75b2b83ac1&amp;type=2#Fervojo-Bold SDF&quot;); font-size: 64px; margin-bottom: 0; padding-bottom: 0;" />
<ui:Label tabindex="-1" parse-escape-sequences="true" display-tooltip-when-elided="true" text="1,000" name="CurrentScoreLabel" enable-rich-text="false" style="color: rgb(255, 255, 255); -unity-text-align: upper-center; white-space: normal; -unity-font: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold.otf?fileID=12800000&amp;guid=505dfbc18d2d4604db47ff55755f9dc8&amp;type=3#Fervojo-Bold&quot;); -unity-font-definition: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Bold%20SDF.asset?fileID=11400000&amp;guid=1abb65c0bf74b1649863fc75b2b83ac1&amp;type=2#Fervojo-Bold SDF&quot;); font-size: 32px; margin-top: 0; padding-top: 0;" />
</ui:VisualElement>
</ui:VisualElement>
</ui:UXML>

View file

@ -1,7 +1,7 @@
<ui:UXML xmlns:ui="UnityEngine.UIElements" xmlns:uie="UnityEditor.UIElements" editor-extension-mode="False">
<ui:VisualElement name="Root" style="flex-grow: 1; justify-content: space-around; align-items: center;">
<ui:VisualElement name="VertHolder" style="flex-grow: 1; justify-content: center; margin-top: 30%;">
<ui:Label tabindex="-1" parse-escape-sequences="true" display-tooltip-when-elided="true" text="Press E to Interact" name="InteractionPromptLabel" style="background-color: rgba(0, 0, 0, 0.33); color: rgb(255, 255, 255); -unity-text-align: upper-center; padding-right: 8px; padding-left: 8px; padding-top: 8px; padding-bottom: 8px; border-top-left-radius: 5px; border-top-right-radius: 5px; border-bottom-right-radius: 5px; border-bottom-left-radius: 5px; white-space: normal; -unity-font: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Medium.otf?fileID=12800000&amp;guid=9439a6fdc5392c6479cda7dd72a8f3f7&amp;type=3#Fervojo-Medium&quot;); -unity-font-definition: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Medium%20SDF.asset?fileID=11400000&amp;guid=45943718062c86e448361bd7f6506932&amp;type=2#Fervojo-Medium SDF&quot;); font-size: 28px;" />
<ui:Label tabindex="-1" parse-escape-sequences="true" display-tooltip-when-elided="true" text="Press E to Interact" name="InteractionPromptLabel" style="background-color: rgba(0, 0, 0, 0.33); color: rgb(255, 255, 255); -unity-text-align: upper-center; padding-right: 8px; padding-left: 8px; padding-top: 8px; padding-bottom: 8px; border-top-left-radius: 5px; border-top-right-radius: 5px; border-bottom-right-radius: 5px; border-bottom-left-radius: 5px; white-space: normal; -unity-font: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Medium.otf?fileID=12800000&amp;guid=9439a6fdc5392c6479cda7dd72a8f3f7&amp;type=3#Fervojo-Medium&quot;); -unity-font-definition: url(&quot;project://database/Assets/UI%20Toolkit/RLFonts/Fervojo/Fervojo-Medium%20SDF.asset?fileID=11400000&amp;guid=45943718062c86e448361bd7f6506932&amp;type=2#Fervojo-Medium SDF&quot;); font-size: 28px; display: flex; visibility: hidden;" />
</ui:VisualElement>
</ui:VisualElement>
</ui:UXML>

View file

@ -9,7 +9,7 @@
</ui:VisualElement>
<ui:VisualElement name="Buttonspace" style="flex-grow: 1; width: 50%; min-width: 50%; height: 50%; min-height: 50%; align-items: center; justify-content: flex-end; align-self: center;">
<ui:Button text="Resume Run" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonResume" />
<ui:Button text="Retry Run" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonRetry" />
<ui:Button text="Retry Run" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonRetry" style="display: none;" />
<ui:Button text="Return to Main Menu" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonReturn" />
</ui:VisualElement>
</ui:VisualElement>

View file

@ -8,7 +8,7 @@
</ui:VisualElement>
</ui:VisualElement>
<ui:VisualElement name="Buttonspace" style="flex-grow: 1; width: 50%; min-width: 50%; height: 50%; min-height: 50%; align-items: center; justify-content: flex-end; align-self: center;">
<ui:Button text="Retry Run" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonRetry" />
<ui:Button text="Retry Run" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonRetry" style="display: none;" />
<ui:Button text="Return to Main Menu" parse-escape-sequences="true" display-tooltip-when-elided="true" name="ButtonReturn" />
</ui:VisualElement>
</ui:VisualElement>

View file

@ -30,6 +30,151 @@
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "lightmapping.autoUnwrapLightmapUV",
"value": "{\"m_Value\":true}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "UnityEngine.ProBuilder.ProBuilderEditor-isUtilityWindow",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "editor.backFaceSelectEnabled",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "editor.toolbarIconGUI",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "experimental.enabled",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "editor.showSceneInfo",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "ShapeComponent.ResetSettings",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "ShapeComponent.SettingsEnabled",
"value": "{\"m_Value\":true}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "mesh.newShapesSnapToGrid",
"value": "{\"m_Value\":true}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "mesh.meshColliderIsConvex",
"value": "{\"m_Value\":false}"
},
{
"type": "System.Boolean, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "editor.autoRecalculateCollisions",
"value": "{\"m_Value\":false}"
},
{
"type": "UnityEngine.ProBuilder.SelectMode, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "editor.selectMode",
"value": "{\"m_Value\":1}"
},
{
"type": "UnityEngine.ProBuilder.SelectionModifierBehavior, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "editor.rectSelectModifier",
"value": "{\"m_Value\":2}"
},
{
"type": "UnityEngine.ProBuilder.RectSelectMode, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "editor.dragSelectRectMode",
"value": "{\"m_Value\":0}"
},
{
"type": "System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "ShapeBuilder.ActiveShapeIndex",
"value": "{\"m_Value\":9}"
},
{
"type": "System.Int32, mscorlib, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b77a5c561934e089",
"key": "ShapeBuilder.LastPivotLocation",
"value": "{\"m_Value\":1}"
},
{
"type": "UnityEngine.ProBuilder.PivotLocation, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "mesh.newShapePivotLocation",
"value": "{\"m_Value\":1}"
},
{
"type": "UnityEngine.Vector3, UnityEngine.CoreModule, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.LastPivotPosition",
"value": "{\"m_Value\":{\"x\":0.0,\"y\":0.0,\"z\":0.0}}"
},
{
"type": "UnityEngine.Vector3, UnityEngine.CoreModule, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.LastSize",
"value": "{\"m_Value\":{\"x\":2.637908935546875,\"y\":0.6330699920654297,\"z\":2.631824493408203}}"
},
{
"type": "UnityEngine.Quaternion, UnityEngine.CoreModule, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.LastRotation",
"value": "{\"m_Value\":{\"x\":0.0,\"y\":0.0,\"z\":0.0,\"w\":1.0}}"
},
{
"type": "UnityEngine.Material, UnityEngine.CoreModule, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "mesh.userMaterial",
"value": "{\"m_Value\":{\"instanceID\":0}}"
},
{
"type": "UnityEngine.Rendering.ShadowCastingMode, UnityEngine.CoreModule, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "mesh.shadowCastingMode",
"value": "{\"m_Value\":1}"
},
{
"type": "UnityEditor.StaticEditorFlags, UnityEditor.CoreModule, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "mesh.defaultStaticEditorFlags",
"value": "{\"m_Value\":0}"
},
{
"type": "UnityEngine.ProBuilder.ColliderType, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "mesh.newShapeColliderType",
"value": "{\"m_Value\":2}"
},
{
"type": "UnityEngine.ProBuilder.UnwrapParameters, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "lightmapping.defaultLightmapUnwrapParameters",
"value": "{\"m_Value\":{\"m_HardAngle\":88.0,\"m_PackMargin\":20.0,\"m_AngleError\":8.0,\"m_AreaError\":15.0}}"
},
{
"type": "UnityEngine.ProBuilder.Shapes.Shape, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.Plane",
"value": "{}"
},
{
"type": "UnityEngine.ProBuilder.Shapes.Shape, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.Stairs",
"value": "{}"
},
{
"type": "UnityEngine.ProBuilder.Shapes.Shape, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.Cube",
"value": "{}"
},
{
"type": "UnityEngine.ProBuilder.Shapes.Shape, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.Cone",
"value": "{}"
},
{
"type": "UnityEngine.ProBuilder.Shapes.Shape, Unity.ProBuilder, Version=0.0.0.0, Culture=neutral, PublicKeyToken=null",
"key": "ShapeBuilder.Torus",
"value": "{}"
}
]
}