summaryrefslogtreecommitdiff
path: root/Assembly_CSharp/UI/UIManager.cs
diff options
context:
space:
mode:
authorchai <215380520@qq.com>2023-11-26 23:52:30 +0800
committerchai <215380520@qq.com>2023-11-26 23:52:30 +0800
commit626381f061cde0c78564f6336e3131835cf20a5b (patch)
treed9991d6eda6ae5d7649ac91ecaa3b4dc833cd4c3 /Assembly_CSharp/UI/UIManager.cs
parent0e63c4a2c6dec8dfa260501fb7d73750261ea7b7 (diff)
* move
Diffstat (limited to 'Assembly_CSharp/UI/UIManager.cs')
-rw-r--r--Assembly_CSharp/UI/UIManager.cs47
1 files changed, 47 insertions, 0 deletions
diff --git a/Assembly_CSharp/UI/UIManager.cs b/Assembly_CSharp/UI/UIManager.cs
new file mode 100644
index 0000000..2a7081f
--- /dev/null
+++ b/Assembly_CSharp/UI/UIManager.cs
@@ -0,0 +1,47 @@
+using UnityEngine;
+
+public class UIManager : MonoBehaviour
+{
+ public static UIManager instance;
+
+ [SerializeField]
+ private LayerMask clickableMask;
+
+ private GameObject currentUI;
+
+ private void Awake()
+ {
+ instance = this;
+ }
+
+ public void SetNewUI(GameObject newUI)
+ {
+ if (currentUI != null)
+ {
+ Object.Destroy(currentUI);
+ }
+ currentUI = newUI;
+ }
+
+ public void CloseUI(GameObject oldUI)
+ {
+ currentUI = null;
+ Object.Destroy(oldUI);
+ }
+
+ private void Update()
+ {
+ if (Input.GetKeyDown(KeyCode.Escape) && currentUI != null)
+ {
+ CloseUI(currentUI);
+ }
+ if (!BuildingManager.instance.buildMode && Input.GetMouseButtonDown(0) && Physics.Raycast(Camera.main.ScreenPointToRay(Input.mousePosition), out var hitInfo, 2000f, clickableMask, QueryTriggerInteraction.Collide))
+ {
+ hitInfo.collider.GetComponent<IBuildable>()?.SpawnUI();
+ }
+ if (Input.GetMouseButtonDown(1))
+ {
+ CloseUI(currentUI);
+ }
+ }
+}