美文网首页Unity3D
【Unity3D】UGUI回调函数

【Unity3D】UGUI回调函数

作者: LittleFatSheep | 来源:发表于2023-02-24 16:27 被阅读0次

    1 简述

    UGUI 回调函数主要指鼠标进入、离开、点下、点击中、抬起、开始拖拽、拖拽中、拖拽结束 UI 控件触发的回调。使用 UGUI 回调函数时,需要引入 UnityEngine.EventSystems 命名空间。

    1) 回调函数

    回调函数 接口 说明
    void OnPointerEnter(PointerEventData eventData) IPointerEnterHandler 鼠标进入
    void OnPointerExit(PointerEventData eventData) IPointerExitHandler 鼠标离开
    void OnPointerDown(PointerEventData eventData) IPointerDownHandler 鼠标点下
    void OnPointerUp(PointerEventData eventData) IPointerUpHandler 鼠标抬起
    void OnPointerClick(PointerEventData eventData) IPointerClickHandler 鼠标单击
    void OnBeginDrag(PointerEventData eventData) IBeginDragHandler 鼠标开始拖拽
    void OnDrag(PointerEventData eventData) IDragHandler 鼠标拖拽中
    void OnEndDrag(PointerEventData eventData) IEndDragHandler 鼠标结束拖拽

    注意:OnPointerClick 方法在 OnPointerUp 方法之后执行;如果在拖拽过程中停下了,但是鼠标左键仍未抬起,OnDrag 方法不会执行。

    2)前提条件

    • 当前 UI 对象必须至少有 1 个基础组件(Text、Image、RawImage)
    • 基础 UI 组件中必须勾选 Raycast Target
    • 代码引入 UnityEngine.EventSystems 命名空间

    3)使用方法

    using UnityEngine;
    using UnityEngine.EventSystems;
    
    public class EventController : MonoBehaviour,
            IPointerEnterHandler,
            IPointerExitHandler,
            IPointerDownHandler,
            IPointerClickHandler,
            IPointerUpHandler,
            IBeginDragHandler,
            IDragHandler,
            IEndDragHandler {
    
        public void OnPointerEnter(PointerEventData eventData) {
            Debug.Log("OnPointerEnter");
        }
    
        public void OnPointerExit(PointerEventData eventData) {
            Debug.Log("OnPointerExit");
        }
    
        public void OnPointerDown(PointerEventData eventData) {
            Debug.Log("OnPointerDown");
        }
    
        public void OnPointerClick(PointerEventData eventData) {
            Debug.Log("OnPointerClick");
        }
    
        public void OnPointerUp(PointerEventData eventData) {
            Debug.Log("OnPointerUp");
        }
    
        public void OnBeginDrag(PointerEventData eventData) {
            Debug.Log("OnBeginDrag");
        }
    
        public void OnDrag(PointerEventData eventData) {
            Debug.Log("OnDrag");
        }
    
        public void OnEndDrag(PointerEventData eventData) {
            Debug.Log("OnEndDrag");
        }
    }
    

    2 应用

    1)UGUI 控件

    分别创建 Panel 和 2 个 Image 控件,并将 Image 控件重命名为 Monster 和 Spear,如下:

    给 Monster 和 Spear 添加 Sprite 图片如下:

    2)脚本组件

    SpearController.cs

    using UnityEngine;
    using UnityEngine.UI;
    using UnityEngine.EventSystems;
    
    public class SpearController : MonoBehaviour, IBeginDragHandler, IDragHandler, IEndDragHandler {
        private bool isDragging = false;
    
        public void OnBeginDrag(PointerEventData eventData) {
            GetComponent<Image>().raycastTarget = false;
            isDragging = true;
        }
    
        public void OnDrag(PointerEventData eventData) {
            Drag1();
            // Drag2();
        }
    
        public void OnEndDrag(PointerEventData eventData) {
            GetComponent<Image>().raycastTarget = true;
            isDragging = false;
        }
    
        public bool IsDragging() {
            return isDragging;
        }
    
        private void Drag1() { // Canvas 渲染模式为 Screen Space - Overlay
            transform.position = Input.mousePosition;
        }
    
        private void Drag2() { // Canvas 渲染模式为 Screen Space - Camera
            Vector3 worldPostion = Vector3.zero;
            RectTransformUtility.ScreenPointToWorldPointInRectangle(
                transform.root as RectTransform,
                Input.mousePosition,
                Camera.main,
                out worldPostion
            );
            transform.position = worldPostion;
        }
    }
    

    说明:SpearController 脚本组件附着在 Spear 对象上。

    MonsterController.cs

    using UnityEngine;
    using UnityEngine.UI;
    using UnityEngine.EventSystems;
    
    public class MonsterController : MonoBehaviour, IPointerEnterHandler, IPointerExitHandler {
        private Image image;
        private SpearController spear;
    
        private void Start() {
            image = GetComponent<Image>();
            spear = GameObject.Find("Spear").GetComponent<SpearController>();
        }
    
        public void OnPointerEnter(PointerEventData eventData) {
            if (spear.IsDragging()) {
                image.color = Color.red;
            }
        }
    
        public void OnPointerExit(PointerEventData eventData) {
            if (spear.IsDragging()) {
                image.color = Color.white;
            }
        }
    }
    

    说明:MonsterController 脚本组件附着在 Monster 对象上。

    3)运行效果

    声明:本文转自【Unity3D】UGUI回调函数

    相关文章

      网友评论

        本文标题:【Unity3D】UGUI回调函数

        本文链接:https://www.haomeiwen.com/subject/nvpohdtx.html