Compare commits

..

3 Commits

Author SHA1 Message Date
Ader Alisma 01
f571fbf580 Cleanup 2025-06-29 17:44:15 -04:00
Ader Alisma 01
9e20b0d463 Deselect fonctionnel 2025-06-29 17:40:51 -04:00
Ader Alisma 01
f39f019912 Optimised observer 2025-06-09 19:19:15 -04:00
4 changed files with 19 additions and 98 deletions

View File

@ -4675,6 +4675,7 @@ MonoBehaviour:
m_Script: {fileID: 11500000, guid: 4c63e60a445cf4549999d898b25ab0ea, type: 3}
m_Name:
m_EditorClassIdentifier:
_canvas: {fileID: 1092900231}
--- !u!1 &1761692192
GameObject:
m_ObjectHideFlags: 0

View File

@ -1,71 +0,0 @@
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;
public class AllyUpgrade : MonoBehaviour, IPointerClickHandler
{
[SerializeField]
private GameObject _upgradeUI;
[SerializeField]
private List<UnitUpgrade> _upgradeList = new List<UnitUpgrade>();
private GameObject _instance = null;
public void OnPointerClick(PointerEventData eventData)
{
if (eventData.button == 0) //Left click
{
if (!_instance)
{
GameObject sceneCanvas = GameObject.Find("Canvas");
if (sceneCanvas != null)
{
Canvas canvas = sceneCanvas.GetComponent<Canvas>();
if (canvas == null)
{
Debug.Log("Canvas introuvable...");
}
else
{
_instance = Instantiate(_upgradeUI, Camera.main.WorldToScreenPoint(transform.position), Quaternion.identity, canvas.transform);
AssignUpgrades(canvas);
DeselectManager.Instance.SetAllyUpgrade(_instance);
}
}
}
else
{
Destroy(_instance);
_instance = null;
}
}
}
private void AssignUpgrades(Canvas canvas)
{
// Assign upgrade Prefabs
for (int i = 0; i < _instance.transform.childCount - 1; i++)
{
if (_upgradeList.Count > i && _upgradeList[i] != null)
{
GameObject upgradeEnfant = _instance.transform.Find("Upgrade" + (i + 1)).gameObject;
if (upgradeEnfant.TryGetComponent<UpgradePlacementButton>(out UpgradePlacementButton button))
{
button.Initialize(_upgradeList[i], gameObject, canvas);
//button.GetComponent<Selectable>().Select();
//button.gameObject.AddComponent<DeselectedAction>().Init(_instance);
}
}
}
}
private void OnDestroy()
{
if (_instance != null)
{
Debug.Log("Destroying upgrade UI");
Destroy(_instance);
_instance = null;
}
}
}

View File

@ -1,11 +0,0 @@
fileFormatVersion: 2
guid: edcd1782caa73a747b1f060d18ce0f18
MonoImporter:
externalObjects: {}
serializedVersion: 2
defaultReferences: []
executionOrder: 0
icon: {instanceID: 0}
userData:
assetBundleName:
assetBundleVariant:

View File

@ -1,47 +1,49 @@
using System.Collections;
using System.Collections.Generic;
using UnityEngine;
using UnityEngine.EventSystems;
using UnityEngine.UI;
public class DeselectManager : SingletonBehaviour<DeselectManager>
{
private GameObject _allyUpgrade;
[SerializeField]
private Canvas _canvas;
private void Update()
{
if (Input.GetMouseButton(0))
if (Input.GetMouseButton(0) && _allyUpgrade != null)
{
// Verifie var si click est sur un enfant d'AllyUpgrade
GameObject selectedObject = UnityEngine.EventSystems.EventSystem.current.currentSelectedGameObject;
if (selectedObject != null && _allyUpgrade != null && selectedObject.transform.IsChildOf(_allyUpgrade.transform))
// Vérifie si click est sur un enfant d'AllyUpgrade
PointerEventData pointerData = new PointerEventData(EventSystem.current)
{
position = Input.mousePosition
};
List<RaycastResult> results = new List<RaycastResult>();
GraphicRaycaster raycaster = _canvas.GetComponent<GraphicRaycaster>();
raycaster.Raycast(pointerData, results);
foreach (RaycastResult result in results)
{
if (result.gameObject.transform.IsChildOf(_allyUpgrade.transform))
{
return;
}
else
{
Debug.Log("Called to deselect from Observer");
if (_allyUpgrade != null)
{
}
Destroy(_allyUpgrade);
_allyUpgrade = null;
}
}
}
}
public void SetAllyUpgrade(GameObject allyUpgradeInstance)
{
if (_allyUpgrade == null)
{
_allyUpgrade = allyUpgradeInstance;
}
else if (_allyUpgrade != allyUpgradeInstance)
{
Destroy(_allyUpgrade);
_allyUpgrade = allyUpgradeInstance;
}
Debug.Log("AllyUpgrade set: " + _allyUpgrade?.name);
}
}