Unity UGUI事件接口概述

  UGUI 系统虽然提供了很多封装好的组件,但是要实现一些特定的功能还是显得非常有限,这时候就需要使用事件接口来完成UI功能的实现。比如我们想实现鼠标移动到图片上时自动显示图片的文字介绍,一般思路会想到写个射线来检测,但其实这样的检测UGUI已经替我们完成了,我们只需要实现检测到目标对象后所要执行的代码即可!
  UI 组件都是基于 UGUI 封装好的类和接口以及一些 Editor 文件来进行封装制作供开发者使用的,开发者利用这些封装好的工具,只需更专注于功能开发即可。UGUI 的代码是开源的,开发者可以查阅 UGUI 系统的具体细节来进行更深入的学习。UGUI 源码传送门:Unity-Technologies/UI
  Unity官方也为开发者提供了很多完整的案例,可以在 Assets Store上进行下载,搜索“Unity Samples: UI”。

【接口介绍】

命名空间:using UnityEngine.EventSystems;

IPointerEnterHandler

该接口实现方法如下:

public void OnPointerEnter(PointerEventData eventData)
{
    //当鼠标光标移入该对象时触发
}

IPointerExitHandler

该接口实现方法如下:

public void OnPointerExit(PointerEventData eventData)
{
    //当鼠标光标移出该对象时触发
}

IPointerDownHandler

该接口实现方法如下:

public void OnPointerDown(PointerEventData eventData)
{
    //鼠标点击A对象,按下鼠标时A对象响应此事件
}

IPointerUpHandler

该接口实现方法如下:

public void OnPointerUp(PointerEventData eventData)
{
    //鼠标点击A对象,抬起鼠标时响应
    //无论鼠标在何处抬起(即不在A对象中)
    //都会在A对象中响应此事件
    //注:响应此事件的前提是A对象必须响应过OnPointerDown事件
    Debug.Log("OnPointerUp " + name);
}

IPointerClickHandler

该接口实现方法如下:

public void OnPointerClick(PointerEventData eventData)
{
    //鼠标点击A对象,抬起鼠标时A对象响应此事件
    //注:按下和抬起时鼠标要处于同一对象上
}

IDragHandler

该接口实现方法如下:

public void OnDrag(PointerEventData eventData)
{
    //当鼠标在A对象按下并拖拽时 A对象每帧响应一次此事件
    //注:如果不实现此接口,则后面的四个接口方法都不会触发
    Debug.Log("OnDrag " + name);

    if (Input.GetMouseButton(0))
    {
        //拖拽移动图片
        SetDraggedPosition(eventData);
    }
}
private void SetDraggedPosition(PointerEventData eventData)
{
    var rt = gameObject.GetComponent<RectTransform>();
    Vector3 globalMousePos;
     if(RectTransformUtility.ScreenPointToWorldPointInRectangle(rt,eventData.position, eventData.pressEventCamera, out globalMousePos))
    {
        rt.position = globalMousePos;
    }
}

IInitializePotentialDragHandler

该接口实现方法如下:

public void OnInitializePotentialDrag(PointerEventData eventData)
{
    //当鼠标在A对象按下还没开始拖拽时 A对象响应此事件
    //注:此接口事件与IPointerDownHandler接口事件类似
    // 二者的执行顺序:先执行IPointerDownHandler,然后执行此接口事件
    Debug.Log("OnInitializePotentialDrag " + name);
}

IBeginDragHandler

该接口实现方法如下:

public void OnBeginDrag(PointerEventData eventData)
{
    //当鼠标在A对象按下并开始拖拽时 A对象响应此事件
    // 此事件在OnInitializePotentialDrag之后响应 OnDrag之前响应
    Debug.Log("OnBeginDrag " + name);
}

IEndDragHandler

该接口实现方法如下:

public void OnEndDrag(PointerEventData eventData)
{
    //当鼠标抬起时 A对象响应此事件
    Debug.Log("OnEndDrag " + name);
}

IDropHandler

该接口实现方法如下:

public void OnDrop(PointerEventData eventData)
{
    //A、B对象必须均实现IDropHandler接口,且A至少实现IDragHandler接口
    //当鼠标从A对象上开始拖拽,在B对象上抬起时 B对象响应此事件
    //此时name获取到的是B对象的name属性
    //eventData.pointerDrag表示发起拖拽的对象(GameObject)
    Debug.Log(eventData.pointerDrag.name + " OnDrop to " + name);
}

 

posted on 2019-03-04 13:58  北田  阅读(4892)  评论(0编辑  收藏  举报