diff options
| author | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
|---|---|---|
| committer | chai <215380520@qq.com> | 2024-05-19 16:05:58 +0800 |
| commit | 8e13e7e2874adc8982e16d1d2ed2e28d7480b45f (patch) | |
| tree | 63ef85c460288891f5a593d69afeca16cba050b3 /Thronefall_1_57/Decompile/Thronefall/PerkSelectionItem.cs | |
| parent | c5f145786f4c6d2fe4bea831dfc16e52228920a5 (diff) | |
+1.57
Diffstat (limited to 'Thronefall_1_57/Decompile/Thronefall/PerkSelectionItem.cs')
| -rw-r--r-- | Thronefall_1_57/Decompile/Thronefall/PerkSelectionItem.cs | 80 |
1 files changed, 80 insertions, 0 deletions
diff --git a/Thronefall_1_57/Decompile/Thronefall/PerkSelectionItem.cs b/Thronefall_1_57/Decompile/Thronefall/PerkSelectionItem.cs new file mode 100644 index 0000000..6e43dea --- /dev/null +++ b/Thronefall_1_57/Decompile/Thronefall/PerkSelectionItem.cs @@ -0,0 +1,80 @@ +using UnityEngine; +using UnityEngine.EventSystems; +using UnityEngine.UI; + +public class PerkSelectionItem : MonoBehaviour, IPointerEnterHandler, IEventSystemHandler, IPointerExitHandler +{ + private LevelSelectManager levelSelectManager; + + [SerializeField] + private GameObject selectedMarker; + + private PerkSelectionGroup perkSelectionGroup; + + private Color colorBasic; + + private Image image; + + [SerializeField] + private Color hoverColor; + + private bool mouseIsOver; + + private Equippable equippable; + + public Equippable Equippable => equippable; + + public bool Selected + { + get + { + return selectedMarker.activeInHierarchy; + } + set + { + selectedMarker.SetActive(value); + } + } + + public void OnPointerEnter(PointerEventData eventData) + { + mouseIsOver = true; + } + + public void OnPointerExit(PointerEventData eventData) + { + mouseIsOver = false; + if (levelSelectManager.ShowingTooltipFor == equippable) + { + levelSelectManager.ShowTooltip(null); + } + } + + private void Update() + { + image.color = (mouseIsOver ? hoverColor : colorBasic); + if (mouseIsOver) + { + levelSelectManager.ShowTooltip(equippable); + } + if (Input.GetMouseButtonDown(0) && mouseIsOver && (bool)perkSelectionGroup) + { + perkSelectionGroup.SelectPerk(this); + } + } + + public void Initialize(Equippable _equippable) + { + image = GetComponent<Image>(); + colorBasic = image.color; + perkSelectionGroup = GetComponentInParent<PerkSelectionGroup>(); + Debug.Log(perkSelectionGroup); + levelSelectManager = LevelSelectManager.instance; + image.sprite = _equippable.icon; + equippable = _equippable; + if (PerkManager.instance.CurrentlyEquipped.Contains(equippable) && (bool)perkSelectionGroup) + { + perkSelectionGroup.SelectPerk(this); + } + } +} |
